### PIC32MK GENERAL PURPOSE AND MOTOR CONTROL (GPK/MCM) WITH CAN FD FAMILY ### 32-bit General Purpose and Motor Control Application MCUs with CAN FD, FPU, ECC Flash, and up to 1 MB Live-Update Flash, 256 KB SRAM, 4 KB EEPROM and Op amps #### Operating Conditions: 2.3V to 3.6V - -40°C to +85°C, DC to 120 MHz - -40°C to +125°C, DC to 80 MHz #### Core: 120 MHz (up to 198 DMIPS) - MIPS32<sup>®</sup> microAptiv™ MCU core with Floating Point Unit - microMIPS™ mode for up to 40% smaller code size - DSP-enhanced core: - Four 64-bit accumulators - Single-cycle MAC, saturating and fractional math - Code-efficient (C and Assembly) architecture - · Two 32-bit core register files to reduce interrupt latency #### **Clock Management** - 8 MHz ±4% (FRC) internal oscillator -40°C to +85°C - Programmable PLLs and oscillator clock sources: HS and EC clock modes - Secondary USB PLL - 32 kHz Internal Low-power RC oscillator (LPRC) - Independent external low-power 32 kHz crystal oscillator - Fail-Safe Clock Monitor (FSCM) - Independent Watchdog Timers (WDT) and Deadman Timer (DMT) - Fast wake-up and start-up - Four Fractional clock out (REFCLKO) modules #### **Power Management** - Low-power management modes (Sleep, and Idle) - Power-on Reset (POR) and Brown-out Reset (BOR) - Programmable High/Low Voltage Detect (HLVD) - On-board capacitorless regulator #### **Motor Control PWM** - Up to twelve PWM pairs - Leading-edge and Trailing-edge blanking - Dead Time for rising and falling edges - **Dead Time Compensation** - 8.33 ns PWM Resolution - Clock Chopping for High-Frequency Operation - PWM Support for: - DC/DC, AC/DC, inverters, PFC, lighting - BLDC, PMSM, ACIM, SRM motors - Choice of 17 Fault and 12 Current Limit Inputs - Flexible Trigger Configuration for ADC Triggering #### **Motor Encoder Interface** - Six Quadrature Encoder Interface (QEI) modules: - Four inputs: Phase A, Phase B, Home, and Index #### Audio/Graphics/Touch Interfaces - External Graphics interfaces through PMP - Up to six I<sup>2</sup>S audio data communication interfaces - Up to six SPI control interfaces - Programmable audio Host clock: - Generation of fractional clock frequencies - Can be synchronized with USB clock - Can be tuned in run-time #### **Unique Features** - Permanent non-volatile 4-word unique device serial number - · Flash Error Code Correction (ECC) #### **Direct Memory Access (DMA)** - Up to eight std channels with automatic data size detection - Programmable Cyclic Redundancy Check (CRC) - Up to 64 KB transfers #### **Security Features** - Advanced Memory Protection: - Peripheral and memory region access control #### **Advanced Analog Features** - 12-bit ADC module: - Sum of all individual ADC's combined, 25.45 Msps 12-bit mode or 33.79 Msps 8-bit mode - 7 individual ADC modules - 3.75 Msps per S&H with dedicated DMA - Up to 42 analog inputs - Flexible and independent ADC trigger sources - Four high bandwidth op amps and five Comparators - Up to three 12-bit CDACs - Internal temperature sensor ±2°C accuracy - Capacitive Touch Divider (CVD) #### **Communication Interfaces** - Up to four CAN Flexible Data-Rate (CAN FD) modules (with dedicated DMA channels): - 2.0B Active with DeviceNet™ addressing support - ISO 11898-1:2015 compliant - Up to six UART modules (up to 25 Mbps): - Supports LIN 2.1 and IrDA<sup>®</sup> protocols Six SPI/I<sup>2</sup>S modules (SPI 50 Mbps) - Parallel Master Port (PMP) - Up to two FS USB 2.0-compliant On-The-Go (OTG) controllers - Up to four I<sup>2</sup>C modules (up to 1 Mbaud) with SMBus support Peripheral Pin Select (PPS) to enable remappable pin functions #### Timers/Output Compare/Input Capture/RTCC - Up to nine 16-bit or one 16-bit and eight 32-bit timers/counters for GP and MC devices and six additional QEI 32-bit timers for MC devices - 16 Output Compare (OC) modules - 16 Input Capture (IC) modules - PPS to enable function remap - Real-Time Clock and Calendar (RTCC) module #### Input/Output - 5V-tolerant pins with up to 22 mA source/sink - Selectable internal open drain, pull-ups, and pull-downs - External interrupts on all I/O pins - Five programmable edge/level-triggered interrupt pins #### **Qualification and Class-B Support** - Class-B Safety Library - Back-up internal oscillator - Clock monitor with back-up internal oscillator - Global register locking #### **Debugger Development Support** - In-circuit and in-application programming 2-wire or 4-wire MIPS<sup>®</sup> Enhanced JTAG interface Unlimited software and 12 complex breakpoints - IEEE 1149.2-compatible (JTAG) boundary scan Non-intrusive hardware-based instruction trace #### **Software and Tools Support** - C/C++ compiler with native DSP/fractional support - MPLAB® Harmony Integrated Software Framework - TCP/IP, USB, Graphics, and mTouch™ middleware - MFi, Android™ and Bluetooth® audio frameworks RTOS Kernels: Express Logic ThreadX, FreeRTOS™, OPENRTOS®, Micriµm® µC/OS™, and SEGGER embOS® **Packages** | Туре | VQFN | TQ | FP | |--------------------|------------------------------------|------------------------------------|------------------------------------| | Pin Count | 64 | 64 | 100 | | I/O Pins (up to) | 49 (GP devices)<br>49 (MC devices) | 49 (GP devices)<br>49 (MC devices) | 78 (GP devices)<br>78 (MC devices) | | Contact/Lead Pitch | 0.50 mm | 0.50 mm | 0.40 mm | | Dimensions | 9x9x0.9 mm | 10x10x1 mm | 12x12x1 mm | #### TABLE 1: PIC32MK GENERAL PURPOSE (GP) FAMILY FEATURES | | | | | ( | | | ( | F | Remappat | le P | eriph | nerals | 5 | | s) | r) | g) | | | | | | | | | | | | |-------------------|---------------------|------------------|----------------|---------------------------|------|----------|------------------------|-----------------|---------------------------------------|------|----------------------|------------------------------------|-------------|------------------|---------------------------|--------------------------|------------------------------------------|------------------------|-------------------|----------------|-----|------|--------|------|------|----------|-----------|-------| | Device | Program Memory (KB) | Data Memory (KB) | EE Memory (KB) | Floating Point Unit (FPU) | Suid | Packages | Boot Flash Memory (KB) | Remappable Pins | Timers/Capture/Compare <sup>(1)</sup> | UART | SPI/I <sup>2</sup> S | External Interrupts <sup>(2)</sup> | CAN FD 2.0B | 1 <sup>2</sup> C | Motor Control PWM (Pairs) | QEI (Quadrature Encoder) | DMA Channels<br>(Programmable/Dedicated) | ADC (Modules/Channels) | Op amp/Comparator | USB 2.0 FS OTG | dWd | RTCC | REFCLK | CDAC | ПШТЭ | I/O Pins | JTAG/ICSP | Trace | | PIC32MK0512GPK064 | 512 | 128 | | ., | 0.4 | TQFP, | 40 | ~ | 0/40/40 | _ | _ | _ | | | | | 0/40 | 7/00 | 4.5 | 1 | ., | | | _ | | 40 | ., | ~ | | PIC32MK1024GPK064 | 1024 | 256 | 4 | Υ | 64 | VQFN | 16 | Y | 9/16/16 | 6 | 6 | 5 | _ | 4 | _ | _ | 8/13 | 7/26 | 4/5 | 1 | Υ | 1 | 4 | 3 | 1 | 49 | Υ | Y | | PIC32MK0512GPK100 | 512 | 128 | | <b>Y</b> | 100 | TOED | 40 | Y | 0/40/40 | • | • | , | | , | | | 0/40 | 7/40 | 4/5 | ۰ | Υ | 1 | , | • | 4 | 70 | Υ | Y | | PIC32MK1024GPK100 | 1024 | 256 | 4 | Y | 100 | TQFP | 16 | Y | 9/16/16 | 6 | 6 | 5 | _ | 4 | _ | _ | 8/13 | 7/42 | 4/5 | 2 | Y | 1 | 4 | 3 | 1 | 78 | Y | Υ | Eight out of nine timers are remappable. Four out of five external interrupts are remappable. An '—' indicates this feature is not available for the listed device. #### TABLE 2: PIC32MK MOTOR CONTROL (MC) FAMILY FEATURES | | | | | | | | | R | emappal | ole P | erip | heral | s | | ) | ) | () | | | | | | | | | | | | | | |-------------------|---------------------|------------------|----------------|---------------------------|------|----------|------------------------|-----------------|---------------------------------------|-------|----------------------|------------------------------------|-------------|------------------|---------------------------|--------------------------|------------------------------------------|------------------------|-------------------|----------------|----------|-----|-------|------|--------|------|------|----------|-----------|-------| | Device | Program Memory (KB) | Data Memory (KB) | EE Memory (KB) | Floating Point Unit (FPU) | Pins | Packages | Boot Flash Memory (KB) | Remappable Pins | Timers/Capture/Compare <sup>(1)</sup> | UART | SPI/I <sup>2</sup> S | External Interrupts <sup>(2)</sup> | CAN FD 2.0B | 1 <sup>2</sup> C | Motor Control PWM (pairs) | QEI (Quadrature Encoder) | DMA Channels<br>(Programmable/Dedicated) | ADC (Modules/Channels) | Op amp/Comparator | USB 2.0 FS OTG | dWd | IBO | MCPWM | RTCC | REFCLK | CDAC | СТМО | I/O Pins | JTAG/ICSP | Trace | | PIC32MK0512MCM064 | 512 | 128 | | Υ | 0.4 | TQFP, | 16 | Υ | 0/40/40 | _ | • | _ | _ | _ | 40 | • | 0/40 | 7/ | 415 | _ | Υ | • | 40 | _ | | • | _ | 40 | Υ | Υ | | PIC32MK1024MCM064 | 1024 | 256 | 4 | ľ | 64 | VQFN | 16 | ť | 9/16/16 | 6 | 6 | 5 | 4 | 4 | 12 | 6 | 8/13 | 26 | 4/5 | 1 | ť | 6 | 12 | 1 | 4 | 3 | 1 | 49 | Y | r | | PIC32MK0512MCM100 | 512 | 128 | 4 | Υ | 100 | TQFP | 16 | Υ | 9/16/16 | 6 | 6 | 5 | 4 | 4 | 12 | 6 | 8/13 | 7/ | 4/5 | 2 | <b>v</b> | 6 | 12 | 1 | 4 | 3 | 1 | 78 | Υ | Υ | | PIC32MK1024MCM100 | 1024 | 256 | 4 | ľ | 100 | IQFP | 10 | ſ | 9/10/10 | υ | 9 | ວ | 4 | 4 | 12 | υ | 0/13 | 42 | 4/5 | 2 | ſ | 0 | 12 | ' | 4 | 3 | 1 | 10 | ī | ī | Eight out of nine timers are remappable. Four out of five external interrupts are remappable. An '—' indicates this feature is not available for the listed device. #### **Device Pin Tables** ### TABLE 3: PIN NAMES FOR 64-PIN GENERAL PURPOSE (GPK) DEVICES PIC32MK0512GPK064 PIC32MK1024GPK064 PIC32MK1024GPK064 | TCK/RPA7/PMD5/RA7 | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------------------------| | 2 RPB14/VBUSON1/PMD6/RB14 3 RPB15/PMD7/RB15 4 AN19/CVD19/RPG6/PMA5/RG6 5 AN18/CVD18/RPG7/SCL1/PMA4/RG7 6 AN17/RPG8/SDA1/PMA3/RG8 7 MCLR 8 AN16/RPG9/PMA2/RG9 9 Vss 10 VDD 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVss 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | Pin# | Full Pin Name | | 3 RPB15/PMD7/RB15 4 AN19/CVD19/RPG6/PMA5/RG6 5 AN18/CVD18/RPG7/SCL1/PMA4/RG7 6 AN17/RPG8/SDA1/PMA3/RG8 7 MCLR 8 AN16/RPG9/PMA2/RG9 9 Vss 10 VDD 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVss 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 1 | TCK/RPA7/PMD5/RA7 | | 4 AN19/CVD19/RPG6/PMA5/RG6 5 AN18/CVD18/RPG7/SCL1/PMA4/RG7 6 AN17/RPG8/SDA1/PMA3/RG8 7 MCLR 8 AN16/RPG9/PMA2/RG9 9 Vss 10 Vdd 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VdD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 2 | RPB14/VBUSON1/PMD6/RB14 | | 5 AN18/CVD18/RPG7/SCL1/PMA4/RG7 6 AN17/RPG8/SDA1/PMA3/RG8 7 MCLR 8 AN16/RPG9/PMA2/RG9 9 Vss 10 VDD 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 3 | RPB15/PMD7/RB15 | | 6 AN17/RPG8/SDA1/PMA3/RG8 7 MCLR 8 AN16/RPG9/PMA2/RG9 9 Vss 10 VDD 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 4 | AN19/CVD19/RPG6/PMA5/RG6 | | 7 MCLR 8 AN16/RPG9/PMA2/RG9 9 Vss 10 VDD 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN1-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN1-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVss 21 OA3OUT/AN6/C3IN1-/C4IN1+/C4IN1-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 5 | AN18/CVD18/RPG7/SCL1/PMA4/RG7 | | 8 AN16/RPG9/PMA2/RG9 9 Vss 10 VDD 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVss 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 6 | AN17/RPG8/SDA1/PMA3/RG8 | | 9 Vss 10 Vdd 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVdd 20 AVss 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 Vdd 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 7 | MCLR | | 10 VDD 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVss 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 8 | AN16/RPG9/PMA2/RG9 | | 11 AN10/RPA12/RA12 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 9 | Vss | | 12 AN9/RPA11/RA11 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 10 | VDD | | 13 OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 11 | AN10/RPA12/RA12 | | 14 OA2IN+/AN1/C2IN1+/RPA1/RA1 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 12 | AN9/RPA11/RA11 | | 15 PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 13 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | 16 PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 14 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | 17 PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 15 | PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 | | 18 PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 16 | PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 | | 19 AVDD 20 AVSS 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 VSS 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 17 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 | | 20 AVss 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 Vdd 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 18 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 | | 21 OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 Vdd 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 19 | AVDD | | 22 OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 Vdd 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 20 | AVss | | 23 OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 Vdd 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 21 | OA3OUT/AN6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 | | 24 AN11/C1IN2-/PMA12/RC11 25 Vss 26 Vdd 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 22 | OA3IN-/AN7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 | | 25 Vss 26 Vdd 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 23 | OA3IN+/AN8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 | | 26 VDD 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 24 | AN11/C1IN2-/PMA12/RC11 | | 27 AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 25 | Vss | | 28 AN13/C3IN2-/SCL4/PMA10/RE13 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 26 | VDD | | 29 AN14/RPE14/PMA1/RE14 30 AN15/RPE15/PMA0/RE15 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 27 | AN12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 | | 30 AN15/RPE15/PMA0/RE15<br>31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 28 | AN13/C3IN2-/SCL4/PMA10/RE13 | | 31 TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | 29 | AN14/RPE14/PMA1/RE14 | | | 30 | AN15/RPE15/PMA0/RE15 | | 32 RPB4/SCL2/PMA8/RB4 | 31 | TDI/CDAC3/AN26/RPA8/SDA2/PMA9/RA8 | | | 32 | RPB4/SCL2/PMA8/RB4 | | Pin# | Full Pin Name | |------|----------------------------------------------------| | 33 | OA5IN+/CDAC1/AN24/C5IN1+/C5IN3-/RPA4/RA4 | | 34 | VBUS | | 35 | Vusb3v3 | | 36 | D1- | | 37 | D1+ | | 38 | VDD | | 39 | OSC1/CLKI/AN49/RPC12/RC12 | | 40 | OSC2/CLKO/RPC15/RC15 | | 41 | Vss | | 42 | RD8 | | 43 | PGD2/RPB5/SDA3/USBID1/RB5 | | 44 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | | 45 | CDAC2/AN48/RPC10/PMA14/RC10 | | 46 | OA5OUT/AN25/C5IN4-/RPB7/SCK1/INT0/RB7 | | 47 | SOSCI/RPC13 <sup>(5)</sup> /RC13 <sup>(5)</sup> | | 48 | SOSCO/T1CK/RPB8 <sup>(5)</sup> /RB8 <sup>(5)</sup> | | 49 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/RPB9/RB9 | | 50 | TRCLK/RPC6/RC6 | | 51 | TRD0/RPC7/RC7 | | 52 | TRD1/RPC8/PMWR/RC8 | | 53 | TRD2/RPD5/PMRD/RD5 | | 54 | TRD3/RPD6/RD6 | | 55 | RPC9/RC9 | | 56 | Vss | | 57 | VDD | | 58 | RPF0/RF0 | | 59 | RPF1/RF1 | | 60 | RPB10/PMD0/RB10 | | 61 | RPB11/PMD1/RB11 | | 62 | RPB12/PMD2/RB12 | | 63 | RPB13/CTPLS/PMD3/RB13 | | 64 | TDO/PMD4/RA10 | - : The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and 13.3 "Peripheral Pin Select (PPS)" for restrictions. - Every I/O port pin (RAx-RGx) can be used as a change notification pin (CNAx-CNGx). See 13.0 "I/O Ports" for more information. - 3: Shaded pins are 5V tolerant. - 4: The metal plane at the bottom of the QFN device is not connected to any pins and is recommended to be connected to VSs externally. - 5: Functions are restricted to input functions only and inputs will be slower than the standard inputs. Change notification interrupt is not available on this pin. Change notification interrupt is not available on this pin. TABLE 4: PIN NAMES FOR 64-PIN MOTOR CONTROL (MCM) DEVICES ### 64-PIN $\mathsf{VQFN}^{(4)}$ AND $\mathsf{TQFP}$ (TOP $\mathsf{VIEW}$ ) PIC32MK0512MCM064 PIC32MK1024MCM064 | Pin# | Full Pin Name | |------|---------------------------------------------------------| | 1 | TCK/RPA7/PWM10H/PWM4L/PMD5/RA7 | | 2 | RPB14/PWM1H/VBUSON1/PMD6/RB14 | | 3 | RPB15/PWM7H/PWM1L/PMD7/RB15 | | 4 | AN19/CVD19/RPG6/PWM10L/PMA5/RG6 | | 5 | AN18/CVD18/RPG7/PWM10H/SCL1/PMA4/RG7 | | 6 | AN17/CVD17/RPG8/SDA1/PMA3/RG8 | | 7 | MCLR | | 8 | AN16/CVD16/RPG9/PMA2/RG9 | | 9 | Vss | | 10 | VDD | | 11 | AN10/CVD10/RPA12/RA12 | | 12 | AN9/CVD9/RPA11/RA11 | | 13 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | 14 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | 15 | PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 | | 16 | PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/RPB1/CTED1/PMA6/RB1 | | 17 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 | | 18 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 | | 19 | AVDD | | 20 | AVss | | 21 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 | | 22 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/PMA7/RC1 | | 23 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/FLT3/PMA13/RC2 | | 24 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | | 25 | Vss | | 26 | VDD | | 27 | AN12/CVD12/C2IN2-/C5IN2-/SDA4/FLT5/PMA11/RE12 | | 28 | AN13/CVD13/C3IN2-/FLT6/SCL4/PMA10/RE13 | | 29 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | | 30 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | | 31 | TDI/DAC3/AN26/CVD26/RPA8/SDA2/PMA9/RA8 | | 32 | FLT15/RPB4/SCL2/PMA8/RB4 | | Pin # | Full Pin Name | |-------|----------------------------------------------------| | 33 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/RPA4/RA4 | | 34 | VBUS | | 35 | Vusb3v3 | | 36 | D- | | 37 | D+ | | 38 | VDD | | 39 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | | 40 | OSCO/CLKO/RPC15/RC15 | | 41 | Vss | | 42 | RD8 | | 43 | PGD2/RPB5/SDA3/USBID1/RB5 | | 44 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | | 45 | DAC2/AN48/CVD48/RPC10/PMA14/PMCS/RC10 | | 46 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/INT0/RB7 | | 47 | SOSCI/RPC13 <sup>(5)</sup> /RC13 <sup>(5)</sup> | | 48 | SOSCO/T1CK/RPB8 <sup>(5)</sup> /RB8 <sup>(5)</sup> | | 49 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/RPB9/RB9 | | 50 | TRCLK/RPC6/PWM6H/RC6 | | 51 | TRD0/RPC7/PWM12H/PWM6L/RC7 | | 52 | TRD1/RPC8/PWM5H/PMWR/RC8 | | 53 | TRD2/RPD5/PWM12H/PMRD/RD5 | | 54 | TRD3/RPD6/PWM12L/RD6 | | 55 | RPC9/PWM11H/PWM5L/RC9 | | 56 | Vss | | 57 | VDD | | 58 | RPF0/PWM11H/RF0 | | 59 | RPF1/PWM11L/RF1 | | 60 | RPB10/PWM3H/PMD0/RB10 | | 61 | RPB11/PWM9H/PWM3L/PMD1/RB11 | | 62 | RPB12/PWM2H/PMD2/RB12 | | 63 | RPB13/PWM8H/PWM2L/CTPLS/PMD3/RB13 | | 64 | TDO/PWM4H/PMD4/RA10 | - 1: The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and 13.3 "Peripheral Pin Select (PPS)" for restrictions. - 2: Every I/O port pin (RAx-RGx) can be used as a change notification pin (CNAx-CNGx). See 13.0 "I/O Ports" for more information. - 3: Shaded pins are 5V tolerant. - 4: The VQFN package metal pad at the bottom of the device is not connected to any pins and is recommended to be connected to Vss externally. - 5: Functions are restricted to input functions only and inputs will be slower than standard inputs. Change notification interrupt is not available on this pin. Change notification interrupt is not available on this pin. TABLE 5: PIN NAMES FOR 100-PIN GENERAL PURPOSE (GPK) DEVICES 100-PIN TQFP (TOP VIEW) ### PIC32MK0512GPK100 PIC32MK1024GPK100 | Pin# | Full Pin Name | |------|-----------------------------------------------| | 1 | AN23/CVD23/PMA23/RG15 | | 2 | VDD | | 3 | TCK/RPA7/PMD5/RA7 | | 4 | RPB14/VBUSON1/PMD6/RB14 | | 5 | RPB15/PMD7/RB15 | | 6 | RD1 | | 7 | RD2 | | 8 | RPD3/RD3 | | 9 | RPD4/RD4 | | 10 | AN19/CVD19/RPG6/VBUSON2/PMA5/RG6 | | 11 | AN18/CVD18/RPG7/SCL1/PMA4/RG7 | | 12 | AN17/CVD17/RPG8/SDA1/PMA3/RG8 | | 13 | MCLR# | | 14 | AN16/CVD16/RPG9/PMA2/RG9 | | 15 | VSS | | 16 | VDD | | 17 | AN22/CVD22/RG10 | | 18 | AN21/CVD21/RE8 | | 19 | AN20/CVD20/RE9 | | 20 | AN10/CVD10/RPA12/RA12 | | 21 | AN9/CVD9/RPA11/RA11 | | 22 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | 23 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | 24 | PGD3/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 | | 25 | PGC3/OA1OUT/AN3/C1IN4-/C4IN2-/RPB1/CTED1/RB1 | | 26 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 | | 27 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 | | 28 | VREF-/AN33/CVD33/PMA7/RF9 | | 29 | VREF+/AN34/CVD34/PMA6/RF10 | | 30 | AVDD | | 31 | AVSS | | 32 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 | | 33 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/RC1 | | 34 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/PMA13/RC2 | | 35 | AN11/CVD11/C1IN2-/PMA12/RC11 | | Pin# | Full Pin Name | |------|-----------------------------------------------| | 36 | VSS | | 37 | VDD | | 38 | AN35/CVD35/RG11 | | 39 | AN36/CVD36/RF13 | | 40 | AN37/CVD37/RF12 | | 41 | AN12/CVD12/C2IN2-/C5IN2-/SDA4/PMA11/RE12 | | 42 | AN13/CVD13/C3IN2-/SCL4/PMA10/RE13 | | 43 | AN14/CVD14/RPE14/PMA1/RE14 | | 44 | AN15/CVD15/RPE15/PMA0/RE15 | | 45 | VSS | | 46 | VDD | | 47 | AN38/CVD38/RD14 | | 48 | AN39/CVD39/RD15 | | 49 | TDI/DAC3/AN26/CVD26/RPA8/SDA2/PMA9/RA8 | | 50 | RPB4/SCL2/PMA8/RB4 | | 51 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/RPA4/RA4 | | 52 | AN40/CVD40/RPE0/RE0 | | 53 | AN41/CVD41/RPE1/RE1 | | 54 | VBUS1 | | 55 | VUSB3V3 | | 56 | D1- | | 57 | D1+ | | 58 | VBUS2 | | 59 | D2- | | 60 | D2+ | | 61 | AN45/CVD45/RF5 | | 62 | VDD | | 63 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | | 64 | OSCO/CLKO/RPC15/RC15 | | 65 | VSS | | 66 | AN46/CVD46/RPA14/RA14 | | 67 | AN47/CVD47/RPA15/RA15 | | 68 | RD8 | | 69 | PGD2/RPB5/SDA3/USBID1/RB5 | | 70 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | - The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and 13.3 "Peripheral Pin Select (PPS)" 1: for restrictions. - Every I/O port pin (RAx-RGx) can be used as a change notification pin (CNAx-CNGx). See 13.0 "I/O Ports" for more information. Shaded pins are 5V tolerant. - 3: - Functions are restricted to input functions only and inputs will be slower than standard inputs. Change notification interrupt is not available on this pin. Change notification interrupt is not available on this pin. ### TABLE 5: PIN NAMES FOR 100-PIN GENERAL PURPOSE (GPK) DEVICES (CONTINUED) ### 100-PIN TQFP (TOP VIEW) ### PIC32MK0512GPK100 PIC32MK1024GPK100 | Pin# | Full Pin Name | |------|----------------------------------------------------| | 71 | DAC2/AN48/CVD48/RPC10/PMA14/PMCS/RC10 | | 72 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/INT0/RB7 | | 73 | SOSCI/RPC13 <sup>(4)</sup> /RC13 <sup>(4)</sup> | | 74 | SOSCO/RPB8 <sup>(4)</sup> /T1CK/RB8 <sup>(4)</sup> | | 75 | VSS | | 76 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/RPB9/RB9 | | 77 | RPC6/USBID2/PMA16/RC6 | | 78 | RPC7/PMA17/RC7 | | 79 | PMD12/RD12 | | 80 | PMD13/RD13 | | 81 | RPC8/PMWR/RC8 | | 82 | RPD5/PMRD/RD5 | | 83 | RPD6/PMD14/RD6 | | 84 | RPC9/PMD15/RC9 | | 85 | VSS | | Pin# | Full Pin Name | |------|-----------------------| | 86 | VDD | | 87 | RPF0/PMD11/RF0 | | 88 | RPF1/PMD10/RF1 | | 89 | RPG1/PMD9/RG1 | | 90 | RPG0/PMD8/RG0 | | 91 | TRCLK/PMA18/RF6 | | 92 | TRD3/PMA19/RF7 | | 93 | RPB10/PMD0/RB10 | | 94 | RPB11/PMD1/RB11 | | 95 | TRD2/PMA20/RG14 | | 96 | TRD1/RPG12/PMA21/RG12 | | 97 | TRD0/PMA22/RG13 | | 98 | RPB12/PMD2/RB12 | | 99 | RPB13/CTPLS/PMD3/RB13 | | 100 | TDO/PMD4/RA10 | - 1: The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and 13.3 "Peripheral Pin Select (PPS)" for restrictions. - 2: Every I/O port pin (RAx-RGx) can be used as a change notification pin (CNAx-CNGx). See 13.0 "I/O Ports" for more information. - 3: Shaded pins are 5V tolerant. - 4: Function's are restricted to input functions only and inputs will be slower than standard inputs. Change notification interrupt is not available on this pin. Change notification interrupt is not available on this pin. #### TABLE 6: PIN NAMES FOR 100-PIN MOTOR CONTROL (MCM) DEVICES ### 100-PIN TQFP (TOP VIEW) ### PIC32MK0512MCM100 PIC32MK1024MCM100 | Pin# | Full Pin Name | |------|---------------------------------------------------| | 1 | AN23/CVD23/PWM7L/PMA23/RG15 | | 2 | VDD | | 3 | TCK/RPA7/PWM10H/PWM4L/PMD5/RA7 | | 4 | RPB14/PWM1H/VBUSON1/PMD6/RB14 | | 5 | RPB15/PWM7H/PWM1L/PMD7/RB15 | | 6 | PWM11H/PWM5L/RD1 | | 7 | PWM5H/RD2 | | 8 | RPD3/PWM12H/PWM6L/RD3 | | 9 | RPD4/PWM6H/RD4 | | 10 | AN19/CVD19/RPG6/PWM10L/VBUSON2/PMA5/RG6 | | 11 | AN18/CVD18/RPG7/PWM10H/SCL1/PMA4/RG7 | | 12 | AN17/CVD17/RPG8/SDA1/PMA3/RG8 | | 13 | MCLR | | 14 | AN16/CVD16/RPG9/PMA2/RG9 | | 15 | Vss | | 16 | VDD | | 17 | AN22/CVD22/RG10 | | 18 | AN21/CVD21/RE8 | | 19 | AN20/CVD20/RE9 | | 20 | AN10/CVD10/RPA12/RA12 | | 21 | AN9/CVD9/RPA11/RA11 | | 22 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | 23 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | 24 | PGD3/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 | | 25 | PGC3/OA1OUT/AN3/C1IN4-/C4IN2-/RPB1/CTED1/RB1 | | 26 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/RPB2/RB2 | | 27 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/RPB3/RB3 | | 28 | VREF-/AN33/CVD33/PMA7/RF9 | | 29 | VREF+/AN34/CVD34/PMA6/RF10 | | 30 | AVDD | | 31 | AVss | | 32 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 | | 33 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/RC1 | | 34 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/FLT3/PMA13/RC2 | | 35 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | | Pin# | Full Pin Name | |------|-----------------------------------------------| | 36 | Vss | | 37 | VDD | | 38 | AN35/CVD35/RG11 | | 39 | AN36/CVD36/RF13 | | 40 | AN37/CVD37/RF12 | | 41 | AN12/CVD12/C2IN2-/C5IN2-/SDA4/FLT5/PMA11/RE12 | | 42 | AN13/CVD13/C3IN2-/SCL4/FLT6/PMA10/RE13 | | 43 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | | 44 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | | 45 | Vss | | 46 | VDD | | 47 | AN38/CVD38/RD14 | | 48 | AN39/CVD39/RD15 | | 49 | TDI/DAC3/AN26/CVD26/RPA8/SDA2/PMA9/RA8 | | 50 | FLT15/RPB4/SCL2/PMA8/RB4 | | 51 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/RPA4/RA4 | | 52 | AN40/CVD40/RPE0/RE0 | | 53 | AN41/CVD41/RPE1/RE1 | | 54 | VBUS | | 55 | Vusbava | | 56 | D1- | | 57 | D1+ | | 58 | VBUS2 | | 59 | D2- | | 60 | D2+ | | 61 | AN45/CVD45/RF5 | | 62 | VDD | | 63 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | | 64 | OSCO/CLKO/RPC15/RC15 | | 65 | Vss | | 66 | AN46/CVD46/RPA14/RA14 | | 67 | AN47/CVD47/RPA15/RA15 | | 68 | RD8 | | 69 | PGD2/RPB5/SDA3/USBID1/RB5 | | 70 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | - The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and 13.3 "Peripheral Pin Select (PPS)" Every I/O port pin (RAx-RGx) can be used as a change notification pin (CNAx-CNGx). See 13.0 "I/O Ports" for more information. Shaded pins are 5V tolerant. for restrictions. - 2: - 3: - Functions are restricted to input functions only and inputs will be slower than standard inputs. Change notification interrupt is not available on this pin. Change notification interrupt is not available on this pin. ### TABLE 6: PIN NAMES FOR 100-PIN MOTOR CONTROL (MCM) DEVICES (CONTINUED) 100-PIN TQFP (TOP VIEW) ### PIC32MK0512MCM100 PIC32MK1024MCM100 | Pin# | Full Pin Name | |------|----------------------------------------------------| | 71 | DAC2/AN48/CVD48/RPC10/PMA14/PMCS/RC10 | | 72 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/INT0/RB7 | | 73 | SOSCI/RPC13 <sup>(4)</sup> /RC13 <sup>(4)</sup> | | 74 | SOSCO/T1CK/RPB8 <sup>(4)</sup> /RB8 <sup>(4)</sup> | | 75 | Vss | | 76 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/RPB9/RB9 | | 77 | RPC6/USBID2/PMA16/RC6 | | 78 | RPC7/PMA17/RC7 | | 79 | PMD12/RD12 | | 80 | PMD13/RD13 | | 81 | RPC8/PMWR/RC8 | | 82 | RPD5/PWM12H/PMRD/RD5 | | 83 | RPD6/PWM12L/PMD14/RD6 | | 84 | RPC9/PMD15/RC9 | | 85 | Vss | | Pin# | Full Pin Name | |------|-----------------------------------| | 86 | VDD | | 87 | RPF0/PWM11H/PMD11/RF0 | | 88 | RPF1/PWM11L/PMD10/RF1 | | 89 | RPG1/PMD9/RG1 | | 90 | RPG0/PMD8/RG0 | | 91 | TRCLK/PWM9H/PMA18/RF6 | | 92 | TRD3/PWM9L/PMA19/RF7 | | 93 | RPB10/PWM3H/PMD0/RB10 | | 94 | RPB11/PWM9H/PWM3L/PMD1/RB11 | | 95 | TRD2/PWM8H/PMA20/RG14 | | 96 | TRD1/RPG12/PWM8L/PMA21/RG12 | | 97 | TRD0/PWM7H/PMA22/RG13 | | 98 | RPB12/PWM2H/PMD2/RB12 | | 99 | RPB13/PWM8H/PWM2L/CTPLS/PMD3/RB13 | | 100 | TDO/PWM4H/PMD4/RA10 | - 1: The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and 13.3 "Peripheral Pin Select (PPS)" for restrictions. - 2: Every I/O port pin (RAx-RGx) can be used as a change notification pin (CNAx-CNGx). See 13.0 "I/O Ports" for more information. - 3: Shaded pins are 5V tolerant. - 4: Functions are restricted to input functions only and inputs will be slower than standard inputs. Change notification interrupt is not available on this pin. Change notification interrupt is not available on this pin. ### **Table of Contents** | 1.0 | Device Overview | 13 | |------|---------------------------------------------------------------------------------------------|-----| | 2.0 | Guidelines for Getting Started with 32-bit MCUs | 35 | | 3.0 | CPU | 47 | | 4.0 | Memory Organization | 69 | | 5.0 | Flash Program Memory | 96 | | 6.0 | Data EEPROM | | | 7.0 | Resets | 113 | | 8.0 | CPU Exceptions and Interrupt Controller | 121 | | 9.0 | Oscillator Configuration | 167 | | 10.0 | Prefetch Module | | | 11.0 | Direct Memory Access (DMA) Controller | 193 | | 12.0 | USB On-The-Go (OTG) | 221 | | 13.0 | I/O Ports | 247 | | 14.0 | Timer1 | 283 | | 15.0 | Timer2 Through Timer9 | 289 | | 16.0 | Deadman Timer (DMT) | 295 | | 17.0 | Watchdog Timer (WDT) | 303 | | | Input Capture | | | | Output Compare | | | 20.0 | Serial Peripheral Interface (SPI) and Inter-IC Sound (I <sup>2</sup> S) | 322 | | 21.0 | Inter-Integrated Circuit (I <sup>2</sup> C) | 334 | | 22.0 | Universal Asynchronous Receiver Transmitter (UART) | 342 | | 23.0 | Parallel Master Port (PMP) | 356 | | | Real-Time Clock and Calendar (RTCC) | | | | 12-bit High-Speed Successive Approximation Register (SAR) Analog-to-Digital Converter (ADC) | | | | Controller Area Network with Flexible Data-rate (CAN FD) | | | | Op Amp/Comparator Module | | | | Charge Time Measurement Unit (CTMU) | | | | Control Digital-to-Analog Converter (CDAC) | | | | Quadrature Encoder Interface (QEI) | | | | Motor Control PWM Module | | | | High/Low-Voltage Detect (HLVD) | | | | Power-Saving Features | | | | Special Features | | | | Instruction Set | | | | Development Support | | | | Electrical Characteristics | | | | AC and DC Characteristics Graphs | | | | Packaging Information | | | | Appendix A: Migration Guide | | | | Appendix B: Revision History | | | | Microchip Web Site | | | | omer Change Notification Service | | | | omer Support | | | Prod | luct Identification System | 778 | ### TO OUR VALUED CUSTOMERS It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced. If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at docerrors@microchip.com. We welcome your feedback. #### **Most Current Data Sheet** To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at: http://www.microchip.com You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000000A is version A of document DS30000000). #### **Errata** An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies. To determine if an errata sheet exists for a particular device, please check with one of the following: - · Microchip's Worldwide Web site; http://www.microchip.com - · Your local Microchip sales office (see last page) When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using. #### **Customer Notification System** Register on our web site at www.microchip.com to receive the most current information on all of our products. #### Referenced Sources This device data sheet is based on the following individual sections of the "PIC32 Family Reference Manual". These documents should be considered as the general reference for the operation of a particular module or device feature. **Note:** To access the following documents, refer to the *Documentation > Reference Manuals* section of the Microchip PIC32 web site: http://www.microchip.com/pic32. - Section 1. "Introduction" (DS60001127) - Section 4. "Prefetch Cache Module" (DS60001119) - Section 7. "Resets" (DS60001118) - Section 8. "Interrupt Controller" (DS60001108) - Section 9. "Watchdog, Deadman, and Power-up Timers" (DS60001114) - Section 10. "Power-Saving Features" (DS60001130) - Section 12. "I/O Ports" (DS60001120) - Section 13. "Parallel Master Port (PMP)" (DS60001128) - Section 14. "Timers" (DS60001105) - Section 15. "Input Capture" (DS60001122) - Section 16. "Output Compare" (DS60001111) - Section 21. "Universal Asynchronous Receiver Transmitter (UART)" (DS60001107) - Section 22. "12-bit High-Speed Successive Approximation Register (SAR) Analog-to-Digital Converter (ADC)" (DS60001344) - Section 23. "Serial Peripheral Interface (SPI)" (DS60001106) - Section 27. "USB On-The-Go (OTG)" (DS60001126) - Section 29. "Real-Time Clock and Calendar (RTCC)" (DS60001125) - Section 31. "Direct Memory Access (DMA) Controller" (DS60001117) - Section 32. "Configuration" (DS60001124) - Section 33. "Programming and Diagnostics" (DS60001129) - Section 37. "Charge Time Measurement Unit (CTMU)" (DS60001167) - Section 39. "Op amp/Comparator" (DS60001178) - Section 42. "Oscillators with Enhanced PLL" (DS60001250) - Section 43. "Quadrature Encoder Interface (QEI)" (DS60001346) - Section 44. "Motor Control PWM (MCPWM) (DS60001393) - Section 45. "Control Digital-to-Analog Converter (CDAC)" (DS60001327) - Section 48. "Memory Organization and Permissions" (DS60001214) - Section 50. "CPU for Devices with MIPS32<sup>®</sup> microAptiv™ and M-Class Cores" (DS60001192) - Section 52. "Flash Program Memory with Support for Live Update" (DS60001193) - Section 56. "Controller Area Network Flexible Data-Rate (CAN FD)" (DS number pending) - Section 58. "Data EEPROM" (DS60001341) | 1 1032MIX 01 | Titll OAN | ı Dı alılılı | У | |--------------|-----------|--------------|---| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 1.0 DEVICE OVERVIEW Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the documents listed in the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). This data sheet contains device-specific information for PIC32MK GPK/MCM with CAN FD Family of devices. Figure 1-1 illustrates a general block diagram of the core and peripheral modules in the PIC32MK GPK/MCM with CAN FD Family of devices. Table 1-21 through Table 1-22 list the pinout I/O descriptions for the pins shown in the device pin tables, Table 3 and Table 5. FIGURE 1-1: PIC32MK GPK/MCM WITH CAN FD FAMILY BLOCK DIAGRAM VDD $\boxtimes$ Power-up VDD, VSS OSC2/CLKO OSC1/CLKI OSC Timer MCLR Oscillators Oscillator Voltage Regulator **FRC** Start-up Timei Secondary sosoc X◀ Oscillators Oscillator Power-on **PORTG** Precision PLL Reset Band Gap **PORTF** Switch VDD X Reference **DIVIDERS** Watchdog **PORTE** LPRC Timer PORTD Oscillator PLL USB **USBCLK** Brown-out **PORTC** RTCC CRU Reset **SYSCLK PORTB PBCLK** Dead Man **FSCM** DSWDT PORTA Timer Deep Sleep SIB **BSCAN EVIC** ADC0-5, 7 SAR USB2 FD2 FD4 FD1 CAN FD3 FS USB1 **EJTAG** INT CAN CAN MIPS32® FS DMAC microAptiv™ MCU Core with FPU SYSCLK PB4 Ds Is T10 /12 ′I3 Sonics - Shared Link Tn = Target Interface Number Sonics Dedicated Link In = Initiator Interface Number 15 Т8 Т9 ICD PB3 PB2 PB6 Flash PB1 Prefetch SRAM1 SRAM2 Cache DSCON IC10-IC16 **CFG** 12-Channel Motor Control 140 **PWM** OC10-OC16 RTCC PPS PFM Flash Wrapper OC1-OC9 Timer1-WDT SPI3-SPI6 140-bit Wide 140-bit Wide Panel Panel IC1-IC9 Flash Memory Flash Memory DMT I2C1-I2C2 12C3-12C4 PMP CRU DFM Flash Wrapper UART3-SPI1-SPI2 **UART6** Data EE 16K HLVD Control 33-bit Wide UART1-2 12-bit CDAC2 Flash Memory CTMU plus Temperature Sensor 12-bit CDAC1 12-bit CDAC3 Comparator 1-5 QEI1-QEI6 Op amp 1-4 Note: Not all features are available on all devices. Refer to the family feature tables (Table 1 and Table 2) for the list of available features by device. TABLE 1-1: ADC1 PINOUT I/O DESCRIPTIONS | | Pin Nu | umber | | | | |----------|-----------------|-------------------------|-------------|----------------|---------------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | AN0 | 22 | 13 | I | Analog | Analog Input Channels | | AN1 | 23 | 14 | I | Analog | | | AN2 | 24 | 15 | I | Analog | | | AN3 | 25 | 16 | I | Analog | | | AN4 | 26 | 17 | I | Analog | | | AN5 | 27 | 18 | I | Analog | | | AN6 | 32 | 21 | I | Analog | | | AN7 | 33 | 22 | I | Analog | | | AN8 | 34 | 23 | I | Analog | | | AN9 | 21 | 12 | I | Analog | | | AN10 | 20 | 11 | I | Analog | | | AN11 | 35 | 24 | I | Analog | | | AN12 | 41 | 27 | I | Analog | | | AN13 | 42 | 28 | I | Analog | | | AN14 | 43 | 29 | I | Analog | | | AN15 | 44 | 30 | I | Analog | | | AN16 | 14 | 8 | I | Analog | | | AN17 | 12 | 6 | I | Analog | | | AN18 | 11 | 5 | I | Analog | | | AN19 | 10 | 4 | I | Analog | | | AN20 | 19 | | I | Analog | | | AN21 | 18 | - | I | Analog | | | AN22 | 17 | | I | Analog | | | AN23 | 1 | _ | I | Analog | | | AN24 | 51 | 33 | I | Analog | | | AN25 | 72 | 46 | I | Analog | | | AN26 | 49 | 31 | I | Analog | | | AN27 | 76 | 49 | I | Analog | | | AN33 | 28 | _ | I | Analog | | | AN34 | 29 | _ | I | Analog | | | AN35 | 38 | _ | I | Analog | | | AN36 | 39 | _ | I | Analog | | | AN37 | 40 | _ | I | Analog | | | AN38 | 47 | _ | I | Analog | | | AN39 | 48 | _ | I | Analog | | | AN40 | 52 | _ | I | Analog | | | AN41 | 53 | _ | I | Analog | | | AN45 | 61 | _ | I | Analog | | | AN46 | 66 | _ | I | Analog | | | AN47 | 67 | _ | I | Analog | | | AN48 | 71 | 45 | I | Analog | | | AN49 | 63 | 39 | Į | Analog | 1 | | Legend: | | MOS-comp | -4:1-1- : | | Analog = Analog input P = Power | **Legend:** CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer Analog = Analog input O = Output PPS = Peripheral Pin Select P = Power I = Input **TABLE 1-2: OSCILLATOR PINOUT I/O DESCRIPTIONS** | | Pin Nu | umber | | | | |----------|-----------------|-------------------------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | CLKI | 63 | 39 | I | ST | External clock source input. Always associated with OSC1 pin function. | | CLKO | 64 | 40 | 0 | CMOS | Oscillator crystal output. Connects to crystal in Crystal Oscillator mode. Optionally functions as CLKO in FRC and EC modes. Always associated with OSC2 pin function. | | OSC1 | 63 | 39 | I | ST/CMOS | Oscillator crystal input. ST buffer when configured in RC mode; CMOS otherwise. | | OSC2 | 64 | 40 | 0 | _ | Oscillator crystal output. Connects to crystal in Crystal Oscillator mode. Optionally functions as CLKO in FRC and EC modes. | | SOSCI | 73 | 47 | I | ST/CMOS | 32.768 kHz low-power oscillator crystal input; CMOS otherwise. | | SOSCO | 74 | 48 | 0 | CMOS | 32.768 low-power oscillator crystal output. | | REFCLKI | PPS | PPS | I | _ | One of several alternate REFCLKOx user-selectable input clock sources. | | REFCLKO1 | PPS | PPS | 0 | _ | Reference Clock Generator Outputs 1-4 | | REFCLKO2 | PPS | PPS | 0 | | | | REFCLKO3 | PPS | PPS | 0 | _ | | | REFCLKO4 | PPS | PPS | 0 | _ | | Legend: CMOS = CMOS-compatible input or output Analog = Analog input ST = Schmitt Trigger input with CMOS levels O = Output P = Power I = Input TTL = Transistor-transistor Logic input buffer PPS = Peripheral Pin Select **TABLE 1-3:** IC1 THROUGH IC16 PINOUT I/O DESCRIPTIONS | | Pin N | umber | | | | |----------|-----------------|-------------------------|-------------|----------------|--------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | Input Capture | | IC1 | PPS | PPS | I | ST | Input Capture Inputs 1-6 | | IC2 | PPS | PPS | I | ST | | | IC3 | PPS | PPS | I | ST | | | IC4 | PPS | PPS | I | ST | | | IC5 | PPS | PPS | I | ST | | | IC6 | PPS | PPS | I | ST | | | IC7 | PPS | PPS | I | ST | | | IC8 | PPS | PPS | I | ST | | | IC9 | PPS | PPS | I | ST | | | IC10 | PPS | PPS | I | ST | | | IC11 | PPS | PPS | I | ST | | | IC12 | PPS | PPS | I | ST | | | IC13 | PPS | PPS | I | ST | | | IC14 | PPS | PPS | I | ST | | | IC15 | PPS | PPS | I | ST | | | IC16 | PPS | PPS | I | ST | | Legend: CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power I = Input TTL = Transistor-transistor Logic input buffer **OC1 THROUGH OC16 PINOUT I/O DESCRIPTIONS TABLE 1-4:** | | Pin Nu | umber | | | | | | | | | |----------|-----------------|-------------------------|-------------|----------------|------------------------------|--|--|--|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | Output Compare | | | | | | | | | | | OC1 | PPS | PPS | 0 | _ | Output Compare Outputs 1-16 | | | | | | | OC2 | PPS | PPS | 0 | _ | | | | | | | | OC3 | PPS | PPS | 0 | _ | | | | | | | | OC4 | PPS | PPS | 0 | _ | | | | | | | | OC5 | PPS | PPS | 0 | _ | | | | | | | | OC6 | PPS | PPS | 0 | _ | | | | | | | | OC7 | PPS | PPS | 0 | _ | | | | | | | | OC8 | PPS | PPS | 0 | _ | | | | | | | | OC9 | PPS | PPS | 0 | _ | | | | | | | | OC10 | PPS | PPS | 0 | _ | | | | | | | | OC11 | PPS | PPS | 0 | _ | | | | | | | | OC12 | PPS | PPS | 0 | _ | | | | | | | | OC13 | PPS | PPS | 0 | _ | | | | | | | | OC14 | PPS | PPS | 0 | _ | | | | | | | | OC15 | PPS | PPS | 0 | _ | | | | | | | | OC16 | PPS | PPS | 0 | _ | | | | | | | | OCFA | PPS | PPS | I | ST | Output Compare Fault A Input | | | | | | | OCFB | PPS | PPS | I | ST | Output Compare Fault B Input | | | | | | Legend: CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power TTL = Transistor-transistor Logic input buffer PPS = Peripheral Pin Select I = Input #### **TABLE 1-5**: **EXTERNAL INTERRUPTS PINOUT I/O DESCRIPTIONS** | | Pin Number | | | | | | | |---------------------|-----------------|-------------------------|-------------|----------------|----------------------|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | External Interrupts | | | | | | | | | INT0 | 72 | 46 | I | ST | External Interrupt 0 | | | | INT1 | PPS | PPS | I | ST | External Interrupt 1 | | | | INT2 | PPS | PPS | I | ST | External Interrupt 2 | | | | INT3 | PPS | PPS | I | ST | External Interrupt 3 | | | | INT4 | PPS | PPS | I | ST | External Interrupt 4 | | | CMOS = CMOS-compatible input or output Legend: ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power I = Input TTL = Transistor-transistor Logic input buffer TABLE 1-6: PORTA THROUGH PORTG PINOUT I/O DESCRIPTIONS | | Pin Nu | ımber | | | | |----------|-----------------|-------------------------|----------------|----------------|-----------------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | PORTA | | RA0 | 22 | 13 | I/O | ST | PORTA is a bidirectional I/O port | | RA1 | 23 | 14 | I/O | ST | | | RA4 | 51 | 33 | I/O | ST | | | RA7 | 3 | 1 | I/O | ST | | | RA8 | 49 | 31 | I/O | ST | | | RA10 | 100 | 64 | I/O | ST | | | RA11 | 21 | 12 | I/O | ST | | | RA12 | 20 | 11 | I/O | ST | | | RA14 | 66 | _ | I/O | ST | | | RA15 | 67 | _ | I/O | ST | | | | 1 | | | | PORTB | | RB0 | 24 | 15 | I/O | ST | PORTB is a bidirectional I/O port | | RB1 | 25 | 16 | I/O | ST | | | RB2 | 26 | 17 | I/O | ST | | | RB3 | 27 | 18 | I/O | ST | | | RB4 | 50 | 32 | I/O | ST | | | RB5 | 69 | 43 | I/O | ST | | | RB6 | 70 | 44 | I/O | ST | | | RB7 | 72 | 46 | I/O | ST | | | RB8 | 74 | 48 | I | ST | | | RB9 | 76 | 49 | I/O | ST | | | RB10 | 93 | 60 | I/O | ST | | | RB11 | 94 | 61 | I/O | ST | | | RB12 | 98 | 62 | I/O | ST | - | | RB13 | 99 | 63 | I/O | ST | - | | RB14 | 4 | 2 | I/O | ST | - | | RB15 | 5 | 3 | I/O | ST | | | | J | 3 | • | | PORTC | | RC0 | 32 | 21 | I/O | ST | PORTC is a bidirectional I/O port | | RC1 | 33 | 22 | I/O | ST | • | | RC2 | 34 | 23 | I/O | ST | † | | RC6 | 77 | 50 | I/O | ST | 1 | | RC7 | 78 | 51 | I/O | ST | † | | RC8 | 81 | 52 | I/O | ST | † | | RC9 | 84 | 55 | I/O | ST | † | | RC10 | 71 | 45 | I/O | ST | | | RC11 | 35 | 24 | I/O | ST | 1 | | RC12 | 63 | 39 | I/O | ST | 1 | | RC13 | 73 | 47 | I | ST | ] | | RC15 | 64 | 40 | I/O | ST | ] | | I egend: | 01400 - 01 | 100 | adila la liana | it or output | Analog = Analog input P = Power | **Legend:** CMOS = CMOS-compatible input or output Analog = Analog input P = Power I = Input ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output PPS = Peripheral Pin Sele PPS = Peripheral Pin Select Note 1: This function does not exist on 100-pin general purpose devices. **2:** This function does not exist on 64-pin general purpose devices. 3: This function does not exist on any general purpose devices. TABLE 1-6: PORTA THROUGH PORTG PINOUT I/O DESCRIPTIONS (CONTINUED) | | Pin N | umber | | | | |----------|-----------------|-------------------------|-------------|----------------|-----------------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | PORTD | | RD1 | 6 | _ | I/O | ST | PORTD is a bidirectional I/O port | | RD2 | 7 | _ | I/O | ST | | | RD3 | 8 | _ | I/O | ST | | | RD4 | 9 | _ | I/O | ST | | | RD5 | 82 | 53 | I/O | ST | | | RD6 | 83 | 54 | I/O | ST | | | RD8 | 68 | 42 | I/O | ST | | | RD12 | 79 | _ | I/O | ST | | | RD13 | 80 | _ | I/O | ST | | | RD14 | 47 | _ | I/O | ST | | | RD15 | 48 | _ | I/O | ST | | | | | | • | | PORTE | | RE0 | 52 | _ | I/O | ST | PORTE is a bidirectional I/O port | | RE1 | 53 | | I/O | ST | | | RE8 | 18 | _ | I/O | ST | | | RE9 | 19 | _ | I/O | ST | | | RE12 | 41 | 27 | I/O | ST | | | RE13 | 42 | 28 | I/O | ST | | | RE14 | 43 | 29 | I/O | ST | | | RE15 | 44 | 30 | I/O | ST | | | | - | - | • | - | PORTF | | RF0 | 87 | 58 | I/O | ST | PORTF is a bidirectional I/O port | | RF1 | 88 | 59 | I/O | ST | ] | | RF5 | 61 | _ | I/O | ST | 1 | | RF6 | 91 | _ | I/O | ST | 1 | | RF7 | 92 | _ | I/O | ST | 1 | | RF9 | 28 | _ | I/O | ST | 1 | | RF10 | 29 | _ | I/O | ST | 1 | | RF12 | 40 | _ | I/O | ST | 1 | | RF13 | 39 | _ | I/O | ST | | Legend: CMOS = CMOS-compatible input or output Analog = Analog input P = Power I = Input ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output PPS = Peripheral Pin Select Note 1: This function does not exist on 100-pin general purpose devices. - 2: This function does not exist on 64-pin general purpose devices. - 3: This function does not exist on any general purpose devices. TABLE 1-6: PORTA THROUGH PORTG PINOUT I/O DESCRIPTIONS (CONTINUED) | | Pin Nu | umber | | | | | | | | | |----------|-----------------|-------------------------|-------------|----------------|-----------------------------------|--|--|--|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | PORTG | | | | | | | | | | | | RG0 | 90 | _ | I/O | ST | PORTG is a bidirectional I/O port | | | | | | | RG1 | 89 | _ | I/O | ST | | | | | | | | RG6 | 10 | 4 | I/O | ST | | | | | | | | RG7 | 11 | 5 | I/O | ST | | | | | | | | RG8 | 12 | 6 | I/O | ST | | | | | | | | RG9 | 14 | 8 | I/O | ST | | | | | | | | RG10 | 17 | _ | I/O | ST | | | | | | | | RG11 | 38 | _ | I/O | ST | | | | | | | | RG12 | 96 | _ | I/O | ST | | | | | | | | RG13 | 97 | _ | I/O | ST | | | | | | | | RG14 | 95 | _ | I/O | ST | | | | | | | | RG15 | 1 | _ | I/O | ST | | | | | | | **Legend:** CMOS = CMOS-compatible input or output Analog = Analog input O = Output P = Power ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer PPS = Peripheral Pin Select I = Input Note 1: This function does not exist on 100-pin general purpose devices. 2: This function does not exist on 64-pin general purpose devices. 3: This function does not exist on any general purpose devices. TABLE 1-7: UART1 THROUGH UART6 PINOUT I/O DESCRIPTIONS | Pin Number | | | | | |-----------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | | Description | | | | Univ | ersal Asyr | nchronous Receiver Transmitter 1 | | PPS | PPS | I | ST | UART1 Receive | | PPS | PPS | 0 | _ | UART1 Transmit | | PPS | PPS | I | ST | UART1 Clear to Send | | PPS | PPS | 0 | _ | UART1 Ready to Send | | | | Univ | ersal Asyr | nchronous Receiver Transmitter 2 | | PPS | PPS | I | ST | UART2 Receive | | PPS | PPS | 0 | _ | UART2 Transmit | | PPS | PPS | I | ST | UART2 Clear To Send | | PPS | PPS | 0 | _ | UART2 Ready To Send | | | | Univ | ersal Asyr | nchronous Receiver Transmitter 3 | | PPS | PPS | I | ST | UART3 Receive | | PPS | PPS | 0 | _ | UART3 Transmit | | PPS | PPS | I | ST | UART3 Clear to Send | | PPS | PPS | 0 | _ | UART3 Ready to Send | | | | Univ | ersal Asyr | nchronous Receiver Transmitter 4 | | PPS | PPS | I | ST | UART4 Receive | | PPS | PPS | 0 | _ | UART4 Transmit | | PPS | PPS | I | ST | UART4 Clear to Send | | PPS | PPS | 0 | _ | UART4 Ready to Send | | | | Univ | ersal Asyr | nchronous Receiver Transmitter 5 | | PPS | PPS | I | ST | UART5 Receive | | PPS | PPS | 0 | _ | UART5 Transmit | | PPS | PPS | I | ST | UART5 Clear to Send | | PPS | PPS | 0 | _ | UART5 Ready to Send | | | | Univ | ersal Asyr | nchronous Receiver Transmitter 6 | | PPS | PPS | I | ST | UART6 Receive | | PPS | PPS | 0 | _ | UART6 Transmit | | PPS | PPS | I | ST | UART6 Clear to Send | | PPS | PPS | 0 | _ | UART6 Ready to Send | | | PPS | 100-pin TQFP 64-pin VQFN/ TQFP PPS | 100-pin TQFP 64-pin VQFN/ TQFP Pin Type PPS PPS I PPS PPS O PPS PPS I | 100-pin TQFP | Legend: CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer Analog = Analog input O = Output PPS = Peripheral Pin Select P = Power I = Input **TABLE 1-8:** SPI1 THROUGH SPI 6 PINOUT I/O DESCRIPTIONS | | Pin N | umber | | | | |----------|---------------------------|-------------------------|-------------|----------------|------------------------------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | al Peripheral Interface 1 | | | | | | SCK1 | 72 | 46 | I/O | ST/CMOS | SPI1 Synchronous Serial Clock Input/Output | | SDI1 | PPS | PPS | I | ST | SPI1 Data In | | SDO1 | PPS | PPS | 0 | CMOS | SPI1 Data Out | | SS1 | PPS | PPS | I/O | ST/CMOS | SPI1 Client Synchronization Or Frame Pulse I/O | | | | | | Seria | al Peripheral Interface 2 | | SCK2 | 70 | 44 | I/O | ST/CMOS | SPI2 Synchronous Serial Clock Input/output | | SDI2 | PPS | PPS | I | ST | SPI2 Data In | | SDO2 | PPS | PPS | 0 | CMOS | SPI2 Data Out | | SS2 | PPS | PPS | I/O | ST/CMOS | SPI2 Client Synchronization Or Frame Pulse I/O | | | | | | Seria | al Peripheral Interface 3 | | SCK3 | PPS | PPS | I/O | ST/CMOS | SPI3 Synchronous Serial Clock Input/Output | | SDI3 | PPS | PPS | I | ST | SPI3 Data In | | SDO3 | PPS | PPS | 0 | CMOS | SPI3 Data Out | | SS3 | PPS | PPS | I/O | ST/CMOS | SPI3 Client Synchronization Or Frame Pulse I/O | | | | | | Seria | al Peripheral Interface 4 | | SCK4 | PPS | PPS | I/O | ST/CMOS | SPI4 Synchronous Serial Clock Input/Output | | SDI4 | PPS | PPS | I | ST | SPI4 Data In | | SDO4 | PPS | PPS | 0 | CMOS | SPI4 Data Out | | SS4 | PPS | PPS | I/O | ST/CMOS | SPI4 Client Synchronization Or Frame Pulse I/O | | | | | | Seria | al Peripheral Interface 5 | | SCK5 | PPS | PPS | I/O | ST/CMOS | SPI5 Synchronous Serial Clock Input/Output | | SDI5 | PPS | PPS | I | ST | SPI5 Data In | | SDO5 | PPS | PPS | 0 | CMOS | SPI5 Data Out | | SS5 | PPS | PPS | I/O | | SPI5 Client Synchronization Or Frame Pulse I/O | | | | | | Seria | Al Peripheral Interface 6 | | SCK6 | PPS | PPS | I/O | ST/CMOS | SPI6 Synchronous Serial Clock Input/Output | | SDI6 | PPS | PPS | I | ST | SPI6 Data In | | SDO6 | PPS | PPS | 0 | CMOS | SPI6 Data Out | | SS6 | PPS | PPS | I/O | ST/CMOS | SPI6 Client Synchronization Or Frame Pulse I/O | CMOS = CMOS-compatible input or output Analog = Analog input P = Power I = Input ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output **TABLE 1-9: I2C1 THROUGH I2C4 PINOUT I/O DESCRIPTIONS** | | Pin Nı | umber | | | Description | | | | | | | |----------|----------------------------|-------------------------|-------------|----------------|--------------------------------------------|--|--|--|--|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | | | | | | | | | | Inter-Integrated Circuit 1 | | | | | | | | | | | | SCL1 | 11 | 5 | I/O | ST | I2C1 Synchronous Serial Clock Input/Output | | | | | | | | SDA1 | 12 | 6 | I/O | ST | I2C1 Synchronous Serial Data Input/Output | | | | | | | | | Inter-Integrated Circuit 2 | | | | | | | | | | | | SCL2 | 50 | 32 | I/O | ST | I2C2 Synchronous Serial Clock Input/Output | | | | | | | | SDA2 | 49 | 31 | I/O | ST | I2C2 Synchronous Serial Data Input/Output | | | | | | | | | | • | | Inte | er-Integrated Circuit 3 | | | | | | | | SCL3 | 70 | 44 | I/O | ST | I2C3 Synchronous Serial Clock Input/Output | | | | | | | | SDA3 | 69 | 43 | I/O | ST | I2C3 Synchronous Serial Data Input/Output | | | | | | | | | | | | Inte | er-Integrated Circuit 4 | | | | | | | | SCL4 | 42 | 28 | I/O | ST | I2C4 Synchronous Serial Clock Input/Output | | | | | | | | SDA4 | 41 | 27 | I/O | ST | I2C4 Synchronous Serial Data Input/Output | | | | | | | Legend: CMOS = CMOS-compatible input or output Analog = Analog input P = Power I = Input ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output PPS = Peripheral Pin Select **TABLE 1-10:** TIMER1 THROUGH TIMER9 AND RTCC PINOUT I/O DESCRIPTIONS | | Pin N | umber | | | | | | | | | | |----------|-----------------------|-------------------------|-------------|----------------|--------------------------------------|--|--|--|--|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | | Timer1 through Timer9 | | | | | | | | | | | | T1CK | 74 | 48 | I | ST | Timer1 External Clock Input | | | | | | | | T2CK | PPS | PPS | I | ST | Timer2 External Clock Input | | | | | | | | T3CK | PPS | PPS | I | ST | Timer3 External Clock Input | | | | | | | | T4CK | PPS | PPS | I | ST | Timer4 External Clock Input | | | | | | | | T5CK | PPS | PPS | I | ST | Timer5 External Clock Input | | | | | | | | T6CK | PPS | PPS | I | ST | Timer6 External Clock Input | | | | | | | | T7CK | PPS | PPS | I | ST | Timer7 External Clock Input | | | | | | | | T8CK | PPS | PPS | I | ST | Timer8 External Clock Input | | | | | | | | T9CK | PPS | PPS | I | ST | Timer9 External Clock Input | | | | | | | | | | | | Real- | Time Clock and Calendar | | | | | | | | RTCC | 27 | 18 | 0 | _ | Real-Time Clock Alarm/Seconds Output | | | | | | | CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power I = Input TTL = Transistor-transistor Logic input buffer PMP PINOUT I/O DESCRIPTIONS **TABLE 1-11:** | Pin Name | Pin Nı | umber | Pin | Buffer | Description | |----------|-----------------|-------------------------|------|----------|------------------------------------------------------------------------| | | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Type | Туре | | | PMA0 | 44 | 30 | 0 | TTL/CMOS | Parallel Master Port Address (Demultiplexed Host mode) or Address/Data | | PMA1 | 43 | 29 | 0 | TTL/CMOS | (Multiplexed Host modes) | | PMA2 | 14 | 8 | 0 | TTL/CMOS | | | PMA3 | 12 | 6 | 0 | TTL/CMOS | | | PMA4 | 11 | 5 | 0 | TTL/CMOS | | | PMA5 | 10 | 4 | 0 | TTL/CMOS | | | PMA6 | 29 | 16 | 0 | TTL/CMOS | | | PMA7 | 28 | 22 | 0 | TTL/CMOS | | | PMA8 | 50 | 32 | 0 | TTL/CMOS | | | PMA9 | 49 | 31 | 0 | TTL/CMOS | | | PMA10 | 42 | 28 | 0 | TTL/CMOS | | | PMA11 | 41 | 27 | 0 | TTL/CMOS | | | PMA12 | 35 | 24 | 0 | TTL/CMOS | | | PMA13 | 34 | 23 | 0 | TTL/CMOS | | | PMA14 | 71 | 45 | 0 | TTL/CMOS | | | PMA15 | 70 | 44 | 0 | TTL/CMOS | | | PMA16 | 77 | _ | 0 | TTL/CMOS | | | PMA17 | 78 | _ | 0 | TTL/CMOS | | | PMA18 | 91 | _ | 0 | TTL/CMOS | | | PMA19 | 92 | _ | 0 | TTL/CMOS | | | PMA20 | 95 | _ | 0 | TTL/CMOS | | | PMA21 | 96 | _ | 0 | TTL/CMOS | | | PMA22 | 97 | _ | 0 | TTL/CMOS | | | PMA23 | 1 | _ | 0 | TTL/CMOS | | | PMCS1 | 71 | 45 | 0 | TTL/CMOS | Parallel Master Port Chip Select 1 for PMA(13:0) | | PMCS2 | 70 | 44 | 0 | TTL/CMOS | Parallel Master Port Chip Select 2 for PMA(14:0) | | PMRD | 82 | 53 | 0 | TTL/CMOS | Parallel Master Port Read Strobe | | PMWR | 81 | 52 | 0 | TTL/CMOS | Parallel Master Port Write Strobe | | PMCS1A | 97 | _ | 0 | TTL/CMOS | Parallel Master Port Chip Select 1 for PMA(21:0) | | PMCS2A | 1 | _ | 0 | TTL/CMOS | Parallel Master Port Chip Select 2 for PMA(22:0) | CMOS = CMOS-compatible input or output Legend: ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power I = Input TTL = Transistor-transistor Logic input buffer TABLE 1-11: PMP PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Nu | umber | Pin | Buffer | Description | |----------|-----------------|-------------------------|------|----------|------------------------------------------------------------------------------| | | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Type | Туре | | | PMD0 | 93 | 60 | I/O | TTL/ST | Parallel Master Port Data (Demultiplexed Host mode) or Address/Data | | PMD1 | 94 | 61 | I/O | TTL/ST | (Multiplexed Host modes) | | PMD2 | 98 | 62 | I/O | TTL/ST | | | PMD3 | 99 | 63 | I/O | TTL/ST | | | PMD4 | 100 | 64 | I/O | TTL/ST | | | PMD5 | 3 | 1 | I/O | TTL/ST | | | PMD6 | 4 | 2 | I/O | TTL/ST | | | PMD7 | 5 | 3 | I/O | TTL/ST | | | PMD8 | 90 | | I/O | TTL/ST | | | PMD9 | 89 | | I/O | TTL/ST | | | PMD10 | 88 | _ | I/O | TTL/ST | | | PMD11 | 87 | | I/O | TTL/ST | | | PMD12 | 79 | _ | I/O | TTL/ST | | | PMD13 | 80 | _ | I/O | TTL/ST | | | PMD14 | 83 | | I/O | TTL/ST | | | PMD15 | 84 | _ | I/O | TTL/ST | | | PMALH | 43 | 29 | 0 | TTL/CMOS | Parallel Master Port Address Latch Enable High Byte (Multiplexed Host modes) | | PMALL | 44 | 30 | 0 | _ | Parallel Master Port Address Latch Enable Low Byte (Multiplexed Host modes) | Legend: CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer Analog = Analog input O = Output PPS = Peripheral Pin Select P = Power I = Input TABLE 1-12: COMPARATOR 1 THROUGH COMPARATOR 5 PINOUT I/O DESCRIPTIONS | | Pin Nu | ımber | | | | | | | | | | | |----------|-----------------|-------------------------|-------------|----------------|---------------------------------|--|--|--|--|--|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | | | Comparator 1 | | | | | | | | | | | | | C1IN1+ | 26 | 17 | I | Analog | Comparator 1 Positive Input | | | | | | | | | C1IN1- | 27 | 18 | I | Analog | Comparator 1 Negative Input 1-4 | | | | | | | | | C1IN2- | 35 | 24 | I | Analog | | | | | | | | | | C1IN3- | 26 | 17 | I | Analog | | | | | | | | | | C1IN4- | 25 | 16 | I | Analog | | | | | | | | | | C1OUT | PPS | PPS | 0 | _ | Comparator 1 Output | | | | | | | | | | | | | | Comparator 2 | | | | | | | | | C2IN1+ | 23 | 14 | I | Analog | Comparator 2 Positive Input | | | | | | | | | C2IN1- | 24 | 15 | I | Analog | Comparator 2 Negative Input 1-4 | | | | | | | | | C2IN2- | 41 | 27 | I | Analog | | | | | | | | | | C2IN3- | 26 | 17 | I | Analog | | | | | | | | | | C2IN4- | 22 | 13 | I | Analog | | | | | | | | | | C2OUT | PPS | PPS | 0 | _ | Comparator 2 Output | | | | | | | | | | | | | | Comparator 3 | | | | | | | | | C3IN1+ | 34 | 23 | I | Analog | Comparator 3 Positive Input | | | | | | | | | C3IN1- | 33 | 22 | I | Analog | Comparator 3 Negative Input 1-4 | | | | | | | | | C3IN2- | 42 | 28 | I | Analog | | | | | | | | | | C3IN3- | 34 | 23 | I | Analog | | | | | | | | | | C3IN4- | 32 | 21 | I | Analog | | | | | | | | | | C3OUT | PPS | PPS | 0 | _ | Comparator 3 Output | | | | | | | | | | | | | | Comparator 4 | | | | | | | | | C4IN1+ | 32 | 21 | I | Analog | Comparator 4 Positive Input | | | | | | | | | C4IN1- | 33 | 22 | I | Analog | Comparator 4 Negative Input 1-4 | | | | | | | | | C4IN2- | 25 | 16 | I | Analog | | | | | | | | | | C4IN3- | 22 | 13 | I | Analog | | | | | | | | | | C4IN4- | 32 | 21 | I | Analog | | | | | | | | | | C4OUT | PPS | PPS | 0 | _ | Comparator 4 Output | | | | | | | | | | | | | | Comparator 5 | | | | | | | | | C5IN1+ | 51 | 33 | I | Analog | Comparator 5 Positive Input | | | | | | | | | C5IN1- | 76 | 49 | I | Analog | Comparator 5 Negative Input 1-4 | | | | | | | | | C5IN2- | 41 | 27 | I | Analog | | | | | | | | | | C5IN3- | 51 | 33 | I | Analog | | | | | | | | | | C5IN4- | 72 | 46 | I | Analog | | | | | | | | | | C1OUT | PPS | PPS | 0 | _ | Comparator 5 Output | | | | | | | | **Legend:** CMOS = CMOS-compatible input or output Analog = Analog input P = Power ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output PPS = Peripheral Pin Select I = Input TABLE 1-13: OP AMP 1 THROUGH OP AMP 3, AND OP AMP 5 PINOUT I/O DESCRIPTIONS | | Pin N | umber | | | | | | | | |----------|-----------------|-------------------------|-------------|----------------|-------------------------|--|--|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | | | | Op amp 1 | | | | | | OA1OUT | 25 | 16 | 0 | Analog | Op amp 1 Output | | | | | | OA1IN+ | 26 | 17 | I | Analog | Op amp 1 Positive Input | | | | | | OA1IN- | 27 | 18 | I | Analog | Op amp 1 Negative Input | | | | | | | Op amp 2 | | | | | | | | | | OA2OUT | 22 | 13 | 0 | Analog | Op amp 2 Output | | | | | | OA2IN+ | 23 | 14 | I | Analog | Op amp 2 Positive Input | | | | | | OA2IN- | 24 | 15 | I | Analog | Op amp 2 Negative Input | | | | | | | | | | | Op amp 3 | | | | | | OA3OUT | 32 | 21 | 0 | Analog | Op amp 3 Output | | | | | | OA3IN+ | 34 | 23 | I | Analog | Op amp 3 Positive Input | | | | | | OA3IN- | 33 | 22 | I | Analog | Op amp 3 Negative Input | | | | | | | Op amp 5 | | | | | | | | | | OA5OUT | 72 | 46 | 0 | Analog | Op amp 5 Output | | | | | | OA5IN+ | 51 | 33 | I | Analog | Op amp 5 Positive Input | | | | | | OA5IN- | 76 | 49 | I | Analog | Op amp 5 Negative Input | | | | | **Legend:** CMOS = CMOS-compatible input or output Analog = Analog input P = Power I = Input ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output PPS = Peripheral Pin Select TABLE 1-14: CAN1 THROUGH CAN4 PINOUT I/O DESCRIPTIONS | | Pin Number | | | | | |--------------------------|-----------------|-------------------------|-------------|----------------|-----------------------| | Pin Name<br>(see Note 1) | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | C1TX | PPS | PPS | 0 | _ | CAN1 Bus Transmit Pin | | C1RX | PPS | PPS | I | ST | CAN1 Bus Receive Pin | | C2TX | PPS | PPS | 0 | _ | CAN2 Bus Transmit Pin | | C2RX | PPS | PPS | I | ST | CAN2 Bus Receive Pin | | C3TX | PPS | PPS | 0 | _ | CAN3 Bus Transmit Pin | | C3RX | PPS | PPS | I | ST | CAN3 Bus Receive Pin | | C4TX | PPS | PPS | 0 | _ | CAN4 Bus Transmit Pin | | C4RX | PPS | PPS | I | ST | CAN4 Bus Receive Pin | Legend: CMOS = CMOS-compatible input or output Analog = Analog input P = Power ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output PPS = Peripheral Pin Select I = Input Note 1: This function does not exist on PIC32MKXXXGPDXXX devices. **TABLE 1-15**: **USB1 AND USB2 PINOUT I/O DESCRIPTIONS** | | Pin Nu | umber | | | | |----------|-----------------|-------------------------|-------------|----------------|---------------------------------------------------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | VUSB3V3 | 55 | 35 | Р | _ | USB internal transceiver supply. This pin must be connected to VDD. | | VBUS1 | 54 | 34 | I | Analog | USB1 Bus Power Monitor (Tie to VSS if USB1 is not used) | | VBUSON1 | 4 | 2 | 0 | CMOS | USB1 VBUS Power Control Output | | VBUSON2 | 10 | _ | 0 | CMOS | USB2 VBUS Power Control Output | | D1+ | 57 | 37 | I/O | Analog | USB1 D+ (Tie through 10k to VSS if USB1 is not used) | | D1- | 56 | 36 | I/O | Analog | USB1 D- (Tie through 10k to VSS if USB1 is not used) | | USBID1 | 69 | 43 | ı | ST | USB1 OTG ID Detect | | VBUS2 | 58 | _ | ı | Analog | USB2 Bus Power Monitor (Tie to VSS if USB2 is not used) | | D2+ | 60 | _ | I/O | Analog | USB2 D+ (Tie through 10k to VSS if USB2 is not used) | | D2- | 59 | _ | I/O | Analog | USB2 D- (Tie through 10k to VSS if USB2 is not used) | | USBID2 | 77 | _ | I | ST | USB2 OTG ID detect | Legend: CMOS = CMOS-compatible input or output Analog = Analog input O = Output P = Power ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer PPS = Peripheral Pin Select I = Input **TABLE 1-16:** CTMU PINOUT I/O DESCRIPTIONS | | Pin Nı | ımber | | | | |----------|-----------------|-------------------------|-------------|----------------|----------------------------------------------------| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | CTED1 | 25 | 16 | ı | ST | CTMU External Edge Input 1 | | CTED2 | 24 | 15 | I | ST | CTMU External Edge Input 2 | | CTCMP | 27 | 18 | I | Analog | CTMU external capacitor input for pulse generation | | CTPLS | PPS | PPS | 0 | CMOS | CTMU Pulse Generator Output | Legend: CMOS = CMOS-compatible input or output Analog = Analog input P = Power ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer O = Output I = Input PPS = Peripheral Pin Select **TABLE 1-17: CDAC1 THROUGH CDAC3 PINOUT I/O DESCRIPTIONS** | Pin Name | Pin Number | | | | | | |----------|-----------------|-------------------------|-------------|----------------|---------------------|--| | | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | CDAC1 | 51 | 33 | 0 | Analog | 12-bit CDAC1 output | | | CDAC2 | 71 | 45 | 0 | Analog | 12-bit CDAC2 output | | | CDAC3 | 49 | 31 | 0 | Analog | 12-bit CDAC3 output | | **Legend:** CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input P = Power TTL = Transistor-transistor Logic input buffer O = Output PPS = Peripheral Pin Select I = Input TABLE 1-18: MCPWM1 THROUGH MCPWM12 PINOUT I/O DESCRIPTIONS (MOTOR CONTROL DEVICES ONLY<sup>(1)</sup>) | | Pin Number | | | | | | | | | |---------------|--------------------------------|------|-------------|----------------|---------------------------------------------------------------------|--|--|--|--| | Pin Name | 100-<br>Pin VQFN/<br>TQFP TQFP | | Pin<br>Type | Buffer<br>Type | Description | | | | | | PWM1H | 4 | 2 | 0 | CMOS | MCPWM1 High Side Output | | | | | | PWM1L | 5 | 3 | 0 | CMOS | MCPWM1 Low Side Output (Only if PWMAPIN1 (CFGCON<18>) = 0, default) | | | | | | PWM2H | 98 | 62 | 0 | CMOS | MCPWM2 High Side Output | | | | | | PWM2L | 99 | 63 | 0 | CMOS | MCPWM2 Low Side Output (Only if PWMAPIN2 (CFGCON<19>) = 0, default) | | | | | | PWM3H | 93 | 60 | 0 | CMOS | MCPWM3 High Side Output | | | | | | PWM3L | 94 | 61 | 0 | CMOS | MCPWM3 Low Side Output (Only if PWMAPIN3 (CFGCON<20>) = 0, default) | | | | | | PWM4H | 100 | 64 | 0 | CMOS | MCPWM4 High Side Output | | | | | | PWM4L | 3 | 1 | 0 | CMOS | MCPWM4 Low Side Output (Only if PWMAPIN4 (CFGCON<21>) = 0, default) | | | | | | PWM5H | 7 | 52 | 0 | CMOS | MCPWM5 High Side Output | | | | | | PWM5L | 6 | 55 | 0 | CMOS | MCPWM5 Low Side Output (Only if PWMAPIN5 (CFGCON<22>) = 0, default) | | | | | | PWM6H | 9 | 50 | 0 | CMOS | MCPWM6 High Side Output | | | | | | PWM6L | 8 | 51 | 0 | CMOS | MCPWM6 Low Side Output (Only if PWMAPIN6 (CFGCON<23>) = 0, default) | | | | | | PWM7H | 97, 5 | 3 | 0 | CMOS | If PWMAPIN1 (CFGCON<18>) = 1), PWM1L is replaced by PWM7H. | | | | | | PWM7L | 1 | _ | 0 | CMOS | MCPWM7 Low Side Output | | | | | | PWM8H | 95, 99 | 63 | 0 | CMOS | If PWMAPIN2 (CFGCON<19>) = 1), PWM2L is replaced by PWM8H. | | | | | | PWM8L | 96 | _ | 0 | CMOS | MCPWM8 Low Side Output | | | | | | PWM9H | 91, 94 | 61 | 0 | CMOS | If PWMAPIN3 (CFGCON<20>) = 1), PWM3L is replaced by PWM9H. | | | | | | PWM9L | 92 | _ | 0 | CMOS | MCPWM9 Low Side Output | | | | | | DWMAAALI | 11 | 5 | 0 | CMOS | MCPWM10 High Side Output | | | | | | PWM10H | 3 | 1 | 0 | CMOS | If PWMAPIN4 (CFGCON<21>) = 1), PWM4L is replaced by PWM10H. | | | | | | PWM10L | 10 | 4 | 0 | CMOS | MCPWM10 Low Side Output | | | | | | PWM11H | 87 | 55 | 0 | CMOS | MCPWM11 High Side Output | | | | | | r vvivi i i ∏ | 6 | 58 | 0 | CMOS | If PWMAPIN5 (CFGCON<22>) = 1), PWM5L is replaced by PWM11H. | | | | | | PWM11L | 88 | 59 | 0 | CMOS | MCPWM11 Low Side Output | | | | | | DWW110Fi | 82 | 51 | 0 | CMOS | MCPWM12 High Side Output | | | | | | PWM12H | 8 | 55 | 0 | CMOS | If PWMAPIN6 (CFGCON<23>) = 1), PWM6L is replaced by PWM12H. | | | | | | PWM12L | 83 | 54 | 0 | CMOS | MCPWM12 Low Side Output | | | | | | Legend: | CMOS = | CMOS | compat | tible inpu | ut or output Analog = Analog input P = Power | | | | | Legend: CMOS = CMOS compatible input or output Analog = Analog input P = Power ST = Schmitt Trigger input with CMOS levels O = Output I = Input TTL = Transistor-Transistor Logic input buffer PPS = Peripheral Pin Select Note 1: PWM functions only exist on "MCM" motor control variants. TABLE 1-19: MCPWM FAULT, CURRENT-LIMIT, AND DEAD TIME COMPENSATION PINOUT I/O DESCRIPTIONS (MOTOR CONTROL DEVICES ONLY<sup>(1)</sup>) | | Pin Number 100-Pin VQFN/ TQFP | | | Buffer<br>Type | | |----------|--------------------------------|-----|-------------|----------------|------------------------------------------| | Pin Name | | | Pin<br>Type | | Description | | FLT1 | PPS | PPS | I | ST | | | FLT2 | PPS | PPS | I | ST | | | FLT3 | 34 | 23 | I | ST | | | FLT4 | 35 | 24 | I | ST | | | FLT5 | 41 | 27 | I | ST | | | FLT6 | 42 | 28 | I | ST | | | FLT7 | 43 | 29 | I | ST | | | FLT8 | 44 | 30 | I | ST | | | FLT9 | 17 | ī | I | ST | PWM Fault / Dead Time Comp Input Control | | FLT10 | 18 | ī | I | ST | | | FLT11 | 19 | ī | I | ST | | | FLT12 | 14 | 8 | i | ST | | | FLT13 | 21 | 12 | i | ST | | | FLT14 | 20 | 11 | I | ST | | | FLT15 | 50 | 32 | i | ST | | | FLT16 | 79 | - | I | ST | | | FLT17 | 80 | - | I | ST | | Legend: CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels TTL = Transistor-Transistor Logic input buffer Analog = Analog input O = Output PPS = Peripheral Pin Select P = Power I = Input Note 1: MCPWM fault features are only supported on "MCM" motor control variants. TABLE 1-20: QEI1 THROUGH QEI6 PINOUT I/O DESCRIPTIONS (MOTOR CONTROL DEVICES ONLY) | | D1 . 11 | | | | | | | | |----------------|-----------------|-------------------------|-------------|----------------|------------------------------------------------------------------------------------------|--|--|--| | Pin Name | 100-Pin<br>TQFP | 64-Pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | | Q | uadrature Encoder Interface 1 | | | | | QEA1 | PPS | PPS | I | ST | QEI1 Phase A Input in QEI mode | | | | | QEB1 | PPS | PPS | I | ST | QEI1 Phase B Input in QEI Mode. Auxiliary timer external clock/gate input in | | | | | INDV4 | DDC | DDC | | ST | Timer mode. QEI1 Index Pulse Input | | | | | INDX1<br>HOME1 | PPS<br>PPS | PPS<br>PPS | l<br>I | ST | • | | | | | | | | | | QEI1 Position Counter Input Capture Trigger Control | | | | | QEICMP1 | PPS | PPS | 0 | | QEI1 Capture Compare Match Output | | | | | 0540 | | 550 | | | uadrature Encoder Interface 2 | | | | | QEA2 | PPS | PPS | l<br>· | ST | QEI2 Phase A Input in QEI mode | | | | | QEB2 | PPS | PPS | I | ST | QEI2 Phase B Input in QEI Mode. Auxiliary timer external clock/gate input in Timer mode. | | | | | INDX2 | PPS | PPS | I | ST | QEI2 Index Pulse Input | | | | | HOME2 | PPS | PPS | I | ST | QEI2 Position Counter Input Capture Trigger Control | | | | | QEICMP2 | PPS | PPS | 0 | CMOS | QEI2 Capture Compare Match Output | | | | | | • | | | Q | uadrature Encoder Interface 3 | | | | | QEA3 | PPS | PPS | ı | ST | QEI3 Phase A Input in QEI mode | | | | | QEB3 | PPS | PPS | I | ST | QEI3 Phase B Input in QEI Mode. Auxiliary timer external clock/gate input in Timer mode. | | | | | INDX3 | PPS | PPS | ı | ST | QEI3 Index Pulse Input | | | | | HOME3 | PPS | PPS | ı | ST | QEI3 Position Counter Input Capture Trigger Control | | | | | QEICMP3 | PPS | PPS | 0 | CMOS | QEI3 Capture Compare Match Output | | | | | | 1 | | | | uadrature Encoder Interface 4 | | | | | QEA4 | PPS | PPS | ı | ST | QEI4 Phase A Input in QEI mode | | | | | QEB4 | PPS | PPS | I | ST | QEI4 Phase B Input in QEI Mode. Auxiliary timer external clock/gate input in Timer mode. | | | | | INDX4 | PPS | PPS | ı | ST | QEI4 Index Pulse Input | | | | | HOME4 | PPS | PPS | i | ST | QEI4 Position Counter Input Capture Trigger Control | | | | | QEICMP4 | PPS | PPS | 0 | | QEI4 Capture Compare Match Output | | | | | QLIOIII I | 1 | | | | uadrature Encoder Interface 5 | | | | | QEA5 | PPS | PPS | ı | ST | QAI5 Phase A Input in QEI mode | | | | | QEB5 | PPS | PPS | İ | ST | QAI5 Phase B Input in QEI Mode. Auxiliary timer external clock/gate input in Timer mode. | | | | | INDX5 | PPS | PPS | 1 | ST | QAI5 Index Pulse Input | | | | | HOME5 | PPS | PPS | i | ST | QAI5 Position Counter Input Capture Trigger Control | | | | | QEICMP5 | PPS | PPS | 0 | CMOS | QAIS Capture Compare Match Output | | | | | <u></u> | 1 | | | <u> </u> | uadrature Encoder Interface 6 | | | | | QEA6 | PPS | PPS | ı | ST | QEI6 Phase A Input in QEI mode | | | | | QEB6 | PPS | PPS | ı | ST | QEI6 Phase B Input in QEI Mode. Auxiliary timer external clock/gate input in Timer mode. | | | | | INDX6 | PPS | PPS | ı | ST | | | | | | HOME6 | PPS | PPS | | ST | | | | | | QEICMP6 | PPS | PPS | 0 | | QEI6 Capture Compare Match Output | | | | | | MOS = CN | | | 1 | | | | | | | MUS = UI | | | | | | | | O = Output PPS = Peripheral Pin Select TTL = Transistor-Transistor Logic input buffer PPS Note: QEI features are only supported on "MCM" motor control variants. ST = Schmitt Trigger input with CMOS levels I = Input TABLE 1-21: POWER, GROUND, AND VOLTAGE REFERENCE PINOUT I/O DESCRIPTIONS | | Pin Number | | | | | | | | |-------------------------------|------------------------------|-------------------------|-----------------------------------------------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | | | Power and Ground | | | | | AVDD 30 19 P P Positiv times. | | Р | Positive supply for analog modules. This pin must be connected at all imes. | | | | | | | AVss | 31 | 20 | Р | Р | Ground reference for analog modules. This pin must be connected at all times. | | | | | VDD | 2, 16, 37,<br>46, 62, 86 | 10, 26,<br>38, 57 | Р | _ | <ul> <li>Positive supply for peripheral logic and I/O pins. This pin must be connected at all times.</li> </ul> | | | | | Vss | 15, 36,<br>45, 65,<br>75, 85 | 9, 25, 41,<br>56 | Р | _ | Ground reference for logic, I/O pins, and USB. This pin must be connected at all times. | | | | | VDD | VDD 68 42 | | Р | Р | Positive supply for low power peripheral logic. This pin must be connected at all times and bypassed with a 1uf ceramic cap. | | | | | | • | | | | Voltage Reference | | | | | VREF+ | 29 | 16 | I | Analog | Analog Voltage Reference (High) Input | | | | | VREF- | 28 15 I | | Analog | Analog Voltage Reference (Low) Input | | | | | Legend: CMOS = CMOS-compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power I = Input TTL = Transistor-transistor Logic input buffer JTAG, TRACE, AND PROGRAMMING/DEBUGGING PINOUT I/O DESCRIPTIONS **TABLE 1-22:** | | Pin Number | | | | | | | |----------|-----------------|-------------------------|-------------|----------------|---------------------------------------------------------------------------------------------|--|--| | Pin Name | 100-pin<br>TQFP | 64-pin<br>VQFN/<br>TQFP | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | | JTAG | | | | TCK | 3 | 1 | I | ST | JTAG Test Clock Input Pin | | | | TDI | 49 | 31 | _ | ST | JTAG Test Data Input Pin | | | | TDO | 100 | 64 | 0 | 1 | JTAG Test Data Output Pin | | | | TMS | 76 | 49 | _ | ST | JTAG Test Mode Select Pin | | | | | Trace | | | | | | | | TRCLK | 91 | 50 | 0 | CMOS | Trace Clock | | | | TRD0 | 97 | 54 | 0 | CMOS | Trace Data bits 0-3 | | | | TRD1 | 96 | 53 | 0 | CMOS | Trace support is available through the MPLAB <sup>®</sup> REAL ICE™ In-circuit<br>Emulator. | | | | TRD2 | 95 | 52 | 0 | CMOS | Elliulator. | | | | TRD3 | 92 | 51 | 0 | CMOS | | | | | | | | | Pro | gramming/Debugging | | | | PGED1 | 27 | 18 | 1/0 | ST | Data I/O pin for Programming/Debugging Communication Channel 1 | | | | PGEC1 | 26 | 17 | I | ST | Clock input pin for Programming/Debugging Communication Channel 1 | | | | PGED2 | 69 | 43 | 1/0 | ST | Data I/O pin for Programming/Debugging Communication Channel 2 | | | | PGEC2 | 70 | 44 | 1 | ST | Clock input pin for Programming/Debugging Communication Channel 2 | | | | PGED3 | 24 | 15 | I/O | ST | Data I/O pin for Programming/Debugging Communication Channel 3 | | | | PGEC3 | 25 | 16 | I | ST | Clock input pin for Programming/Debugging Communication Channel 3 | | | | MCLR | 13 | 7 | I | ST | Master Clear (Reset) input. This pin is an active-low Reset to the device. | | | CMOS = CMOS-compatible input or output Legend: ST = Schmitt Trigger input with CMOS levels TTL = Transistor-transistor Logic input buffer Analog = Analog input O = Output PPS = Peripheral Pin Select P = Power I = Input | | K GFK/I | | | | |--------|---------|--|--|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 2.0 GUIDELINES FOR GETTING STARTED WITH 32-BIT MCUS Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the documents listed in the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). ### 2.1 Basic Connection Requirements Getting started with the PIC32MK GPK/MCM with CAN FD Family of 32-bit Microcontrollers (MCUs) requires attention to a minimal set of device pin connections before proceeding with development. The following is a list of pin names, which must always be connected: - All VDD and Vss pins (see 2.2 "Decoupling Capacitors") - All AVDD and AVSS pins, even if the ADC module is not used (see 2.2 "Decoupling Capacitors") - MCLR pin (see 2.3 "Master Clear (MCLR) Pin") - PGECx/PGEDx pins, used for In-Circuit Serial Programming™ (ICSP™) and debugging purposes (see 2.4 "ICSP Pins") - OSC1 and OSC2 pins, when external oscillator source is used (see 2.7 "External Oscillator Pins") The following pins may be required: VREF+/VREF- pins, used when external voltage reference for the ADC module is implemented. **Note:** The AVDD and AVSS pins must be connected, regardless of ADC use and the ADC voltage reference source. ### 2.2 Decoupling Capacitors The use of decoupling capacitors on power supply pins, such as VDD, Vss, AVDD and AVss is required, see Figure 2-1. Consider the following criteria when using decoupling capacitors: - Value and type of capacitor: A value of 0.1 µF (100 nF), 10-20V is recommended. The capacitor should be a low Equivalent Series Resistance (low-ESR) capacitor and have resonance frequency in the range of 20 MHz and higher. It is further recommended that ceramic capacitors be used. - Placement on the printed circuit board: The decoupling capacitors should be placed as close to the pins as possible. It is recommended that the capacitors be placed on the same side of the board as the device. If space is constricted, the capacitor can be placed on another layer on the PCB using a via; however, ensure that the trace length from the pin to the capacitor is within onequarter inch (6 mm) in length. - Handling high frequency noise: If the board is experiencing high frequency noise, upward of tens of MHz, add a second ceramic-type capacitor in parallel to the above described decoupling capacitor. The value of the second capacitor can be in the range of 0.01 μF to 0.001 μF. Place this second capacitor next to the primary decoupling capacitor. In high-speed circuit designs, consider implementing a decade pair of capacitances as close to the power and ground pins as possible. For example, 0.1 μF in parallel with 0.001 μF. - Maximizing performance: On the board layout from the power supply circuit, run the power and return traces to the decoupling capacitors first, and then to the device pins. This ensures that the decoupling capacitors are first in the power chain. Equally important is to keep the trace length between the capacitor and the power pins to a minimum thereby reducing PCB track inductance. ## FIGURE 2-1: RECOMMENDED MINIMUM CONNECTION Note 1: This pin must be connected to VDD, regardless of whether the USB module is or is not used. 2: As an option, instead of a hard-wired connection, an inductor (L1) can be substituted between VDD and AVDD to improve ADC noise rejection. The inductor impedance should be less than 3Ω and the inductor capacity greater than 10 mA. Where: $$f= rac{FCNV}{2}$$ (i.e., ADC conversion rate/2) $$f= rac{1}{(2\pi\sqrt{LC})}$$ $L=\left( rac{1}{(2\pi f\sqrt{C})} ight)^2$ 3: Aluminum or electrolytic capacitors should not be used. ESR ≤ 3Ω from -40°C to +125°C @ SYSCLK frequency (i.e., MIPS). #### 2.2.1 BULK CAPACITORS The use of a bulk capacitor is recommended to improve power supply stability. Typical values range from 4.7 $\mu$ F to 47 $\mu$ F. This capacitor should be located as close to the device as possible. ### 2.3 Master Clear (MCLR) Pin The MCLR pin provides two specific device functions: - · Device Reset - · Device programming and debugging Pulling The MCLR pin low generates a device Reset. Figure 2-2 illustrates a typical MCLR circuit. During device programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the MCLR pin. Consequently, specific voltage levels (VIH and VIL) and fast signal transitions must not be adversely affected. Therefore, specific values of R and C will need to be adjusted based on the application and PCB requirements. For example, as illustrated in Figure 2-2, it is recommended that the capacitor C, be isolated from the MCLR pin during programming and debugging operations. Place the components illustrated in Figure 2-2 within one-quarter inch (6 mm) from the MCLR pin. ## FIGURE 2-2: EXAMPLE OF MCLR PIN CONNECTIONS - Note 1: $\frac{470\Omega \leq R1 \leq 1 \ K\Omega}{MCLR}$ from the external capacitor C, in the event of $\frac{MCLR}{MCLR}$ pin breakdown, due to Electrostatic Discharge $\frac{(ESD)}{MCLR}$ pin VIH and VIL specifications are met without interfering with the Debug/Programmer tools. - The capacitor can be sized to prevent unintentional Resets from brief glitches or to extend the device Reset period during POR. - 3: No pull-ups or bypass capacitors are allowed on active debug/program PGECx/PGEDx pins. #### 2.4 ICSP Pins The PGECx and PGEDx pins are used for ICSP and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of Ohms, not to exceed 100 Ohms. Pull-up resistors, series diodes and capacitors on the PGECx and PGEDx pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits and pin input voltage high (VIH) and input low (VIL) requirements. Ensure that the "Communication Channel Select" (i.e., PGECx/PGEDx pins) programmed into the device matches the physical connections for the ICSP to MPLAB® ICD 3 or MPLAB REAL ICE™. For additional information on ICD 3 and REAL ICE connection requirements, refer to the following documents that are available on the Microchip web site. - "Using MPLAB® ICD 3" (poster) DS50001765 - "MPLAB® ICD 3 Design Advisory" DS50001764 - "MPLAB® REAL ICE™ In-Circuit Debugger User's Guide" DS50001616 - "Using MPLAB® REAL ICE™ Emulator" (poster) DS50001749 #### 2.5 JTAG The TMS, TDO, TDI and TCK pins are used for testing and debugging according to the Joint Test Action Group (JTAG) standard. It is recommended to keep the trace length between the JTAG connector and the JTAG pins on the device as short as possible. If the JTAG connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of Ohms, not to exceed 100 Ohms Pull-up resistors, series diodes and capacitors on the TMS, TDO, TDI and TCK pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits and pin input voltage high (VIH) and input low (VIL) requirements. #### 2.6 Trace When present on select pin counts, the trace pins can be connected to a hardware trace-enabled programmer to provide a compressed real-time instruction trace. When used for trace, the TRD3, TRD2, TRD1, TRD0 and TRCLK pins should be dedicated for this use. The trace hardware requires a 22 Ohm series resistor between the trace pins and the trace connector. #### 2.7 External Oscillator Pins Many MCUs have options for at least two oscillators: a high-frequency primary oscillator and a low-frequency secondary oscillator (refer to **Section 9.0 "Oscillator Configuration"** for details). The oscillator circuit should be placed on the same side of the board as the device. Also, place the oscillator circuit close to the respective oscillator pins, not exceeding one-half inch (12 mm) distance between them. The load capacitors should be placed next to the oscillator itself, on the same side of the board. Use a grounded copper pour around the oscillator circuit to isolate them from surrounding circuits. The grounded copper pour should be routed directly to the MCU ground. Do not run any signal traces or power traces inside the ground pour. Also, if using a two-sided board, avoid any traces on the other side of the board where the crystal is placed. A suggested layout is illustrated in Figure 2-3. FIGURE 2-3: SUGGESTED OSCILLATOR CIRCUIT PLACEMENT # 2.7.1 CRYSTAL OSCILLATOR DESIGN CONSIDERATION The following example assumptions are used to calculate the Primary Oscillator loading capacitor values: - CIN = PIC32 OSCO Pin Capacitance = 4 pF - COUT = PIC32\_OSCI\_Pin Capacitance = 4 pF - PCB stray capacitance (i.e., 12 mm length) = 2.5 pF - C1 and C2 = the loading capacitors to use on your crystal circuit design to guarantee that the effective capacitance as seen by the crystal in circuit meets the crystal manufacturer specification MFG Crystal Data Sheet CLOAD spec: CLOAD = {( [CIN + C1] \* [COUT + C2] ) / [CIN + C1 + C2 + COUT] } + oscillator PCB stray capacitance # EXAMPLE 2-1: CRYSTAL LOAD CAPACITOR CALCULATION Crystal manufacturer data sheet spec example: CLOAD = 15 pF Therefore: $MFG\ CLOAD = \{(\ [CIN + C1] * [COUT + C2]\ ) / [CIN + C1 + C2 + COUT]\}$ + estimated oscillator PCB stray capacitance Assuming CI = C2 and PIC32 Cin = Cout, the formula can be further simplified and restated to solve for CI and C2 by: C1 = C2 = ((2 \* MFG Cload spec) - Cin - (2 \* PCB capacitance))= ((2 \* 15) - 4 - (2 \* 2.5 pF))= (30 - 4 - 5)= 21 pF Therefore: $CI=C2=21\,pF$ is the correct loading capacitors to use on your crystal circuit design to guarantee that the effective capacitance as seen by the crystal in circuit in this example is 15 pF to meet the crystal manufacturer specification. Tips to increase oscillator gain, (i.e., to increase peakto-peak oscillator signal): - Select an crystal oscillator with a lower XTAL manufacturing "ESR" rating. - C1 and C2 values also affect the gain of the oscillator. The lower the values, the higher the gain. - Likewise, C2/C1 ratio also affects gain. To increase the gain, make C1 slightly smaller than C2, which will also help start-up performance. NOLG Do not add excessive gain such that the oscillator signal is clipped, flat on top of the sine wave. If so, you need to reduce the gain or add a series resistor, Rs, as shown in circuit "A" in Figure 2-4. Failure to do so will stress and age the crystal, which can result in an early failure. When measuring the oscillator signal you must use an active-powered scope probe with ≤ 1 pF or the scope probe itself will unduly change the gain and peak-to-peak levels. #### 2.7.1.1 Additional Microchip References - AN588 "PICmicro® Microcontroller Oscillator Design Guide" - AN826 "Crystal Oscillator Basics and Crystal Selection for rfPIC™ and PICmicro® Devices" - AN849 "Basic PICmicro® Oscillator Design" #### FIGURE 2-4: # PRIMARY CRYSTAL OSCILLATOR CIRCUIT RECOMMENDATIONS Note: Refer to the "PIC32MK GP/MC Family with ECC Flash Silicon Errata and Data Sheet Clarification", which is available from the Microchip website (www.microchip.com), for the recommended Rs values versus crystal/frequency. #### 2.8 Unused I/Os Unused I/O pins should not be allowed to float as inputs. They can be configured as outputs and driven to a logic-low state. Alternatively, inputs can be reserved by connecting the pin to Vss through a 1k resistor and configuring the pin as an input, which they are by default on any Reset. # 2.9 Considerations When Interfacing to Remotely Powered Circuits #### 2.9.1 NON-5V TOLERANT INPUT PINS A quick review of the absolute maximum rating section in **37.0** "Electrical Characteristics" will indicate that the voltage on any non-5v tolerant pin may not exceed VDD + 0.3V unless the input current is limited to meet the respective injection current specifications defined by parameters DI60a, DI60b, and DI60c in TABLE 37-10: "DC Characteristics: I/O Pin Input Injection current Specifications". Figure 2-5 shows an example of a remote circuit using an independent power source, which is powered while connected to a PIC32 non-5V tolerant circuit that is not powered. FIGURE 2-5: PIC32 NON-5V TOLERANT CIRCUIT EXAMPLE Without proper signal isolation, on non-5V tolerant pins, the remote signal can power the PIC32 device through the high side ESD protection diodes. Besides violating the absolute maximum rating specification when VDD of the PIC32 device is restored and ramping up or ramping down, it can also negatively affect the internal Power-on Reset (POR) and Brown-out Reset (BOR) circuits, which can lead to improper initialization of internal PIC32 logic circuits. In these cases, it is recommended to implement digital or analog signal isolation as depicted in Figure 2-6, as appropriate. This is indicative of all industry microcontrollers and not just Microchip products. TABLE 2-1: EXAMPLES OF DIGITAL/ ANALOG ISOLATORS WITH OPTIONAL LEVEL TRANSLATION | Example Digital/Analog<br>Signal Isolation Circuits | Inductive Coupling | Capacitive Coupling | Opto Coupling | Analog/Digital Switch | |-----------------------------------------------------|--------------------|---------------------|---------------|-----------------------| | ADuM7241 / 40 ARZ (1 Mbps) | Χ | _ | _ | _ | | ADuM7241 / 40 CRZ (25 Mbps) | Х | _ | _ | _ | | ISO721 | _ | Х | _ | _ | | LTV-829S (2 Channel) | | | Χ | _ | | LTV-849S (4 Channel) | | | Χ | | | FSA266 / NC7WB66 | _ | _ | _ | Χ | FIGURE 2-6: EXAMPLE DIGITAL/ANALOG SIGNAL ISOLATION CIRCUITS #### 2.9.2 **5V TOLERANT INPUT PINS** The internal high side diode on 5v tolerant pins are bussed to an internal floating node, rather than being connected to VDD, as shown in Figure 2-7. Voltages on these pins, if VDD < 2.3V, should not exceed roughly 3.2V relative to Vss of the PIC32 device. Voltage of 3.6V or higher will violate the absolute maximum specification, and will stress the oxide layer separating the high side floating node, which impacts device reliability. If a remotely powered "digital-only" signal can be guaranteed to always be ≤ 3.2V relative to Vss on the PIC32 device side, a 5V tolerant pin could be used without the need for a digital isolator. This is assuming there is not a ground loop issue, logic ground of the two circuits not at the same absolute level, and a remote logic low input is not less than Vss - 0.3V. FIGURE 2-7: PIC32 5V TOLERANT PIN ARCHITECTURE EXAMPLE PIC32 On/Off VDD 5V Tolerant Pin Architecture Floating Bus Oxide BV = 3.6V OXIDE **ANSEL** if VDD < 2.3VI/O IN Remote VIH = 2.5V PIC32 RG10 **POWER** I/O OUT LOGIC **SUPPLY** Remote GND **TRIS** CPU Vss # 2.10 Designing for High-Speed Peripherals The PIC32MK GPK/MCM with CAN FD Family of devices have peripherals that operate at frequencies much higher than typical for an embedded environment. Table 2-2 lists the peripherals that produce high-speed signals on their external pins: TABLE 2-2: PERIPHERALS THAT PRODUCE HS SIGNALS ON EXTERNAL PINS | Peripheral | High-Speed Signal<br>Pins | Maximum<br>Speed on<br>Signal Pin | |----------------------|---------------------------|-----------------------------------| | SPI/I <sup>2</sup> S | SCKx, SDOx, SDIx | 50 MHz | | REFCLKx | REFCLKx | 50 MHz | Due to these high-speed signals, it is important to consider several factors when designing a product that uses these peripherals, as well as the PCB on which these components will be placed. Adhering to these recommendations will help achieve the following goals: - Minimize the effects of electromagnetic interference to the proper operation of the product - Ensure signals arrive at their intended destination at the same time - · Minimize crosstalk - · Maintain signal integrity - · Reduce system noise - · Minimize ground bounce and power sag #### 2.10.1 SYSTEM DESIGN #### 2.10.1.1 Impedance Matching When selecting parts to place on high-speed buses, particularly the SPI bus and/or REFCLKx output(s), if the impedance of the peripheral device does not match the impedance of the pins on the PIC32MK GPK/MCM with CAN FD Family device to which it is connected, signal reflections could result, thereby degrading the quality of the signal. If it is not possible to select a product that matches impedance, place a series resistor at the load to create the matching impedance. See Figure 2-8 for an example. FIGURE 2-8: SERIES RESISTOR #### 2.10.1.2 PCB Layout Recommendations The following list contains recommendations that will help ensure the PCB layout will promote the goals previously listed. #### Component Placement - Place bypass capacitors as close to their component power and ground pins as possible, and place them on the same side of the PCB - Devices on the same bus that have larger setup times should be placed closer to the PIC32MK GPK/MCM with CAN FD Family device #### · Power and Ground - Multi-layer PCBs will allow separate power and ground planes - Each ground pin should be connected to the ground plane individually - Place bypass capacitor vias as close to the pad as possible (preferably inside the pad) - If power and ground planes are not used, maximize width for power and ground traces - Use low-ESR, surface-mount bypass capacitors #### · Clocks and Oscillators - Place crystals as close as possible to the PIC32MK GPK/MCM with CAN FD Family device OSC/SOSC pins - Do not route high-speed signals near the clock or oscillator - Avoid via usage and branches in clock lines (SCK) - Place termination resistors at the end of clock lines #### Traces - Higher-priority signals should have the shortest traces - Avoid long run lengths on parallel traces to reduce coupling - Make the clock traces as straight as possible - Use rounded turns rather than right-angle turns - Have traces on different layers intersect on right angles to minimize crosstalk - Maximize the distance between traces, preferably no less than three times the trace width - Power traces should be as short and as wide as possible - High-speed traces should be placed close to the ground plane # 2.10.1.3 EMI/EMC/EFT (IEC 61000-4-4 and IEC 61000-4-2) Suppression Considerations The use of LDO regulators is preferred to reduce overall system noise and provide a cleaner power source. However, when utilizing switching Buck/Boost regulators as the local power source for PIC32MK GP devices, as well as in electrically noisy environments or test conditions required for IEC 61000-4-4 and IEC 61000-4-2, users should evaluate the use of T-Filters (i.e., L-C-L) on the power pins, as shown in Figure 2-9. In addition to a more stable power source, use of this type of T-Filter can greatly reduce susceptibility to EMI sources and events. FIGURE 2-9: EMI/EMC/EFT SUPPRESSION CIRCUIT # 2.11 Typical Application Connection Examples Examples of typical application connections are shown in Figure 2-10, Figure 2-11, and Figure 2-12. FIGURE 2-10: CAPACITIVE TOUCH SENSING WITH GRAPHICS APPLICATION #### FIGURE 2-11: AUDIO PLAYBACK APPLICATION FIGURE 2-12: LOW-COST CONTROLLERLESS (LCC) GRAPHICS APPLICATION WITH PROJECTED CAPACITIVE TOUCH | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 3.0 CPU - Note 1: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 50. "CPU for Devices with MIPS32® microAptiv™ and M-Class Cores" (DS60001192) of the "PIC32 Family Reference Manual", which is available from the Microchip web site (www.microchip.com/PIC32). - 2: The microAptiv™ CPU core resources are available at: www.imgtec.com. The MIPS32<sup>®</sup> microAptiv™ MCU Core is the heart of the PIC32MK GPK/MCM with CAN FD Family device processor. The CPU fetches instructions, decodes each instruction, fetches source operands, executes each instruction and writes the results of instruction execution to the proper destinations. The following are key features of the CPU module: - · 5-stage pipeline - · 32-bit address and data paths - MIPS32 Enhanced Architecture (Release 5): - Multiply-accumulate and multiply-subtract instructions - Targeted multiply instruction - Zero/One detect instructions - WAIT instruction - Conditional move instructions (MOVN, MOVZ) - Vectored interrupts - Programmable exception vector base - Atomic interrupt enable/disable - GPR shadow registers to minimize latency for interrupt handlers - Bit field manipulation instructions - Virtual memory support - microMIPS™ compatible instruction set: - Improves code size density over MIPS32, while maintaining MIPS32 performance. - Supports all MIPS32 instructions (except branch-likely instructions) - Fifteen additional 32-bit instructions and 39 16-bit instructions corresponding to commonly-used MIPS32 instructions - Stack pointer implicit in instruction - MIPS32 assembly and ABI compatible - · Autonomous Multiply/Divide Unit (MDU): - Maximum issue rate of one 32x32 multiply per clock - Early-in iterative divide. Minimum 12 and maximum 38 clock latency (dividend (rs) sign extension-dependent) - · Power Control: - Minimum frequency: 0 MHz - Low-Power mode (triggered by WAIT instruction) - Extensive use of local gated clocks - EJTAG Debug and Instruction Trace: - Support for single stepping - Virtual instruction and data address/value breakpoints - Hardware breakpoint supports both address match and address range triggering. - Eight instruction and four data complex breakpoints - iFlowtrace<sup>®</sup> version 2.0 support: - Real-time instruction program counter - Special events trace capability - Two performance counters with 34 userselectable countable events - Disabled if the processor enters Debug mode - Program Counter sampling - DSP ASE Extension: - Native fractional format data type operations - Register Single Instruction Multiple Data (SIMD) operations (add, subtract, multiply, shift) - GPR-based shift - Bit manipulation - Compare-Pick - DSP Control Access - Indexed-Load - Branch - Multiplication of complex operands - Variable bit insertion and extraction - Virtual circular buffers - Arithmetic saturation and overflow handling - Zero-cycle overhead saturation and rounding operations - · Floating Point Unit (FPU): - 1985 IEEE-754 compliant Floating Point Unit - Supports single and double precision datatypes - 2008 IEEE-754 compatibility control of NaN handling and Abs/Neg instructions - Runs at 1:1 core/FPU clock ratio A typical block diagram of the PIC32MK GPK/MCM with CAN FD Family processor core is shown in Figure 3-1. FIGURE 3-1: PIC32MK GPK/MCM WITH CAN FD FAMILY MICROPROCESSOR CORE BLOCK DIAGRAM #### 3.1 Architecture Overview The MIPS32 microAptiv MCU core in the PIC32MK GPK/MCM with CAN FD Family devices contains several logic blocks working together in parallel, providing an efficient high-performance computing engine. The following blocks are included with the core: - · Execution unit - · General Purpose Register (GPR) - · Multiply/Divide Unit (MDU) - · System control coprocessor (CP0) - Floating Point Unit (FPU) - · Power Management - · microMIPS support - · Enhanced JTAG (EJTAG) controller #### 3.1.1 EXECUTION UNIT The processor core execution unit implements a load/store architecture with single-cycle ALU operations (logical, shift, add, subtract) and an autonomous multiply/divide unit. The core contains thirty-two 32-bit General Purpose Registers (GPRs) used for integer operations and address calculation. Seven additional register file shadow sets (containing thirty-two registers) are added to minimize context switching overhead during interrupt/exception processing. The register file consists of two read ports and one write port and is fully bypassed to minimize operation latency in the pipeline. The execution unit includes: - · 32-bit adder used for calculating the data address - Address unit for calculating the next instruction address - Logic for branch determination and branch target address calculation - · Load aligner - Trap condition comparator - Bypass multiplexers used to avoid stalls when executing instruction streams where data producing instructions are followed closely by consumers of their results - Leading Zero/One detect unit for implementing the CLZ and CLO instructions - Arithmetic Logic Unit (ALU) for performing arithmetic and bitwise logical operations - · Shifter and store aligner - DSP ALU and logic block for performing DSP instructions, such as arithmetic/shift/compare operations #### 3.1.2 MULTIPLY/DIVIDE UNIT (MDU) The processor core includes a Multiply/Divide Unit (MDU) that contains a separate pipeline for multiply and divide operations, and DSP ASE multiply instructions. This pipeline operates in parallel with the Integer Unit (IU) pipeline and does not stall when the IU pipeline stalls. This allows MDU operations to be partially masked by system stalls and/or other integer unit instructions. The high-performance MDU consists of a 32x16 Booth recoded multiplier, a pair of result/accumulation registers (HI and LO), a divide state machine, and the necessary multiplexers and control logic. The first number shown ('32' of 32x16) represents the rs operand. The second number '16' of 32x16) represents the rt operand. The MDU supports execution of one multiply or multiply-accumulate operation every clock cycle. Divide operations are implemented with a simple 1-bit-per-clock iterative algorithm. An early-in detection checks the sign extension of the dividend (rs) operand. If rs is 8 bits wide, 23 iterations are skipped. For a 16-bit wide rs, 15 iterations are skipped and for a 24-bit wide rs, 7 iterations are skipped. Any attempt to issue a subsequent MDU instruction while a divide is still active causes an IU pipeline stall until the divide operation has completed. Table 3-1 lists the repeat rate (peak issue rate of cycles until the operation can be reissued) and latency (number of cycles until a result is available) for the processor core multiply and divide instructions. The approximate latency and repeat rates are listed in terms of pipeline clocks. TABLE 3-1: MIPS32<sup>®</sup> microAptiv<sup>™</sup> MCU CORE HIGH-PERFORMANCE INTEGER MULTIPLY/ DIVIDE UNIT LATENCIES AND REPEAT RATES | Opcode | Operand Size (mul rt) (div rs) | Latency | Repeat Rate | |--------------------------------|--------------------------------|---------|-------------| | MULT/MULTU, MADD/MADDU, | 16 bits | 5 | 1 | | MSUB/MSUBU (HI/LO destination) | 32 bits | 5 | 1 | | MUL (GPR destination) | 16 bits | 5 | 1 | | | 32 bits | 5 | 1 | | DIV/DIVU | 8 bits | 12/14 | 12/14 | | | 16 bits | 20/22 | 20/22 | | | 24 bits | 28/30 | 28/30 | | | 32 bits | 36/38 | 36/38 | The MIPS architecture defines that the result of a multiply or divide operation be placed in one of four pairs of HI and LO registers. Using the Move-From-HI (MFHI) and Move-From-LO (MFLO) instructions, these values can be transferred to the General Purpose Register file. In addition to the HI/LO targeted operations, the MIPS32 architecture also defines a multiply instruction, $\mathtt{MUL}$ , which places the least significant results in the primary register file instead of the HI/LO register pair. By avoiding the explicit $\mathtt{MFLO}$ instruction required when using the LO register, and by supporting multiple destination registers, the throughput of multiply-intensive operations is increased. Two other instructions, Multiply-Add (MADD) and Multiply-Subtract (MSUB), are used to perform the multiply-accumulate and multiply-subtract operations. The MADD instruction multiplies two numbers and then adds the product to the current contents of the HI and LO registers. Similarly, the MSUB instruction multiplies two operands and then subtracts the product from the HI and LO registers. The MADD and MSUB operations are commonly used in DSP algorithms. The MDU also implements various shift instructions operating on the HI/LO register and multiply instructions as defined in the DSP ASE. The MDU supports all of the data types required for this purpose and includes three extra HI/LO registers as defined by the ASE. Table 3-2 lists the latencies and repeat rates for the DSP multiply and dot-product operations. The approximate latencies and repeat rates are listed in terms of pipeline clocks. TABLE 3-2: DSP-RELATED LATENCIES AND REPEAT RATES | Op code | Latency | Repeat<br>Rate | |----------------------------------------------------------------|---------|----------------| | Multiply and dot-product without saturation after accumulation | 5 | 1 | | Multiply and dot-product with saturation after accumulation | 5 | 1 | | Multiply without accumulation | 5 | 1 | # 3.1.3 SYSTEM CONTROL COPROCESSOR (CP0) In the MIPS architecture, CP0 is responsible for the virtual-to-physical address translation, the exception control system, the processor's diagnostics capability, the operating modes (Kernel, User and Debug) and whether interrupts are enabled or disabled. Configuration information, such as the presence of options like microMIPS is also available by accessing the CP0 registers, listed in Table 3-3. TABLE 3-3: COPROCESSOR 0 REGISTERS | Register<br>Number | Register<br>Name | Function | |--------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------| | 0-6 | Reserved | Reserved in the PIC32MK GP Family core. | | 7 | HWREna | Enables access via the RDHWR instruction to selected hardware registers in Non-privileged mode. | | 8 | BadVAddr | Reports the address for the most recent address-related exception. | | | BadInstr | Reports the instruction that caused the most recent exception. | | | BadInstrP | Reports the branch instruction if a delay slot caused the most recent exception. | | 9 | Count | Processor cycle count. | | 10 | Reserved | Reserved in the PIC32MK GP Family core. | | 11 | Compare | Core timer interrupt control. | | 12 | Status | Processor status and control. | | | IntCtl | Interrupt control of vector spacing. | | | SRSCtl | Shadow register set control. | | | SRSMap | Shadow register mapping control. | | | View_IPL | Allows the Priority Level to be read/written without extracting or inserting that bit from/to the Status register. | | | SRSMAP2 | Contains two 4-bit fields that provide the mapping from a vector number to the shadow set number to use when servicing such an interrupt. | | 13 | Cause | Describes the cause of the last exception. | | | NestedExc | Contains the error and exception level status bit values that existed prior to the current exception. | | | View_RIPL | Enables read access to the RIPL bit that is available in the Cause register. | TABLE 3-3: COPROCESSOR 0 REGISTERS (CONTINUED) | Register<br>Number | Register<br>Name | Function | |--------------------|------------------|-------------------------------------------------------------------------------------| | 14 | EPC | Program counter at last exception. | | | NestedEPC | Contains the exception program counter that existed prior to the current exception. | | 15 | PRID | Processor identification and revision | | | Ebase | Exception base address of exception vectors. | | | CDMMBase | Common device memory map base. | | 16 | Config | Configuration register. | | | Config1 | Configuration register 1. | | | Config2 | Configuration register 2. | | | Config3 | Configuration register 3. | | | Config4 | Configuration register 4. | | | Config5 | Configuration register 5. | | | Config7 | Configuration register 7. | | 17 | Reserved | Reserved in the PIC32MK GP Family core. | | 18 | Reserved | Reserved in the PIC32MK GP Family core. | | 19 | Reserved | Reserved in the PIC32MK GP Family core. | | 20-22 | Reserved | Reserved in the PIC32MK GP Family core. | | 23 | Debug | EJTAG debug register. | | | TraceControl | EJTAG trace control. | | | TraceControl2 | EJTAG trace control 2. | | | UserTraceData1 | EJTAG user trace data 1 register. | | | TraceBPC | EJTAG trace breakpoint register. | | | Debug2 | Debug control/exception status 1. | | 24 | DEPC | Program counter at last debug exception. | | | UserTraceData2 | EJTAG user trace data 2 register. | | 25 | PerfCtI0 | Performance counter 0 control. | | | PerfCnt0 | Performance counter 0. | | | PerfCtl1 | Performance counter 1 control. | | | PerfCnt1 | Performance counter 1. | | 26 | Reserved | Reserved in the PIC32MK GP Family core. | | 27 | Reserved | Reserved in the PIC32MK GP Family core. | | 28 | Reserved | Reserved in the PIC32MK GP Family core. | | 29 | Reserved | Reserved in the PIC32MK GP Family core. | | 30 | ErrorEPC | Program counter at last error exception. | | 31 | DeSave | Debug exception save. | #### 3.1.4 FLOATING POINT UNIT (FPU) The Floating Point Unit (FPU), Coprocessor (CP1), implements the MIPS Instruction Set Architecture for floating point computation. The implementation supports the ANSI/IEEE Standard 754 (IEEE for Binary Floating Point Arithmetic) for single- and double-precision data formats. The FPU can be programmed to have thirty-two 32-bit or 64-bit floating point registers used for floating point operations. The performance is optimized for single precision formats. Most instructions have one FPU cycle throughput and four FPU cycle latency. The FPU implements the multiply-add (MADD) and multiply-sub (MSUB) instructions with intermediate rounding after the multiply function. The result is guaranteed to be the same as executing a MUL and an ADD instruction separately, but the instruction latency, instruction fetch, dispatch bandwidth, and the total number of register accesses are improved. IEEE denormalized input operands and results are supported by hardware for some instructions. IEEE denormalized results are not supported by hardware in general, but a fast flush-to-zero mode is provided to optimize performance. The fast flush-to-zero mode is enabled through the FCCR register, and use of this mode is recommended for best performance when denormalized results are generated. The FPU has a separate pipeline for floating point instruction execution. This pipeline operates in parallel with the integer core pipeline and does not stall when the integer pipeline stalls. This allows long-running FPU operations, such as divide or square root, to be partially masked by system stalls and/or other integer unit instructions. Arithmetic instructions are always dispatched and completed in order, but loads and stores can complete out of order. The exception model is "precise" at all times. Table 3-4 contains the floating point instruction latencies and repeat rates for the processor core. In this table, 'Latency' refers to the number of FPU cycles necessary for the first instruction to produce the result needed by the second instruction. The "Repeat Rate" refers to the maximum rate at which an instruction can be executed per FPU cycle. TABLE 3-4: FPU INSTRUCTION LATENCIES AND REPEAT RATES | Op code | Latency<br>(FPU<br>Cycles) | Repeat<br>Rate<br>(FPU<br>Cycles) | |-----------------------------------------------------------------------------------------------------|----------------------------|-----------------------------------| | ABS.[S,D], NEG.[S,D],<br>ADD.[S,D], SUB.[S,D],<br>C.cond.[S,D], MUL.S | 4 | 1 | | MADD.S, MSUB.S,<br>NMADD.S, NMSUB.S,<br>CABS.cond.[S,D] | 4 | 1 | | CVT.D.S, CVT.PS.PW,<br>CVT.[S,D].[W,L] | 4 | 1 | | CVT.S.D, CVT.[W,L].[S,D], CEIL.[W,L].[S,D], FLOOR.[W,L].[S,D], ROUND.[W,L].[S,D], TRUNC.[W,L].[S,D] | 4 | 1 | | MOV.[S,D], MOVF.[S,D],<br>MOVN.[S,D],<br>MOVT.[S,D], MOVZ.[S,D] | 4 | 1 | | MUL.D | 5 | 2 | | MADD.D, MSUB.D,<br>NMADD.D, NMSUB.D | 5 | 2 | | RECIP.S | 13 | 10 | | RECIP.D | 26 | 21 | | RSQRT.S | 17 | 14 | | RSQRT.D | 36 | 31 | | DIV.S, SQRT.S | 17 | 14 | | DIV.D, SQRT.D | 32 | 29 | | MTC1, DMTC1, LWC1,<br>LDC1, LDXC1, LUXC1,<br>LWXC1 | 4 | 1 | | MFC1, DMFC1, SWC1,<br>SDC1, SDXC1, SUXC1,<br>SWXC1 | 1 | 1 | **Legend:** S = Single D = Double W = Word L = Long word The FPU implements a high-performance 7-stage pipeline: - Decode, register read and unpack (FR stage) - Multiply tree double pumped for double (M1 stage) - Multiply complete (M2 stage) - Addition first step (A1 stage) - · Addition second and final step (A2 stage) - · Packing to IEEE format (FP stage) - · Register writeback (FW stage) The FPU implements a bypass mechanism that allows the result of an operation to be forwarded directly to the instruction that needs it without having to write the result to the FPU register and then read it back. Table 3-5 lists the Coprocessor 1 Registers for the FPU. TABLE 3-5: FPU (CP1) REGISTERS | Register<br>Number | Register<br>Name | Function | |--------------------|------------------|---------------------------------------------------------------------------------------| | 0 | FIR | Floating Point implementation register. Contains information that identifies the FPU. | | 25 | FCCR | Floating Point condition codes register. | | 26 | FEXR | Floating Point exceptions register. | | 28 | FENR | Floating Point enables register. | | 31 | FCSR | Floating Point Control and Status register. | #### 3.2 Power Management The processor core offers a number of power management features, including low-power design, active power management and power-down modes of operation. The core is a static design that supports slowing or halting the clocks, which reduces system power consumption during Idle periods. # 3.2.1 INSTRUCTION-CONTROLLED POWER MANAGEMENT The mechanism for invoking Power-Down mode is through execution of the WAIT instruction. For more information on power management, see 33.0 "Power-Saving Features". #### 3.2.2 LOCAL CLOCK GATING The majority of the power consumed by the processor core is in the clock tree and clocking registers. The PIC32MK family makes extensive use of local gated-clocks to reduce this dynamic power consumption. #### 3.3 EJTAG Debug Support The processor core provides for an Enhanced JTAG (EJTAG) interface for use in the software debug of application and kernel code. In addition to standard User mode and Kernel modes of operation, the processor core provides a Debug mode that is entered after a debug exception (derived from a hardware breakpoint, single-step exception, etc.) is taken and continues until a Debug Exception Return (DERET) instruction is executed. During this time, the processor executes the debug exception handler routine. The EJTAG interface operates through the Test Access Port (TAP), a serial communication port used for transferring test data in and out of the core. In addition to the standard JTAG instructions, special instructions defined in the EJTAG specification specify which registers are selected and how they are used. #### 3.4 MIPS DSP ASE Extension The MIPS DSP Application-Specific Extension Revision 2 is an extension to the MIPS32 architecture. This extension comprises new integer instructions and states that include new HI/LO accumulator register pairs and a DSP control register. This extension is crucial in a wide range of DSP, multimedia, and DSP-like algorithms covering Audio and Video processing applications. The extension supports native fractional format data type operations, register Single Instruction Multiple Data (SIMD) operations, such as add, subtract, multiply, and shift. In addition, the extension includes the following features that are essential in making DSP algorithms computationally efficient: - · Support for multiplication of complex operands - · Variable bit insertion and extraction - · Implementation and use of virtual circular buffers - Arithmetic saturation and overflow handling support - Zero cycle overhead saturation and rounding operations #### 3.5 microMIPS ISA The processor core supports the microMIPS ISA, which contains all MIPS32 ISA instructions (except for branch-likely instructions) in a new 32-bit encoding scheme, with some of the commonly used instructions also available in 16-bit encoded format. This ISA improves code density through the additional 16-bit instructions while maintaining a performance similar to MIPS32 mode. In microMIPS mode, 16-bit or 32-bit instructions will be fetched and recoded to legacy MIPS32 instruction opcodes in the pipeline's I stage, so that the processor core can have the same microAptiv MPU microarchitecture. Because the microMIPS instruction stream can be intermixed with 16-bit halfword or 32-bit word size instructions on halfword or word boundaries, additional logic is in place to address the word misalignment issues, thus minimizing performance loss. # 3.6 MIPS32<sup>®</sup> microAptiv<sup>™</sup> MCU Core Configuration Register 3-1 through Register 3-5 show the default configuration of the MIPS32 microAptiv MCU core, which is included on the PIC32MK GPK/MCM with CAN FD Family of devices. REGISTER 3-1: CONFIG: CONFIGURATION REGISTER; CP0 REGISTER 16, SELECT 0 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 21.24 | r-1 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R-0 | | 31:24 | _ | _ | _ | _ | _ | _ | _ | ISP | | 00:40 | R-0 | R-0 | R-1 | R-0 | U-0 | R-1 | R-0 | R-0 | | 23:16 | DSP | UDI | SB | MDU | _ | MM<1:0> | | BM | | 45.0 | R-0 | R-0 | R-0 | R-0 | R-0 | R-1 | R-0 | R-1 | | 15:8 | BE | AT< | 1:0> | | AR<2:0> | | U-0 | U-0 | | 7:0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | _ | _ | | 7.0 | _ | _ | _ | _ | _ | | K0<2:0> | | Legend:r = Reserved bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31 Reserved: This bit is hardwired to '1' to indicate the presence of the Config1 register. bit 30-25 Unimplemented: Read as '0' bit 24 ISP: Instruction Scratch Pad RAM bit 0 = Instruction Scratch Pad RAM is not implemented bit 23 DSP: Data Scratch Pad RAM bit $_{ m 0}$ = Data Scratch Pad RAM is not implemented bit 22 UDI: User-defined bit 0 = CorExtend User-Defined Instructions are not implemented bit 21 SB: SimpleBE bit 1 = Only Simple Byte Enables are allowed on the internal bus interface bit 20 MDU: Multiply/Divide Unit bit 0 = Fast, high-performance MDU bit 19 Unimplemented: Read as '0' bit 18-17 MM<1:0>: Merge Mode bits 10 = Merging is allowed bit 16 **BM:** Burst Mode bit 0 = Burst order is sequential bit 15 **BE:** Endian Mode bit 0 = Little-endian bit 14-13 AT<1:0>: Architecture Type bits 00 = MIPS32 bit 12-10 AR<2:0>: Architecture Revision Level bits 001 = MIPS32 Release 2 bit 9-3 Unimplemented: Read as '0' #### REGISTER 3-1: CONFIG: CONFIGURATION REGISTER; CP0 REGISTER 16, SELECT 0 bit 2-0 **K0<2:0>:** Kseg0 Coherency Algorithm bits 000 = Reserved 001 = Reserved 010 = Instruction Prefetch Uncached (Default) 011 = Instruction Prefetch cached (Recommended) 100 = Reserved • • 111 = Reserved #### REGISTER 3-2: CONFIG1: CONFIGURATION REGISTER 1; CP0 REGISTER 16, SELECT 1 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | r-1 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | U-0 | | 31:24 | | | • | MMUSIZ | E<5:0> | | • | _ | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 | U-0 | U-0 | R-1 | R-1 | R-0 | R-1 | R-1 | | 7:0 | _ | _ | _ | PC | WR | CA | EP | FP | Legend: r = Reserved bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 Reserved: This bit is hardwired to a '1' to indicate the presence of the Config2 register. bit 30-25 MMUSIZE<5:0>: MMU Size bits **Note:** This bit field is read as '0' decimal in the fixed table-based MMU core, as no TLB is present. bit 24-5 **Unimplemented:** Read as '0' bit 4 **PC:** Performance Counter bit 1 = The processor core contains Performance Counters bit 3 WR: Watch Register Presence bit 1 = No Watch registers are present bit 2 CA: Code Compression Implemented bit 0 = No MIPS16e® present bit 1 EP: EJTAG Present bit 1 = Core implements EJTAG bit 0 **FP:** Floating Point Unit bit 1 = Floating Point Unit is present #### REGISTER 3-3: CONFIG3: CONFIGURATION REGISTER 3; CP0 REGISTER 16, SELECT 3 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|-------------------------| | 24.24 | r-1 | U-0 | 31:24 | _ | _ | | _ | _ | | _ | _ | | 00:40 | U-0 | R-0 | R-1 | R-0 | R-0 | R-0 | R-1 | R/W-y | | 23:16 | _ | IPLW<1:0> | | MMAR<2:0> | | | MCU | ISAONEXC <sup>(1)</sup> | | 45.0 | R-y | R-y | R-1 | R-1 | R-1 | R-1 | U-0 | R-1 | | 15:8 | ISA<1:0> <sup>(1)</sup> | | ULRI | RXI | DSP2P | DSPP | _ | ITL | | 7.0 | U-0 | R-1 | R-1 | R-0 | R-1 | U-0 | U-0 | R-0 | | 7:0 | _ | VEIC | VINT | SP | CDMM | _ | _ | TL | Legend:r = Reserved bity = Value set from Configuration bits on PORR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31 Reserved: This bit is hardwired as '1' to indicate the presence of the Config4 register bit 30-23 Unimplemented: Read as '0' bit 22-21 IPLW<1:0>: Width of the Status IPL and Cause RIPL bits 01 = IPL and RIPL bits are 8-bits in width bit 20-18 MMAR<2:0>: microMIPS Architecture Revision Level bits 000 = Release 1 bit 17 MCU: MIPS<sup>®</sup> MCU™ ASE Implemented bit 1 = MCU ASE is implemented bit 16 **ISAONEXC:** ISA on Exception bit<sup>(1)</sup> 1 = microMIPS is used on entrance to an exception vector 0 = MIPS32 ISA is used on entrance to an exception vector bit 15-14 ISA<1:0>: Instruction Set Availability bits(1) 11 = Both MIPS32 and microMIPS are implemented; microMIPS is used when coming out of reset 10 = Both MIPS32 and microMIPS are implemented; MIPS32 ISA used when coming out of reset bit 13 ULRI: UserLocal Register Implemented bit 1 = UserLocal Coprocessor 0 register is implemented bit 12 **RXI:** RIE and XIE Implemented in PageGrain bit 1 = RIE and XIE bits are implemented bit 11 DSP2P: MIPS DSP ASE Revision 2 Presence bit 1 = DSP Revision 2 is present bit 10 DSPP: MIPS DSP ASE Presence bit 1 = DSP is present bit 9 Unimplemented: Read as '0' bit 8 ITL: Indicates that iFlowtrace® hardware is present 1 = The iFlowtrace<sup>®</sup> 2.0 hardware is implemented in the core bit 7 Unimplemented: Read as '0' bit 6 **VEIC:** External Vector Interrupt Controller bit 1 = Support for an external interrupt controller is implemented. bit 5 VINT: Vector Interrupt bit 1 = Vector interrupts are implemented bit 4 SP: Small Page bit 0 = 4 KB page size Note 1: These bits are set based on the value of the BOOTISA Configuration bit (DEVCFG0<6>). REGISTER 3-3: CONFIG3: CONFIGURATION REGISTER 3; CP0 REGISTER 16, SELECT 3 bit 3 CDMM: Common Device Memory Map bit 1 = CDMM is implemented bit 2-1 Unimplemented: Read as '0' bit 0 TL: Trace Logic bit 0 = Trace logic is not implemented Note 1: These bits are set based on the value of the BOOTISA Configuration bit (DEVCFG0<6>). #### REGISTER 3-4: CONFIG4: CONFIGURATION REGISTER 4; CP0 REGISTER 16, SELECT 4 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R-1 | U-0 | | | 31:24 | M | _ | _ | _ | _ | _ | _ | _ | | | | 00:40 | R-0 | | | 23:16 | KScr Exist<7:0> | | | | | | | | | | | 45.0 | R/W-0 | | | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | | | 7:0 | R/W-0 | | | | _ | _ | _ | _ | _ | _ | _ | _ | | | **Legend:** r = Reserved R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 M: Config5 Register Present bit 1 = Config5 register is present 0 = Config5 register is not present bit 30-24 Unimplemented: Read as '0' bit 23-16 KScr Exist<7:0>: Number of Scratch Registers Available to Kernel Mode bits Indicates how many scratch registers are available to Kernel mode software within CP0 Register 31. Each bit represents a select for Coprocessor0 Register 31. Bit 16 represents Select 0. Bit 23 represents Select 7. If the bit is set, the associated scratch register is implemented and is available for Kernel mode software. Note: These bits are read-only, and this field is all zeros on these products, as is read as '0'. bit 15-0 Reserved: Read/write as '0' #### REGISTER 3-5: CONFIG5: CONFIGURATION REGISTER 5; CP0 REGISTER 16, SELECT 5 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | | _ | _ | _ | _ | _ | _ | _ | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | | _ | _ | _ | _ | _ | _ | _ | | 7:0 | U-0 R-1 | | | _ | _ | _ | _ | _ | _ | _ | NF | **Legend:** r = Reserved R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-1 Unimplemented: Read as '0' bit 0 NF: Nested Fault bit 1 = Nested Fault feature is implemented #### REGISTER 3-6: CONFIG7: CONFIGURATION REGISTER 7; CP0 REGISTER 16, SELECT 7 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R-1 | U-0 | 31:24 | WII | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 | 7:0 | _ | _ | _ | _ | _ | _ | _ | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 WII: Wait IE Ignore bit 1 = Indicates that this processor will allow an interrupt to unblock a WAIT instruction bit 30-0 Unimplemented: Read as '0' #### REGISTER 3-7: FIR: FLOATING POINT IMPLEMENTATION REGISTER; CP1 REGISTER 0 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | U-0 | U-0 | U-0 | R-1 | U-0 | U-0 | U-0 | R-1 | | | | 31:24 | _ | _ | _ | UFRP | _ | _ | _ | FC | | | | 22.40 | R-1 | R-1 | R-1 | R-1 | R-0 | R-0 | R-1 | R-1 | | | | 23:16 | HAS2008 | F64 | L | W | MIPS3D | PS | D | S | | | | 45.0 | R-1 | R-0 | R-1 | R-0 | R-0 | R-1 | R-1 | R-1 | | | | 15:8 | PRID<7:0> | | | | | | | | | | | 7:0 | R-x | | | | | | | REVISIO | N<7:0> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' bit 28 UFRP: User Mode FR Switching Instruction bit 1 = User mode FR switching instructions are supported 0 = User mode FR switching instructions are not supported bit 27-25 Unimplemented: Read as '0' bit 24 FC: Full Convert Ranges bit 1 = Full convert ranges are implemented (all numbers can be converted to another type by the FPU) 0 = Full convert ranges are not implemented bit 23 **HAS008:** IEEE-754-2008 bit 1 = MAC2008, ABS2008, NAN2008 bits exist within the FCSR register 0 = MAC2009, ABS2008, and NAN2008 bits do not exist within the FCSR register bit 22 **F64:** 64-bit FPU bit 1 = This is a 64-bit FPU 0 = This is not a 64-bit FPU bit 21 L: Long Fixed Point Data Type bit 1 = Long fixed point data types are implemented 0 = Long fixed point data types are not implemented bit 20 W: Word Fixed Point data type bit 1 = Word fixed point data types are implemented 0 = Word fixed point data types are not implemented bit 19 MIPS3D: MIPS-3D ASE bit 1 = MIPS-3D is implemented 0 = MIPS-3D is not implemented bit 18 **PS:** Paired Single Floating Point data bit 1 = PS floating point is implemented 0 = PS floating point is not implemented bit 17 **D:** Double-precision floating point data bit 1 = Double-precision floating point data types are implemented 0 = Double-precision floating point data types are not implemented bit 16 S: Single-precision Floating Point Data bit 1 = Single-precision floating point data types are implemented 0 = Single-precision floating point data types are not implemented bit 15-8 PRID<7:0>: Processor Identification bits These bits allow software to distinguish between the various types of MIPS processors. For PIC32 devices with the MIPS32 microAptiv MCU core, this value is 0x9D. bit 7-0 REVISION<7:0>: Processor Revision Identification bits These bits allow software to distinguish between one revision and another of the same processor type. This number is increased on major revisions of the processor core #### REGISTER 3-8: FCCR: FLOATING POINT CONDITION CODES REGISTER; CP1 REGISTER 25 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7:0 | R/W-x | | | | | FCC< | 7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-0 FCC<7:0>: Floating Point Condition Code bits These bits record the results of floating point compares and are tested for floating point conditional branches and conditional moves. #### REGISTER 3-9: FEXR: FLOATING POINT EXCEPTIONS STATUS REGISTER; CP1 REGISTER 26 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | | _ | | | _ | _ | _ | _ | | | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-x | R/W-x | | 23:16 | _ | _ | _ | _ | _ | _ | CAUSE<5:4> | | | | | | | | | | Е | V | | | R/W-x | R/W-x | R/W-x | U-0 | U-0 | U-0 | U-0 | U-0 | | 15:8 | | CAUSE | CAUSE<3:0> | | | | | | | | Z | 0 | U | I | _ | _ | _ | _ | | | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | U-0 | U-0 | | 7:0 | | | | FLAGS<4:0> | , | | | | | | _ | V | Z | 0 | U | ļ | | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-18 Unimplemented: Read as '0' bit 17-12 CAUSE<5:0>: FPU Exception Cause bits These bits indicated the exception conditions that arise during execution of an FPU arithmetic instruction. bit 16 V: Invalid Operation bit bit 15 Z: Divide-by-Zero bit bit 14 O: Overflow bit bit 13 U: Underflow bit bit 11-7 Unimplemented: Read as '0' bit 6-2 **FLAGS<4:0>:** FPU Flags bits These bits show any exception conditions that have occurred for completed instructions since the flag was last reset by software. bit 6 V: Invalid Operation bit bit 4 Z: Divide-by-Zero bit bit 4 O: Overflow bit bit 3 U: Underflow bit bit 2 I: Inexact bit bit 1-0 Unimplemented: Read as '0' #### REGISTER 3-10: FENR: FLOATING POINT EXCEPTIONS AND MODES ENABLE REGISTER; CP1 REGISTER 28 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | | 1 | - | - | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | | 1 | - | - | _ | _ | _ | _ | | | U-0 | U-0 | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | | 15:8 | | | | | ENABLES<4:1> | | | | | | _ | _ | _ | _ | V | Z | 0 | U | | | R/W-x | U-0 | U-0 | U-0 | U-0 | R-x | R/W-x | R/W-x | | 7:0 | ENABLES<0> | | _ | _ | _ | FS | DM | 1:0> | | | I | _ | | | | | RM<1:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-12 Unimplemented: Read as '0' bit 11-7 ENABLES<4:0>: FPU Exception Enable bits These bits control whether or not a trap is taken when an IEEE exception condition occurs for any of the five conditions. The trap occurs when both an enable bit and its corresponding cause bit are set either during an FPU arithmetic operation or by moving a value to the FCSR or one of its alternative representations. bit 11 V: Invalid Operation bit bit 10 **Z:** Divide-by-Zero bit bit 9 **O:** Overflow bit bit 8 **U:** Underflow bit bit 7 I: Inexact bit bit 6-3 Unimplemented: Read as '0' bit 2 FS: Flush to Zero control bit 1 = Denormal input operands are flushed to zero. Tiny results are flushed to either zero or the applied format's smallest normalized number (MinNorm) depending on the rounding mode settings. 0 = Denormal input operands result in an Unimplemented Operation exception. bit 1-0 RM<1:0>: Rounding Mode control bits 11 = Round towards Minus Infinity ( $-\infty$ ) 10 = Round towards Plus Infinity (+ $\infty$ ) 01 = Round toward Zero (0) 00 = Round to Nearest #### REGISTER 3-11: FCSR: FLOATING POINT CONTROL AND STATUS REGISTER; CP1 REGISTER 31 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | R/W-x | 31:24 | | | ı | FCC<7:1> | | | | FS | | 00:40 | R/W-x | R/W-x | R/W-x | R-0 | R-1 | R-1 | R/W-x | R/W-x | | 23:16 | FCC<0> | FO | FN | MAC2008 | ABS2008 | NAN2008 | CAUS | E<5:4> | | | R/W-x | 15:8 | CAUSE<3:0> | | | | ENABLES<4:1> | | | | | | | CAUSE | V | Z | 0 | U | | | | | R/W-x | 7:0 | ENABLES<0> | | | FLAGS<4:0> | , DM. | | | ·1·0> | | | I | V | Z | 0 | U | I | RM<1:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-25 FCC<7:1>: Floating Point Condition Code bits These bits record the results of floating point compares and are tested for floating point conditional branches and conditional moves. - bit 24 FS: Flush to Zero control bit - 1 = Denormal input operands are flushed to zero. Tiny results are flushed to either zero or the applied format's smallest normalized number (MinNorm) depending on the rounding mode settings. - 0 = Denormal input operands result in an Unimplemented Operation exception. - bit 23 **FCC<0>:** Floating Point Condition Code bits These bits record the results of floating point compares and are tested for floating point conditional branches and conditional moves. - bit 22 FO: Flush Override Control bit - 1 = The intermediate result is kept in an internal format, which can be perceived as having the usual mantissa precision but with unlimited exponent precision and without forcing to a specific value or taking an exception. - 0 = Handling of Tiny Result values depends on setting of the FS bit. - bit 21 FN: Flush to Nearest Control bit - 1 = Final result is rounded to either zero or 2E\_min (MinNorm), whichever is closest when in Round to Nearest (RN) rounding mode. For other rounding modes, a final result is given as if FS was set to 1. - 0 = Handling of Tiny Result values depends on setting of the FS bit. - bit 20 MAC2008: Fused Multiply Add mode control bit - 0 = Unfused multiply-add. Intermediary multiplication results are rounded to the destination format. - bit 19 ABS2008: Absolute value format control bit - 1 = ABS.fmt and NEG.fmt instructions compliant with IEEE Standard 754-2008. The ABS and NEG functions accept QNAN inputs without trapping. - bit 18 NAN2008: NaN Encoding control bit - 1 = Quiet and signaling NaN encodings recommended by the IEEE Standard 754-2008. A quiet NaN is encoded with the first bit of the fraction being 1 and a signaling NaN is encoded with the first bit of the fraction being 0. - bit 17-12 CAUSE<5:0>: FPU Exception Cause bits These bits indicated the exception conditions that arise during execution of an FPU arithmetic instruction. - bit 16 V: Invalid Operation bit - bit 15 **Z:** Divide-by-Zero bit #### REGISTER 3-11: FCSR: FLOATING POINT CONTROL AND STATUS REGISTER; CP1 REGISTER 31 - bit 14 **O:** Overflow bit bit 13 **U:** Underflow bit bit 12 **I:** Inexact bit - bit 11-7 ENABLES<4:0>: FPU Exception Enable bits These bits control whether or not a trap is taken when an IEEE exception condition occurs for any of the five conditions. The trap occurs when both an enable bit and its corresponding cause bit are set either during an FPU arithmetic operation or by moving a value to the FCSR or one of its alternative representations. - bit 11 V: Invalid Operation bit bit 10 Z: Divide-by-Zero bit bit 9 O: Overflow bit bit 8 U: Underflow bit bit 7 I: Inexact bit - bit 6-2 FLAGS<4:0>: FPU Flags bits These bits show any exception conditions that have occurred for completed instructions since the flag was last reset by software. - bit 6 V: Invalid Operation bit bit 5 Z: Divide-by-Zero bit O: Overflow bit U: Underflow bit bit 2 I: Inexact bit - bit 1-0 RM<1:0>: Rounding Mode control bits - 11 = Round towards Minus Infinity ( $-\infty$ ) - 10 = Round towards Plus Infinity (+ $\infty$ ) - 01 = Round toward Zero (0) - 00 = Round to Nearest | | Witti | TID Tull | | |--------|-------|----------|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 4.0 MEMORY ORGANIZATION Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive For detailed reference source. information, refer to Section 48. "Memory Organization and Permissions" (DS60001214), which is available from the Documentation Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). PIC32MK GPK/MCM with CAN FD Family microcontrollers provide 4 GB of unified virtual memory address space. All memory regions, including program, data memory, Special Function Registers (SFRs) and Configuration registers, reside in this address space at their respective unique addresses. The program and data memories can be optionally partitioned into user and kernel memories. In addition, PIC32MK GPK/MCM with CAN FD Family devices allow execution from data memory. Key features include: - · 32-bit native data width - Separate User (KUSEG) and Kernel (KSEG0/ KSEG1) mode address space - Separate boot Flash memory for protected code - Robust bus exception handling to intercept runaway code - Read/write permission access to predefined memory regions #### 4.1 Memory Layout PIC32MK GPK/MCM with CAN FD Family microcontrollers implement two address schemes: virtual and physical. All hardware resources, such as program memory, data memory and peripherals, are located at their respective physical addresses. Virtual addresses are exclusively used by the CPU to fetch and execute instructions as well as access peripherals. Physical addresses are used by bus initiator peripherals, such as DMA and the Flash controller, that access memory independently of the CPU. The main memory maps for the PIC32MK GPK/MCM with CAN FD Family devices are illustrated in Figure 4-1 through Figure 4-2. Figure 4-1 provides memory map information for boot Flash and boot alias. Table 4-1 provides memory map information for SFRs. FIGURE 4-1: MEMORY MAP FOR DEVICES WITH 512 KB PROGRAM MEMORY AND 128 KB RAM FIGURE 4-2: MEMORY MAP FOR DEVICES WITH 1024 KB PROGRAM MEMORY AND 256 KB RAM # TABLE 4-1: BOOT AND ALIAS MEMORY MAP #### Physical Memory Map(1) - Note 1: Memory areas are not shown to scale. - 2: Memory locations 0x1FC0\_3FB0 through 0x1FC0\_3FFC are used to initialize Configuration registers (see Section 41.0 "Special Features"). - **3:** Refer to Section 4.1.1 "Boot Flash Sequence and Configuration Spaces" for more information. - 4: Memory locations 0x1FC4\_5020 and 0x1FC4\_502C contain a unique device serial number (see Section 41.0 "Special Features"). - 5: This configuration space cannot be used for executing code in the upper boot alias. TABLE 4-2: SFR MEMORY MAP | | Virtual Add | ress | |---------------|--------------|--------------| | Peripheral | Base | Offset Start | | CFG-PMD | | 0x0000 | | CACHE | | 0x0800 | | FC-NVM | | 0x0A00 | | WDT | | 0x0C00 | | DMT | 0xBF800000 | 0x0E00 | | ICD | | 0x1000 | | CRU | | 0x1200 | | PPS | | 0x1400 | | HLVD | | 0x1800 | | EVIC | 0xBF810000 | 0x0000 | | DMA | 0XDI 010000 | 0x1000 | | Timer1-Timer9 | | 0x0000 | | IC1-IC9 | | 0x2000 | | OC1-OC9 | | 0x4000 | | I2C1-I2C2 | | 0x6000 | | SPI1-SPI2 | | 0x7000 | | UART1-UART2 | | 0x8000 | | DATAEE | 0xBF820000 | 0x9000 | | PWM1-PWM12 | | 0xA000 | | QEI1-QEI6 | | 0xB200 | | CMP | | 0xC000 | | CDAC1 | | 0xC200 | | СТМИ | | 0xD000 | | PMP | | 0xE000 | | IC10-IC16 | | 0x3200 | | OC10-OC16 | | 0x5200 | | I2C3-I2C4 | 0xBF840000 | 0x6400 | | SPI3-SPI6 | 0.21 0 10000 | 0x7400 | | UART3-UART6 | | 0x8400 | | CDAC2-CDAC3 | | 0xC400 | | PORTA-PORTG | 0xBF860000 | 0x0000 | | CAN1-CAN4 | | 0x0000 | | ADC | 0xBF880000 | 0x7000 | | USB1-USB2 | | 0x9000 | | RTCC | 0xBF8C0000 | 0x0000 | | SSX CTL | 0xBF8F0000 | 0x0000 | Note 1: Refer to 4.2 "System Bus Arbitration" for important legal information. ## 4.1.1 BOOT FLASH SEQUENCE AND CONFIGURATION SPACES Sequence space is used to identify which boot Flash is aliased by aliased regions. If the value programmed into the TSEQ<15:0> bits of the BF1SEQ word is equal to or greater than the value programmed into the TSEQ<15:0> bits of the BF2SEQ word, Boot Flash 1 is aliased by the lower boot alias region, and Boot Flash 2 is aliased by the upper boot alias region. If the TSEQ<15:0> bits of the BF2SEQ word is greater than the TSEQ<15:0> bits of the BF1SEQ word, the opposite is true (see Table 4-3 and Table 4-4 for BFxSEQ word memory locations). Once boot Flash memories are aliased, configuration space located in the lower boot alias region is used as the basis for the Configuration words, DEVSIGNO, DEVCPO, and DEVCFGx. This means that the boot Flash region to be aliased by lower boot alias region memory must contain configuration values in the appropriate memory locations. **Note:** Use only Quad Word program operation (NVMOP<3:0> = 0010) when programming data into the sequence and configuration spaces. ## 4.1.2 ALTERNATE SEQUENCE AND CONFIGURATION WORDS Every word in the configuration space and sequence space has an associated alternate word (designated by the letter A as the first letter in the name of the word). During device start-up, primary words are read, and if uncorrectable ECC errors are found, the BCFGERR (RCON<27>) flag is set and alternate words are used. If uncorrectable ECC errors are found in primary and alternate words, the BCFGFAIL (RCON<26>) flag is set and the default configuration is used. | ◡ | |---------------| | DS60 | | O | | 0 | | ē | | Ō | | ュ | | S | | $\rightarrow$ | | 9 | | Ш | | | | O | | മ | | 9 | | age | | 75 | | ٠. | | TARI F 1-3. | BOOT FLASH 1 | SECUENCE AND | CONFIGURATION WORDS SUMMARY | |-------------|--------------|--------------|-----------------------------| | IADLE 4-3. | DUUI FLAGR | OEGUENCE AND | CUNFIGURATION WORDS SUMMART | | ess | | | | Bits | | | | | | | | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|----------|-------------|---------------|---------------|------|------|------|------|------|------|-----------| | Virtual Address<br>(BFC4_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | 3F3C | ABF1DEVCFG4 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | xx | | | | | | | | | | | | | | xxxx | | | 3F40 | ABF1DEVCFG3 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F44 | ABF1DEVCFG2 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F48 | ABF1DEVCFG1 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F4C | ABF1DEVCFG0 | 31:16 | | | | | | | Note:Se | e Table 34- | 1 for the bi | it descriptio | ns | | | | | | XXXX | | | | 15:0 | | | | | | | 11010.00 | o labio o l | 1 101 1110 11 | it dooonpac | | | | | | | XXXX | | 3F50 | ABF1DEVCP3 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F54 | ABF1DEVCP2 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F58 | ABF1DEVCP1 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F5C | ABF1DEVCP0 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F70 | ABF1DEVSEQ3 | 31:16 | | | | | | | | CSEQ | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | TSEQ | <15:0> | | | | | | | | xxxx | | 3F74 | ABF1DEVSEQ2 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F78 | ABF1DEVSEQ1 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F7C | ABF1DEVSEQ0 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | x = unknown value on Reset; — = Reserved, read as '1'. Reset values are shown in hexadecimal. Legend: | S | |---------------------| | ğ | | 0 | | 2 | | Ų | | $\overline{\alpha}$ | | $\simeq$ | | 9 | | Ш | | <del>_</del> | | င္က | | Š | | æ | | ٠. | | $\simeq$ | | C | | TABLE 4-3: BOOT FLASH 1 SEQUENCE AND CONFIGURATION WORDS SUMMARY (CONTINU | |---------------------------------------------------------------------------| |---------------------------------------------------------------------------| | ess | | | | Bits | | | | | | | | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|---------|-------------|--------------|--------------|------|------|------|------|------|------|-----------| | Virtual Address<br>(BFC4_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | 3FBC | BF1DEVCFG4 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FC0 | BF1DEVCFG3 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FC4 | BF1DEVCFG2 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FC8 | BF1DEVCFG1 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FCC | BF1DEVCFG0 | 31:16 | | | | | | | Note:Se | e Table 34- | 1 for the bi | t descriptio | ns. | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FD0 | BF1DEVCP3 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FD4 | BF1DEVCP2 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FD8 | BF1DEVCP1 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FDC | BF1DEVCP0 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FF0 | BF1DEVSEQ3 | 31:16 | | | | | | | | CSEQ- | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | TSEQ | <15:0> | | | | | | | | XXXX | | 3FF4 | BF1DEVSEQ2 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FF8 | BF1DEVSEQ1 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FFC | BF1DEVSEQ0 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | x = unknown value on Reset; — = Reserved, read as '1'. Reset values are shown in hexadecimal. Legend: | $\Box$ | J | |------------|---| | Ú | 1 | | | j | | č | ) | | $\sim$ | ) | | č | 2 | | | | | O | 1 | | == | | | <u>u</u> | 2 | | п | 1 | | | Į | | ä | | | -ba | | | :-pag | | | :-page | | | :-page / | | | :-page / / | | | :-page // | | | TABLE 4-4: | BOOT FLASH 2 SEQUENCE AND CONFIGURATION WORDS SUMMARY | |------------|-------------------------------------------------------| |------------|-------------------------------------------------------| | ess ( | | Φ | | | | | | | | Bi | ts | | | | | | | | S | |-----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|----------|------------|--------------|----------------|------|------|------|------|------|------|------------| | Virtual Address<br>(BFC6_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 3F3C | ABF2DEVCFG4 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F40 | ABF2DEVCFG3 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | , | | | | | | | | | | | | | | | | XXXX | | 3F44 | ABF2DEVCFG2 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F48 | ABF2DEVCFG1 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F4C | ABF2DEVCFG0 | 31:16 | | | | | | | Note: Se | e Table 34 | -1 for the b | it description | ons. | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F50 | ABF2DEVCP3 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F54 | ABF2DEVCP2 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F58 | ABF2DEVCP1 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F5C | ABF2DEVCP0 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3F70 | ABF2DEVSEQ3 | 31:16 | | | | | | | | CSEQ. | <15:0> | | | | | | | | XXXX | | | | 15:0 | | | | | | | | TSEQ | <15:0> | | | | | | | | XXXX | | 3F74 | ABF2DEVSEQ2 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F78 | ABF2DEVSEQ1 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3F7C | ABF2DEVSEQ0 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | x = unknown value on Reset; — = Reserved, read as '1'. Reset values are shown in hexadecimal. Legend: | <b>TABLE 4-4</b> : | BOOT FLASH 2 SEQUENCE AND CONFIGURATION WORDS SUMMARY (C | CONTINUED) | |--------------------|----------------------------------------------------------|------------| | | | | | ssa. | | Φ | | Bits | | | | | | | | | | | | | | s | | |-----------------------------|------------------|-----------|-------|--------------|-------|-------|-------|-------|----------|------------|--------------|----------------|-------|------|------|------|------|------|------------| | Virtual Address<br>(BFC6_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 3FBC | BF2DEVCFG4 | 31:16 | | <del>_</del> | | | | | | | | | | | | | | xxxx | | | | | 15:0 | | <u>x</u> | | | | | | | | | | | | | | | xxxx | | 3FC0 | BF2DEVCFG3 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 3FC4 | BF2DEVCFG2 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FC8 | BF2DEVCFG1 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FCC | BF2DEVCFG0 | 31:16 | | | | | | | Note: Se | e Table 34 | 1 for the h | it description | nne | | | | | | XXXX | | | | 15:0 | | | | | | | Note. Se | e lable 04 | T loi tile b | it description | J113. | | | | | | xxxx | | 3FD0 | BF2DEVCP3 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FD4 | BF2DEVCP2 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FD8 | BF2DEVCP1 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FDC | BF2DEVCP0 | 31:16 | | | | | | | | | | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FF0 | BF2DEVSEQ3 | 31:16 | | | | | | | | CSEQ- | <15:0> | | | | | | | | xxxx | | | | 15:0 | | | | | | | | TSEQ | <15:0> | | | | | | | | xxxx | | 3FF4 | BF2DEVSEQ2 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FF8 | BF2DEVSEQ1 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | | 3FFC | BF2DEVSEQ0 | 31:16 | | | | | | | | | | | | | | | | | xxxx | | | | 15:0 | | | | | | | | | | | | | | | | | xxxx | **Legend:** x = unknown value on Reset; — = Reserved, read as '1'. Reset values are shown in hexadecimal. ### REGISTER 4-1: BFxSEQ: BOOT FLASH 'x' SEQUENCE REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | R/P | 31:24 | | • | | CSEQ< | 15:8> | | • | | | 22.46 | R/P | 23:16 | | | | CSEQ< | <7:0> | | | | | 45.0 | R/P | 15:8 | | | | TSEQ< | 15:8> | | | | | 7.0 | R/P | 7:0 | | | | TSEQ< | <7:0> | | | | | Legend: | | P = Programmable bit | | |-------------------|------------------|--------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, r | ead as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 31-16 CSEQ<15:0>: Boot Flash Complement Sequence Number bits bit 15-0 TSEQ<15:0>: Boot Flash True Sequence Number bits ### 4.2 System Bus Arbitration Note: The System Bus interconnect implements one or more instantiations of the SonicsSX<sup>®</sup> interconnect from Sonics, Inc. This document contains materials that are (c) 2003-2015 Sonics, Inc., and that constitute proprietary information of Sonics, Inc. SonicsSX is a registered trademark of Sonics, Inc. All such materials and trademarks are used under license from Sonics, Inc. As shown in the PIC32MK GPK/MCM with CAN FD Family Block Diagram (see Figure 1-1), there are multiple initiator modules (I1 through I13) in the system that can access various target modules (T1 through T14). Table 4-5 illustrates which initiator can access which target. The System Bus supports simultaneous access to targets by initiators, so long as the initiators are accessing different targets. The System Bus will perform arbitration, if multiple initiators attempt to access the same target. TABLE 4-5: INITIATORS TO TARGETS ACCESS ASSOCIATION | Target | Initiator ID: | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|-------------|--------------|-------|-------------|-------------|------|------|------|------|------|------| | # | Name: | CPU<br>IS | CPU<br>ID | DMA<br>Read | DMA<br>Write | Flash | ICD<br>JTAG | ADC<br>Mem. | USB1 | USB2 | CAN1 | CAN2 | CAN3 | CAN4 | | 1 | Program Flash | X | | Х | | | | | | | | | | | | 2 | Data | | Х | | | | | | | | | | | | | 3 | Peripheral Module | | | Х | | | Х | | Х | X | Χ | Х | Х | X | | 4 | RAM Bank 1 | Χ | Х | Х | X | X | Х | X | X | Х | X | Х | Х | Х | | 5 | RAM Bank 2 | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | | 7 | Peripheral Bus 1:<br>DMT, CVR,<br>PPS Input,<br>PPS Output,<br>WDT | | | | | | х | | | | | | | | | 8 | Peripheral Bus 2:<br>Timer1-Timer9,<br>I2C1-I2C2,<br>SPI1-SPI2,<br>UART1-UART2,<br>CDAC1,<br>OC1-OC9,<br>IC1-IC9,<br>PMP,<br>Comparator 1-<br>Comparator 5,<br>Op amp 1-Op amp 4<br>PWM1-PWM12<br>QEI1-QEI6 | | X | X | X | | X | | | | | | | | | 9 | Peripheral Bus 3:<br>IC10-IC16,<br>OC10-OC16,<br>SPI3-SPI6,<br>I2C3-I2C4,<br>UART3-UART6,<br>CDAC2-CDAC3 | | × | × | × | | × | | | | | | | | | 10 | Peripheral Bus 4:<br>PORTA-PORTG | | Х | Х | Х | | Х | | | | | | | | | 11 | Peripheral Bus 5:<br>USB1-USB2,<br>CAN1-CAN4<br>ADC | | Х | | | | Х | | | | | | | | | 14 | Peripheral Bus 6:<br>RTCC | | Х | | | | Х | | | | | | | | The System Bus arbitration scheme implements a non-programmable, Least Recently Serviced (LRS) priority, which provides Quality Of Service (QOS) for most initiators. However, some initiators can use Fixed High Priority (HIGH) arbitration to guarantee their access to data. The arbitration scheme for the available initiators is shown in Table 4-6. TABLE 4-6: INITIATOR ID AND QOS | Name | ID | QOS | |------------------|----|------| | CPU-IS | 1 | LRS | | CPU-DS | 2 | LRS | | DMA Read | 3 | LRS | | DMA Write | 4 | LRS | | Flash Controller | 5 | HIGH | | ICD-JTAG | 6 | LRS | | ADC | 7 | LRS | | USB1 | 8 | LRS | | USB2 | 9 | LRS | | CAN1 | 10 | LRS | | CAN2 | 11 | LRS | | CAN3 | 12 | LRS | | CAN4 | 13 | LRS | ### 4.3 Permission Access and System Bus Registers The System Bus on PIC32MK GPK/MCM with CAN FD Family of microcontrollers provides access control capabilities for the transaction initiators on the System Bus. The System Bus divides the entire memory space into fourteen target regions and permits access to each target by initiators through permission groups. Four Permission Groups (0 through 3) can be assigned to each initiator. Each permission group is independent of the others and can have exclusive or shared access to a region. Using the CFGPG register (see Register 34-9 in 34.0 "Special Features"), Boot firmware can assign a permission group to each initiator, which can make requests on the System Bus. The available targets and their regions, as well as the associated control registers to assign protection, are described and listed in Table 4-7. Register 4-2 through Register 4-10 are used for setting and controlling access permission groups and regions. To change these registers, they must be unlocked in hardware. The register lock is controlled by the PGLOCK Configuration bit (CFGCON<11>). Setting the PGLOCK bit prevents writes to the control registers and clearing the PGLOCK bit allows writes. To set or clear the PGLOCK bit, an unlock sequence must be executed. Refer to **Section 42. "Oscillators with Enhanced PLL"** (DS60001250) in the *"PIC32 Family Reference Manual"* for details. TABLE 4-7: SYSTEM BUS TARGETS AND ASSOCIATED PROTECTION REGISTERS | | | | SBTxF | REGy Regis | ter | | SBTxRD | y Register | SBTxWR | y Register | |------------------|-----------------------------------------|----------|----------|------------------------------|----------------|-------------------|---------|-----------------------------------------------------------------|---------|---------------------------------------------------| | Target<br>Number | Target Description | Name | Region | Physical<br>Start<br>Address | Region<br>Size | Priority<br>Level | Name | Read<br>Permission<br>(Group3,<br>Group2,<br>Group1,<br>Group0) | Name | Write Permission (Group3, Group2, Group1, Group0) | | 0 | System Bus | SBT0REG0 | Region 0 | 1F8F0000 | | 0 | SBT0RD0 | 1,1,1,1 | SBT0WR0 | 1,1,1,1 | | U | System bus | SBT0REG1 | Region 1 | 1F8F8000 | 32 KB | 3 | SBT0RD1 | 0,0,0,1 | SBT0WR1 | 0,0,0,1 | | | | SBT1REG0 | Region 0 | 1D000000 | | 0 | SBT1RD0 | 1,1,1,1 | SBT1WR0 | 0,0,0,0 | | | Flash Memory (CPU Instruction) | SBT1REG2 | Region 2 | 1FC04000 | 4 KB | 2 | SBT1RD2 | 0,0,0,1 | SBT1WR2 | 0,0,0,0 | | 1 | Program Flash | SBT1REG3 | Region 3 | 1FC24000 | 4 KB | 2 | SBT1RD3 | 0,0,0,1 | SBT1WR3 | 0,0,0,0 | | | Boot Flash Prefetch | SBT1REG4 | Region 4 | 1FC44000 | 4 KB | 2 | SBT1RD4 | 0,0,0,1 | SBT1WR4 | 0,0,0,0 | | | | SBT1REG5 | Region 5 | 1FC64000 | 4 KB | 2 | SBT1RD5 | 0,0,0,1 | SBT1WR5 | 0,0,0,0 | | | | SBT2REG0 | Region 0 | 1D000000 | | 0 | SBT2RD0 | 1,1,1,1 | SBT2WR0 | 0,0,0,0 | | | Flash Memory (CPU data) | SBT2REG2 | Region 2 | 1FC04000 | 4 KB | 2 | SBT2RD2 | 0,0,0,1 | SBT2WR2 | 0,0,0,0 | | 2 | Program Flash | SBT2REG3 | Region 3 | 1FC24000 | 4 KB | 2 | SBT2RD3 | 0,0,0,1 | SBT2WR3 | 0,0,0,0 | | | | SBT2REG4 | Region 4 | 1FC44000 | 4 KB | 2 | SBT2RD4 | 0,0,0,1 | SBT2WR4 | 0,0,0,0 | | | | SBT2REG5 | Region 5 | 1FC64000 | 4 KB | 2 | SBT2RD5 | 0,0,0,1 | SBT2WR5 | 0,0,0,0 | | | | SBT3REG0 | Region 0 | 1D000000 | | 0 | SBT3RD0 | 1,1,1,1 | SBT3WR0 | 0,0,0,0 | | | | SBT3REG2 | Region 2 | 1FC04000 | 4 KB | 2 | SBT3RD2 | 0,0,0,1 | SBT3WR2 | 0,0,0,0 | | 3 | Flash Memory (peripheral) Program Flash | SBT3REG3 | Region 3 | 1FC24000 | 4 KB | 2 | SBT3RD3 | 0,0,0,1 | SBT3WR3 | 0,0,0,0 | | | | SBT3REG4 | Region 4 | 1FC44000 | 4 KB | 2 | SBT3RD4 | 0,0,0,1 | SBT3WR4 | 0,0,0,0 | | | | SBT3REG5 | Region 5 | 1FC64000 | 4 KB | 2 | SBT3RD5 | 0,0,0,1 | SBT3WR5 | 0,0,0,0 | Legend: R = Read; R/W = Read/Write; 'x' in a register name = 0-13; 'y' in a register name = 0-8. #### **TABLE 4-8: SYSTEM BUS REGISTER MAP** | SS | | | | | | | | | | | Bits | | | | | | | | | |---------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|-------|-------|-------|-------|---------------| | Virtual Addre<br>(BF8F_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0540 | CDEL AC | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0510 | SBFLAG | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | T3PGV | T2PGV | T1PGV | T0PGV | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Legend: #### **TABLE 4-9: SYSTEM BUS TARGET 0 REGISTER MAP** | SS | | | | | | | | | | | Bits | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|----------|----------|-------|-------|------|----------|-------|----------|------|--------|--------|---------|--------|---------------| | Virtual Address<br>(BF8F_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 8020 | SBT0ELOG1 | 31:16 | MULTI | _ | _ | _ | | CODE | <3:0> | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 0020 | OBTOLLOGT | 15:0 | | | | INI | TID<7:0> | | | | | REGIO | N<3:0> | | _ | С | MD<2:0> | | 0000 | | 8024 | SBT0ELOG2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0024 | SBTULLOGZ | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUI | P<1:0> | 0000 | | 8028 | SBT0ECON | 31:16 | _ | _ | _ | _ | _ | _ | _ | ERRP | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | SBTULCON | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 8030 | SBT0ECLRS | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0030 | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLEAR | 0000 | | 8038 | SBT0ECLRM | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0030 | SBTOLCLIN | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLEAR | 0000 | | 8040 | SBT0REG0 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | | | xxxx | | 0040 | SBTOKEGO | 15:0 | | | BA | ASE<5:0> | | | PRI | _ | | | SIZE<4:0 | > | | _ | _ | _ | xxxx | | 8050 | SBT0RD0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | | _ | | _ | _ | _ | _ | xxxx | | 0030 | SBTONDO | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8058 | SBT0WR0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | | _ | | _ | _ | _ | _ | xxxx | | 0000 | OBTOVINO | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8060 | SBT0REG1 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | | | xxxx | | 0000 | OBTORECT | 15:0 | | | B/ | ASE<5:0> | | | PRI | | | | SIZE<4:0 | > | | _ | _ | | xxxx | | 8070 | 3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | XXXX | | 0070 | SBTONDT | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8078 | 31 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | XXXX | | 0070 | GBTOWICI | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | PIC32MK GPK/MCM with CAN FD Family x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Legend: Note: For reset values listed as 'xxxx', please refer to Table 4-7 for the actual reset values. TABLE 4-10: SYSTEM BUS TARGET 1 REGISTER MAP | ess | | | Bits | | | | | | | | | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|------------|----------|-------|-------|------|----------|-------|----------|------|--------|--------|---------|--------|---------------| | Virtual Address<br>(BF8F_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 8420 | SBT1ELOG1 | 31:16 | MULTI | _ | _ | _ | | CODE | <3:0> | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0420 | SBITELOGI | 15:0 | | | • | INI | ΓID<7:0> | | | | | REGIO | N<3:0> | | _ | С | MD<2:0> | • | 0000 | | 8424 | SBT1ELOG2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0424 | 3BTTLLOG2 | 15:0 | _ | _ | _ | _ | _ | _ | | 1 | - | _ | _ | | _ | _ | GROU | P<1:0> | 0000 | | 8428 | SBT1ECON | 31:16 | _ | _ | _ | _ | _ | _ | _ | ERRP | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0420 | OBTILOON | 15:0 | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 8430 | SBT1ECLRS | 31:16 | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 0400 | OBTILOLINO | 15:0 | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | _ | _ | _ | CLEAR | 0000 | | 8438 | SBT1ECLRM | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0400 | OBTILOLIUM | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLEAR | 0000 | | 8440 | SBT1REG0 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | | | xxxx | | 0440 | OBT INEGO | 15:0 | | | BA | \SE<5:0> | | | PRI | | | | SIZE<4:0 | > | | _ | _ | _ | xxxx | | 8450 | SBT1RD0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 0100 | CBTTINGO | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | ) xxxx | | 8458 | SBT1WR0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 0.00 | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | ) xxxx | | 8480 | SBT1REG2 | 31:16 | | | | | | | 1 | BA | SE<21:6> | | | | | | | | xxxx | | 0.00 | | 15:0 | | | BA | \SE<5:0> | | | PRI | _ | | | SIZE<4:0 | > | | _ | _ | _ | xxxx | | 8490 | SBT1RD2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | XXXX | | 0.00 | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | ) xxxx | | 8498 | SBT1WR2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 0.00 | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | ) xxxx | | 84A0 | SBT1REG3 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | 1 | | | XXXX | | | | 15:0 | | 1 | B/ | ASE<5:0> | 1 | 1 | PRI | | | ı | SIZE<4:0 | > | | _ | _ | | XXXX | | 84B0 | SBT1RD3 | 31:16 | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | | _ | _ | _ | _ | XXXX | | | | 15:0 | _ | _ | _ | _ | _ | | | | _ | _ | _ | | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | | 84B8 | SBT1WR3 | 31:16 | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | | | | _ | | XXXX | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | ) xxxx | | 84C0 | SBT1REG4 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | 1 | | | XXXX | | | | 15:0 | | | | \SE<5:0> | | | PRI | _ | | | SIZE<4:0 | | | _ | _ | | XXXX | | 84D0 | SBT1RD4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | XXXX | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | | | 84D8 | SBT1WR4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | XXXX | | Logon | | 15:0 | _ | _ | _ | ented read | _ | _ | | — | _ | _ | _ | | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. **Note:** For reset values listed as 'xxxx', please refer to Table 4-7 for the actual reset values. ### TABLE 4-10: SYSTEM BUS TARGET 1 REGISTER MAP (CONTINUED) | 388 | | _ | | | | | | | | | Bits | | | | | | | | | |----------------------------|----------|-----------|-------|-------|-------|---------|-------|-------|------|------|----------|------|----------|------|--------|--------|--------|--------|---------------| | Virtual Addres<br>(BF8F_#) | | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 84E0 | SDT1DEC5 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | | | xxxx | | 04EU | SBTIREGS | 15:0 | | | BA | SE<5:0> | | | PRI | _ | | | SIZE<4:0 | > | | _ | _ | _ | xxxx | | 84F0 | SBT1RD5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 04FU | SBLIKDS | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 84F8 | SBT1WR5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 04F0 | SDIIWKS | 15:0 | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note: For reset values listed as 'xxxx', please refer to Table 4-7 for the actual reset values. TABLE 4-11: SYSTEM BUS TARGET 2 REGISTER MAP | SS | LL <del>4</del> -111. | <del> </del> | | <b>D</b> 00 | IAILOLI | | O I LIX II | | | | Bits | | | | | | | | | |-----------------------------|-----------------------|---------------------|-------|-------------|---------|----------|------------|-------|-------|------|----------|----------|----------|------|--------|--------|---------|--------|---------------| | Virtual Address<br>(BF8F_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | | SBT2ELOG1 | 31:16 | MULTI | _ | _ | _ | | CODE | <3:0> | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 8820 | SBIZELUGT | 15:0 | | | | INI | ΓID<7:0> | | | | | REGIO | N<3:0> | | _ | С | MD<2:0> | | 0000 | | 0004 | SBT2ELOG2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 8824 | SB12ELUG2 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROU | P<1:0> | 0000 | | 8828 | SBT2ECON | 31:16 | _ | _ | _ | _ | _ | _ | _ | ERRP | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | SBIZECON | 15:0 | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | 1 | _ | _ | _ | _ | _ | 0000 | | 8830 | SBT2ECLRS | 31:16 | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | 1 | _ | _ | _ | _ | _ | 0000 | | 0030 | 3B12ECLR3 | 15:0 | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | 1 | _ | _ | _ | _ | CLEAR | 0000 | | 8838 | SBT2ECLRM | 31:16 | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | 1 | _ | _ | _ | _ | _ | 0000 | | 0030 | SBIZECENII | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLEAR | 0000 | | 8840 | SBT2REGO | SBT2REG0 31:16 15:0 | | | | | | | | BA | SE<21:6> | | | | | | | | xxxx | | 1 | 15:0 | | | BA | SE<5:0> | | | PRI | _ | | | SIZE<4:0 | > | | _ | _ | _ | xxxx | | | 8850 | 31<br>850 SBT2RD0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 0000 | OBTZNOO | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8858 | SBT2WR0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 0000 | 051211110 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8860 | SBT2REG1 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | | • | xxxx | | 0000 | | 15:0 | | • | BA | \SE<5:0> | | | PRI | _ | | • | SIZE<4:0 | > | • | _ | _ | _ | xxxx | | 8870 | SBT2RD1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | _ | _ | _ | xxxx | | 00.0 | | 15:0 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8878 | SBT2WR1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | _ | _ | _ | XXXX | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8880 | 80 SBT2REG2 31:16 | | | | | | | | ı | BA | SE<21:6> | | | | | ı | ı | ı | xxxx | | | | 15:0 | | 1 | BA | \SE<5:0> | ı | I | PRI | | | ı | SIZE<4:0 | > | 1 | _ | _ | _ | XXXX | | 8890 | SBT2RD2 | 31:16 | _ | _ | _ | | | | _ | | | | | _ | _ | _ | _ | _ | xxxx | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8898 | SBT2WR2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | | xxxx | | | | 15:0 | _ | | _ | _ | _ | _ | _ | — | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note: For reset values listed as 'xxxx', please refer to Table 4-7 for the actual reset values. | DS60 | |------| | 0 | | Õ | | | | ŏ | | ユ | | S | | = | | 9 | | m | | Υ. | | o | | ã | | | | ē | | | | œ | | 7 | | | | | | TABLE 4-12: | SYSTEM BUS | S TARGET 3 | REGISTER MAP | |-------------|------------|------------|--------------| | | | | | | ess | | • | Bits | | | | | | | | | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|----------|----------|-------|-------|------|----------|-------|----------|------|--------|--------|---------|--------|---------------| | Virtual Address<br>(BF8F_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 8C20 | SBT3ELOG1 | 31:16 | MULTI | | _ | _ | | CODE | <3:0> | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | SBISELOGI | 15:0 | | | | INI | ΓID<7:0> | | | | | REGIO | N<3:0> | | _ | С | MD<2:0> | | 0000 | | 8C24 | SBT3ELOG2 | 31:16 | | - | - | _ | _ | | I | I | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0024 | 3B13ELOG2 | 15:0 | | - | - | _ | _ | | I | I | | _ | _ | _ | _ | _ | GROU | P<1:0> | 0000 | | 8C28 | SBT3ECON | 31:16 | | - | - | _ | _ | | I | ERRP | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | SBISECON | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 8C30 | SBT3ECLRS | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0030 | 3B13ECENS | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLEAR | 0000 | | 8C38 | SBT3ECLRM | 31:16 | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | OBTOLOLINI | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLEAR | 0000 | | 8C40 | SBT3REG0 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | | | xxxx | | 0040 | OBTOREGO | 15:0 | | | BA | \SE<5:0> | | | PRI | _ | | | SIZE<4:0 | > | | _ | _ | _ | xxxx | | 8C50 | SBT3RD0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 0000 | 05101150 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8C58 | SBT3WR0 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | | | 15:0 | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | xxxx | | 8C60 | SBT3REG1 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | ı | | xxxx | | | | 15:0 | | | BA | \SE<5:0> | l | | PRI | _ | | ı | SIZE<4:0 | > | ı | _ | _ | _ | xxxx | | 8C70 | SBT3RD1 | 31:16 | _ | _ | | | | | | | | | _ | | _ | _ | _ | _ | xxxx | | | - | 15:0 | _ | | | | | | | | | | _ | | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | | 8C78 | SBT3WR1 | 31:16 | _ | | | | | | | | | | _ | | _ | _ | _ | _ | XXXX | | | - | 15:0 | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | | 8C80 | SBT3REG2 | 31:16 | | | | | | | | BA | SE<21:6> | | | | | | | | XXXX | | | | 15:0 | | | BA | ASE<5:0> | | | PRI | _ | | | SIZE<4:0 | > | | _ | _ | _ | XXXX | | 8C90 | SBT3RD2 | 31:16 | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | XXXX | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | | 8C98 | SBT3WR2 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | | | 15:0 | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | XXXX | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note: For reset values listed as 'xxxx', please refer to Table 4-7 for the actual reset values. #### REGISTER 4-2: SBFLAG: SYSTEM BUS STATUS FLAG REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22,16 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | | 7:0 | _ | _ | _ | _ | T3PGV | T2PGV | T1PGV | T0PGV | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-4 Unimplemented: Read as '0' bit 3-0 T3PGV:T0PGV: Target Permission Group Violation Status bits Refer to Table 4-7 for the list of available targets and their descriptions. 1 = Target is reporting a Permission Group (PG) violation 0 = Target is not reporting a PG violation Note: All errors are cleared at the source (i.e., SBTxELOG1, SBTxELOG2, SBTxECLRS, or SBTxECLRM registers). ## REGISTER 4-3: SBTxELOG1: SYSTEM BUS TARGET 'x' ERROR LOG REGISTER 1 ('x' = 0-3) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R/W-0, C | U-0 | U-0 | U-0 | R/W-0, C | R/W-0, C | R/W-0, C | R/W-0, C | | 31:24 | MULTI | _ | _ | _ | | CODE | <3:0> | | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R-0 | 15:8 | | | | INITIE | )<7:0> | | | | | 7.0 | R-0 | R-0 | R-0 | R-0 | U-0 | R-0 | R-0 | R-0 | | 7:0 | | REGIO | N<3:0> | | | | CMD<2:0> | | Legend: C = Clearable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared ``` bit 31 MULTI: Multiple Permission Violations Status bit ``` This bit is cleared by writing a '1'. - 1 = Multiple errors have been detected - 0 = No multiple errors have been detected - bit 30-28 Unimplemented: Read as '0' - bit 27-24 CODE<3:0>: Error Code bits Indicates the type of error that was detected. These bits are cleared by writing a '1'. 1111 = Reserved 1101 = Reserved : 0011 = Permission violation 0010 = Reserved 0001 = Reserved 0000 **= No error** #### bit 23-16 Unimplemented: Read as '0' bit 15-8 INITID<7:0>: Initiator ID of Requester bits 11111111 = Reserved . 00001111 = Reserved 00001110 = Reserved 00001101 **= CAN4** 00001100 **= CAN3** 00001011 **= CAN2** 00001010 **= CAN1** 00001001 **= USB2** 00001000 = USB1 00000111 = ADC0-ADC5, ADC7 00000110 = Reserved 00000101 = Flash Controller 00000100 **= DMA Read** 00000011 = DMA Read 00000010 = CPU (CPUPRI (CFGCON<24>) = 1) 00000001 = CPU (CPUPRI (CFGCON<25>) = 0) 00000000 = Reserved ## REGISTER 4-3: SBTxELOG1: SYSTEM BUS TARGET 'x' ERROR LOG REGISTER 1 ('x' = 0-3) (CONTINUED) - bit 7-4 **REGION<3:0>:** Requested Region Number bits - 1111 0000 = Target's region that reported a permission group violation - bit 3 **Unimplemented:** Read as '0' - bit 2-0 CMD<2:0>: Transaction Command of the Requester bits - 111 = Reserved - 110 = Reserved - 101 = Write (a non-posted write) - 100 = Reserved - 011 = Read (a locked read caused by a Read-Modify-Write transaction) - 010 = Read - 001 = Write - 000 **= Idle** REGISTER 4-4: SBTxELOG2: SYSTEM BUS TARGET 'x' ERROR LOG REGISTER 2 ('x' = 0-3) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23:10 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | - | - | _ | - | - | - | _ | | 7.0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R-0 | R-0 | | 7:0 | _ | _ | _ | _ | _ | _ | GROUI | P<1:0> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-3 Unimplemented: Read as '0' bit 1-0 GROUP<1:0>: Requested Permissions Group bits 11 = Reserved 10 = Reserved 01 **= Group 1** 00 = Group 0 (default group of CPU at Reset) **Note:** Refer to Table 4-7 for the list of available targets and their descriptions. # REGISTER 4-5: SBTxECON: SYSTEM BUS TARGET 'x' ERROR CONTROL REGISTER ('x' = 0-3) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 R/W-0 | | 31.24 | _ | _ | - | - | _ | _ | _ | ERRP | | 00.40 | U-0 | 23:16 | _ | 1 | 1 | ı | 1 | | 1 | _ | | 45.0 | U-0 | 15:8 | _ | - | - | - | - | _ | - | _ | | 7.0 | U-0 | 7:0 | _ | | | | | _ | | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-25 Unimplemented: Read as '0' bit 24 ERRP: Error Control bit 1 = Report protection group violation errors 0 = Do not report protection group violation errors bit 23-0 Unimplemented: Read as '0' REGISTER 4-6: SBTxECLRS: SYSTEM BUS TARGET 'x' SINGLE ERROR CLEAR REGISTER ('x' = 0-3) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | 1 | _ | - | _ | _ | - | _ | _ | | 00.46 | U-0 | 23:16 | _ | - | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 R-0 | | 7:0 | _ | _ | _ | _ | _ | _ | _ | CLEAR | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-1 Unimplemented: Read as '0' bit 0 CLEAR: Clear Single Error on Read bit A single error as reported through SBTxELOG1 and SBTxELOG2 is cleared by a read of this register. **Note:** Refer to Table 4-7 for the list of available targets and their descriptions. # REGISTER 4-7: SBTxECLRM: SYSTEM BUS TARGET 'x' MULTIPLE ERROR CLEAR REGISTER ('x' = 0-3) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | - | _ | - | _ | - | | 7.0 | U-0 R-0 | | 7:0 | _ | _ | _ | _ | _ | _ | _ | CLEAR | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-1 Unimplemented: Read as '0' bit 0 CLEAR: Clear Multiple Errors on Read bit Multiple errors as reported through SBTxELOG1 and SBTxELOG2 is cleared by a read of this register. **REGISTER 4-8:** SBTxREGy: SYSTEM BUS TARGET 'x' REGION 'y' REGISTER ('x' = 0-3; 'y' = 0-2) | | | , , | | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | 24.24 | R/W0 | R/W-0 | R/W0 | R/W-0 | R/W0 | R/W-0 | R/W0 | R/W-0 | | 31:24 | | | | BASE | <21:14> | • | • | • | | 00:40 | R/W-0 | 23:16 | | | | BASE | E<13:6> | | | | | 45.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0 | U-0 | | 15:8 | | | BAS | E<5:0> | | | PRI | _ | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | | 7:0 | | | SIZE<4:0> | | _ | _ | _ | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-10 BASE<21:0>: Region Base Address bits bit 9 PRI: Region Priority Level bit > 1 = Level 2 0 = Level 1 bit 8 Unimplemented: Read as '0' bit 7-3 SIZE<4:0>: Region Size bits Permissions for a region are only active is the SIZE is non-zero. $11111 = \text{Region size} = 2^{(\text{SIZE} - 1)} \times 1024 \text{ (bytes)}$ 00001 = Region size = $2^{(SIZE - 1)}$ x 1024 (bytes) 00000 = Region is not present bit 2-0 Unimplemented: Read as '0' Note 1: Refer to Table 4-7 for the list of available targets and their descriptions. For some target regions, certain bits in this register are read-only with preset values. See Table 4-7 for more information. REGISTER 4-9: SBTxRDy: SYSTEM BUS TARGET 'x' REGION 'y' READ PERMISSIONS REGISTER ('x' = 0-3; 'y' = 0-2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | | _ | - | _ | _ | - | _ | 1 | | 00.46 | U-0 | 23:16 | _ | | - | - | | - | _ | - | | 45.0 | U-0 | 15:8 | _ | - | - | - | - | - | - | - | | 7.0 | U-0 | U-0 | U-0 | U-0 | R-1 | R-1 | R-1 | R-1 | | 7:0 | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-4 Unimplemented: Read as '0' bit 3 GROUP3: Group 3 Read Permissions bits 1 = Privilege Group 3 has read permission 0 = Privilege Group 3 does not have read permission bit 2 GROUP2: Group 2 Read Permissions bits 1 = Privilege Group 2 has read permission 0 = Privilege Group 2 does not have read permission bit 1 GROUP1: Group 1 Read Permissions bits 1 = Privilege Group 1 has read permission 0 = Privilege Group 1 does not have read permission bit 0 GROUP0: Group 0 Read Permissions bits 1 = Privilege Group 0 has read permission 0 = Privilege Group 0 does not have read permission Note 1: Refer to Table 4-7 for the list of available targets and their descriptions. 2: For some target regions, certain bits in this register are read-only with preset values. See Table 4-7 for more information. REGISTER 4-10: SBTxWRy: SYSTEM BUS TARGET 'x' REGION 'y' WRITE PERMISSIONS REGISTER ('x' = 0-3; 'y' = 0-2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | - | - | - | - | _ | - | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | | 7:0 | _ | _ | _ | _ | GROUP3 | GROUP2 | GROUP1 | GROUP0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-4 Unimplemented: Read as '0' bit 3 **GROUP3:** Group 3 Write Permissions bits 1 = Privilege Group 3 has write permission 0 = Privilege Group 3 does not have write permission bit 2 **GROUP2:** Group 2 Write Permissions bits 1 = Privilege Group 2 has write permission 0 = Privilege Group 2 does not have write permission bit 1 GROUP1: Group 1 Write Permissions bits 1 = Privilege Group 1 has write permission 0 = Privilege Group 1 does not have write permission bit 0 GROUP0: Group 0 Write Permissions bits 1 = Privilege Group 0 has write permission 0 = Privilege Group 0 does not have write permission Note 1: Refer to Table 4-7 for the list of available targets and their descriptions. 2: For some target regions, certain bits in this register are read-only with preset values. See Table 4-7 for more information. #### 5.0 FLASH PROGRAM MEMORY Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 52. "Flash **Program Memory with Support for Live** Update" (DS60001193), which available from the Documentation Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). PIC32MK GPK/MCM with CAN FD Family devices contain an internal Flash program memory for executing user code, which includes the following features: - · Two Flash banks for live update support - Dual boot support - · Write protection for program and boot Flash - · ECC support There are three methods by which the user can program this memory: - Run-Time Self-Programming (RTSP) - · EJTAG Programming - · In-Circuit Serial Programming (ICSP) RTSP is performed by software executing from either Flash or RAM memory. For information about RTSP techniques, refer to **Section 52.** "Flash Program Memory with Support for Live Update" (DS60001193) in the "PIC32 Family Reference Manual". EJTAG is performed using the EJTAG port of the device and an EJTAG capable programmer. ICSP is performed using a serial data connection to the device and allows much faster programming times than RTSP. The EJTAG and ICSP methods are described in the "PIC32 Flash Programming Specification" (DS60001145), which is available for download from the Microchip website. Note: In PIC32MK GPK/MCM with CAN FD Family of devices, the Flash page size is 1024 Instruction Words and the row size is 128 Instruction Words. ### 5.1 Flash Control Registers ### TABLE 5-1: FLASH CONTROLLER REGISTER MAP | ess | _ | o. | | | | | | | | Е | lits | | | | | | | | ø | |-----------------------------|------------------------|---------------|------------|--------|--------|--------|-------|-------|-------|---------------|------------|---------|------|----------|-------|-------|--------|-------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 000 | NVMCON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0/100 | | 15:0 | WR | WREN | WRERR | LVDERR | _ | _ | _ | _ | PFSWAP | BFSWAP | _ | _ | | NVMO | P<3:0> | | 0000 | | 0A10 | NVMKEY | 31:16 | | | | | | | | NVMKE | Y<31:0> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | | | | | | | | | | 0000 | | 0A20 | NVMADDR <sup>(1)</sup> | 31:16<br>15:0 | | | | | | | | NVMAD | DR<31:0> | | | | | | | | 0000 | | | | 31:16 | | | | | | | | | | | | | | | | | 0000 | | 0A30 | NVMDATA0 | 15:0 | | | | | | | | NVMDA | ΓA0<31:0> | | | | | | | | 0000 | | 04.40 | NI) (MAD ATA 4 | 31:16 | | | | | | | | ND (1) 41 D A | FA4 :04 0: | | | | | | | | 0000 | | 0A40 | NVMDATA1 | 15:0 | | | | | | | | NVMDA | ΓA1<31:0> | | | | | | | | 0000 | | 0A50 | NVMDATA2 | 31:16 | | | | | | | | NVMDA | ΓA2<31:0> | | | | | | | | 0000 | | 07.00 | | 15:0 | | | | | | | | | | | | | | | | | 0000 | | 0A60 | NVMDATA3 | 31:16 | | | | | | | | NVMDA | ΓA3<31:0> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | | | | | | | | | | 0000 | | 0A70 | NVMSRC<br>ADDR | 31:16<br>15:0 | | | | | | | | NVMSRCA | ADDR<31:0> | | | | | | | | 0000 | | | | 31:16 | PWPULOCK | | _ | _ | | _ | | _ | | | | PWP<2 | 3:16> | | | | 8000 | | 0A80 | NVMPWP <sup>(1)</sup> | 15:0 | I WI OLOOK | | | | | | | | <15:0> | | | 1 771 32 | 0.10- | | | | 0000 | | | 40 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0A90 | NVMBWP <sup>(1)</sup> | | LBWPULOCK | | _ | LBWP4 | LBWP3 | LBWP2 | LBWP1 | LBWP0 | UBWPULOCK | | _ | UBWP4 | UBWP3 | UBWP2 | UBWP1 | UBWP0 | 9FDF | | | (4) | 31:16 | | ERSCNT | <3:0> | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 001F | | 0AA0 | NVMCON2 <sup>(1)</sup> | 15:0 | | _ | CREAD1 | VREAD1 | _ | _ | ERETR | Y<1:0> | SWAPLOG | CK<1:0> | _ | _ | _ | _ | _ | _ | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:This register has corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. #### REGISTER 5-1: NVMCON: PROGRAMMING CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-----------------------|-------------------------|----------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | - | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | - | _ | _ | - | | 45.0 | R/W-0, HC | R/W-0 | R-0, HS, HC | R-0, HS, HC | U-0 | U-0 | U-0 | U-0 | | 15:8 | WR <sup>(1)</sup> | WREN <sup>(1)</sup> | WRERR <sup>(1)</sup> | LVDERR(1) | | _ | _ | _ | | 7.0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | PFSWAP <sup>(2)</sup> | BFSWAP <sup>(2,3)</sup> | _ | _ | | NVMOF | o<3:0> | | **Legend:** HS = Hardware Set HC = Hardware Cleared R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-16 Unimplemented: Read as '0' bit 15 WR: Write Control bit (1) This bit cannot be cleared and can be set only when WREN = 1 and the unlock sequence has been performed. - 1 = Initiate a Flash operation - 0 = Flash operation is complete or inactive - bit 14 WREN: Write Enable bit<sup>(1)</sup> - 1 = Enable writes to the WR bit and disables writes to the NVMOP<3:0> bits - 0 = Disable writes to WR bit and enables writes to the NVMOP<3:0> bits - bit 13 **WRERR:** Write Error bit<sup>(1)</sup> This bit can be cleared only by setting the NVMOP<3:0> bits = 0000 and initiating a Flash operation. - 1 = Program or erase sequence did not complete successfully - 0 = Program or erase sequence completed normally - bit 12 LVDERR: Low-Voltage Detect Error bit<sup>(1)</sup> This bit can be cleared only by setting the NVMOP<3:0> bits = 0000 and initiating a Flash operation. - 1 = Low-voltage detected (possible data corruption, if WRERR is set) - 0 = Voltage level is acceptable for programming - bit 11-8 Unimplemented: Read as '0' - bit 7 **PFSWAP:** Program Flash Bank Swap Control bit<sup>(2)</sup> - 1 = Program Flash Bank 2 is mapped to the lower mapped region and Program Flash Bank 1 is mapped to the upper mapped region - 0 = Program Flash Bank 1 is mapped to the lower mapped region and Program Flash Bank 2 is mapped to the upper mapped region - Note 1: These bits are only reset by a Power-on Reset (POR) and are not affected by other reset sources. - 2: This bit can only be modified when the WREN bit = 0, the NVMKEY unlock sequence is satisfied, and the SWAPLOCK<1:0> bits (NVMCON2<7:6>) are cleared to '0'. - **3:** The BFSWAP value is determined by the values of the user-programmed Sequence Numbers in each boot panel. - 4: This operation results in a "No Operation" (NOP) when the Dynamic Flash ECC Configuration bits = 00 (FECCCON<1:0> (DVCFG0<9:8>)), which enables ECC at all times. For all other FECCCON<1:0> bit settings, this command will execute, but will not write the ECC bits for the word and can cause DED errors if dynamic Flash ECC is enabled (FECCCON<1:0> = 01). Refer to Section 52. "Flash Program Memory with Support for Live Update" (DS60001193) for information regarding ECC and Flash programming. ### REGISTER 5-1: NVMCON: PROGRAMMING CONTROL REGISTER (CONTINUED) - bit 6 **BFSWAP:** Boot Flash Bank Swap Control bit<sup>(2,3)</sup> - 1 = Boot Flash Bank 2 is mapped to the lower boot region and program Boot Flash Bank 1 is mapped to the upper boot region - 0 = Boot Flash Bank 1 is mapped to the lower boot region and program Boot Flash Bank 2 is mapped to the upper boot region - bit 5-4 Unimplemented: Read as '0' - bit 3-0 NVMOP<3:0>: NVM Operation bits These bits are only writable when WREN = 0. 1111 = Reserved • 1000 = Reserved - 0111 = Program erase operation: erase all of program Flash memory (all pages must be unprotected, PWP<23:0> = 0x000000) - 0110 = Upper program Flash memory erase operation: erases only the upper mapped region of program Flash (all pages in that region must be unprotected) - 0101 = Lower program Flash memory erase operation: erases only the lower mapped region of program Flash (all pages in that region must be unprotected) - 0100 = Page erase operation: erases page selected by NVMADDR, if it is not write-protected - 0011 = Row program operation: programs row selected by NVMADDR, if it is not write-protected - 0010 = Quad Word (128-bit) program operation: programs the 128-bit Flash word selected by NVMADDR, if it is not write-protected - 0001 = Word program operation: programs word selected by NVMADDR, if it is not write-protected<sup>(4)</sup> - 0000 = No operation - Note 1: These bits are only reset by a Power-on Reset (POR) and are not affected by other reset sources. - 2: This bit can only be modified when the WREN bit = 0, the NVMKEY unlock sequence is satisfied, and the SWAPLOCK<1:0> bits (NVMCON2<7:6>) are cleared to '0'. - **3:** The BFSWAP value is determined by the values of the user-programmed Sequence Numbers in each boot panel. - 4: This operation results in a "No Operation" (NOP) when the Dynamic Flash ECC Configuration bits = 00 (FECCCON<1:0> (DVCFG0<9:8>)), which enables ECC at all times. For all other FECCCON<1:0> bit settings, this command will execute, but will not write the ECC bits for the word and can cause DED errors if dynamic Flash ECC is enabled (FECCCON<1:0> = 01). Refer to Section 52. "Flash Program Memory with Support for Live Update" (DS60001193) for information regarding ECC and Flash programming. #### REGISTER 5-2: NVMKEY: PROGRAMMING UNLOCK REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | | | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | | |--------------|-------------------|-------------------|-----|------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--|--| | 24.24 | W-0 | | | | | | | | 31:24 | | NVMKEY<31:24> | | | | | | | | | | | | | | | 22.40 | W-0 | | | | | | | | 23:16 | NVMKEY<23:16> | | | | | | | | | | | | | | | | 45.0 | W-0 | | | | | | | | 15:8 | NVMKEY<15:8> | | | | | | | | | | | | | | | | 7.0 | W-0 | | | | | | | | 7:0 | | | | NVMK | EY<7:0> | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 NVMKEY<31:0>: Unlock Register bits These bits are write-only, and read as '0' on any read Note: This register is used as part of the unlock sequence to prevent inadvertent writes to the PFM. ### REGISTER 5-3: NVMADDR: FLASH ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------------------|-------------------|-------------------|-------------------|------------------------|-------------------|------------------|------------------|--|--|--|--|--|--| | 24.04 | R/W-0 | | | | | | | 31:24 | NVMADDR<31:24> <sup>(1)</sup> | | | | | | | | | | | | | | | 00:40 | R/W-0 | | | | | | | 23:16 | NVMADDR<23:16> <sup>(1)</sup> | | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | 15:8 | NVMADDR<15:8> <sup>(1)</sup> | | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | | 7:0 | | | | NVMADI | OR<7:0> <sup>(1)</sup> | | | | | | | | | | Legend: -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-0 NVMADDR<31:0>: Flash Address bits<sup>(1)</sup> | NVMOP<3:0><br>Selection | Flash Address Bits (NVMADDR<31:0>) | |-------------------------|----------------------------------------------------------------------------------------| | Page Erase | Address identifies the page to erase (NVMADDR<11:0> are ignored). | | Row Program | Address identifies the row to program (NVMADDR<8:0> are ignored). | | Word Program | Address identifies the word to program (NVMADDR<1:0> are ignored). | | Quad Word Program | Address identifies the quad word (128-bit) to program (NVMADDR<3:0> bits are ignored). | **Note 1:** For all other NVMOP<3:0> bit settings, the Flash address is ignored. See the NVMCON register (Register 5-1) for additional information on these bits. **Note:** The bits in this register are only reset by a POR and are not affected by other reset sources. ### REGISTER 5-4: NVMDATAX: FLASH DATA REGISTER (x = 0-3) | Bit<br>Range | Bit<br>31/23/15/7 | | | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|-------|-------|--------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 24.24 | R/W-0 | | | | | | 31:24 | | | | NVMDA <sup>*</sup> | TA<31:24> | | | | | | | | | | 00:40 | R/W-0 | | | | | | 23:16 | NVMDATA<23:16> | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | 15:8 | NVMDATA<15:8> | | | | | | | | | | | | | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 R/W-0 | | R/W-0 | R/W-0 | | | | | | | 7:0 | | | | NVMD | ATA<7:0> | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 NVMDATA<31:0>: Flash Data bits Word Program: Writes NVMDATA0 to the target Flash address defined in NVMADDR Quad Word Program: Writes NVMDATA3:NVMDATA2:NVMDATA1:NVMDATA0 to the target Flash address defined in NVMADDR. NVMDATA0 contains the Least Significant Instruction Word. Note: The bits in this register are only reset by a POR and are not affected by other reset sources. #### REGISTER 5-5: NVMSRCADDR: SOURCE DATA ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | 15/7 30/22/14/6 29/21/13/5 | | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------|----------------------------|-------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--| | 24.04 | R/W-0 | | | | | | | 31:24 | | | | NVMSRCA | DDR<31:24> | > | | | | | | | | | | 00:40 | R/W-0 | | | | | | | 23:16 | NVMSRCADDR<23:16> | | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | 15:8 | NVMSRCADDR<15:8> | | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | | 7:0 | | | | NVMSRC | ADDR<7:0> | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 NVMSRCADDR<31:0>: Source Data Address bits The system physical address of the data to be programmed into the Flash when the NVMOP<3:0> bits (NVMCON<3:0>) are set to perform row programming. Note: The bits in this register are only reset by a POR and are not affected by other reset sources. #### REGISTER 5-6: NVMPWP: PROGRAM FLASH WRITE-PROTECT REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 24.24 | R/W-1 | U-0 | | | | | | 31:24 | PWPULOCK | _ | - | _ | _ | _ | _ | _ | | | | | | | 00.46 | R/W-0 | | | | | | 23:16 | PWP<23:16> | | | | | | | | | | | | | | 45.0 | R/W-0 | R/W-0 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | | | | | | 15:8 | PWP<15:8> | | | | | | | | | | | | | | 7.0 | R-0 | | | | | | 7:0 | | · | · | PWP< | 7:0> | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 PWPULOCK: Program Flash Memory Page Write-protect Unlock bit 1 = Register is not locked and can be modified 0 = Register is locked and cannot be modified This bit is only clearable and cannot be set except by any reset. bit 30-24 Unimplemented: Read as '0' bit 23-0 **PWP<23:0>:** Flash Program Write-protect (Page) Address bits Physical memory below address 0x1Dxxxxxx is write protected, where 'xxxxxx' is specified by PWP<23:0>. When PWP<23:0> has a value of '0', write protection is disabled for the entire program Flash. If the specified address falls within the page, the entire page and all pages below the current page will be protected. Note: The bits in this register are only writable when the NVMKEY unlock sequence is followed. ### REGISTER 5-7: NVMBWP: FLASH BOOT (PAGE) WRITE-PROTECT REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | 15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 | | | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|--------------------------------------------------|-----|----------------------|----------------------|----------------------|----------------------|----------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | _ | | - | _ | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | | | - | _ | | 45.0 | R/W-1 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | | 15:8 | LBWPULOCK | _ | _ | LBWP4 <sup>(1)</sup> | LBWP3 <sup>(1)</sup> | LBWP2 <sup>(1)</sup> | LBWP1 <sup>(1)</sup> | LBWP0 <sup>(1)</sup> | | 7.0 | R/W-1 | r-1 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | | 7:0 | UBWPULOCK | | _ | UBWP4 <sup>(1)</sup> | UBWP3 <sup>(1)</sup> | UBWP2 <sup>(1)</sup> | UBWP1 <sup>(1)</sup> | UBWP0 <sup>(1)</sup> | **Legend:** r = Reserved R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 **LBWPULOCK:** Lower Boot Alias Write-protect Unlock bit 1 = LBWPx bits are not locked and can be modified 0 = LBWPx bits are locked and cannot be modified This bit is only clearable and cannot be set except by any reset. bit 14-13 Unimplemented: Read as '0' bit 12 **LBWP4:** Lower Boot Alias Page 4 Write-protect bit<sup>(1)</sup> 1 = Write protection for physical address 0x01FC10000 through 0x1FC13FFF enabled 0 = Write protection for physical address 0x01FC10000 through 0x1FC13FFF disabled bit 11 LBWP3: Lower Boot Alias Page 3 Write-protect bit<sup>(1)</sup> 1 = Write protection for physical address 0x01FC0C000 through 0x1FC0FFFF enabled 0 = Write protection for physical address 0x01FC0C000 through 0x1FC0FFFF disabled bit 10 **LBWP2:** Lower Boot Alias Page 2 Write-protect bit<sup>(1)</sup> 1 = Write protection for physical address 0x01FC08000 through 0x1FC0BFFF enabled 0 = Write protection for physical address 0x01FC08000 through 0x1FC0BFFF disabled bit 9 **LBWP1:** Lower Boot Alias Page 1 Write-protect bit<sup>(1)</sup> 1 = Write protection for physical address 0x01FC04000 through 0x1FC07FFF enabled 0 = Write protection for physical address 0x01FC04000 through 0x1FC07FFF disabled bit 8 **LBWP0:** Lower Boot Alias Page 0 Write-protect bit<sup>(1)</sup> 1 = Write protection for physical address 0x01FC00000 through 0x1FC03FFF enabled 0 = Write protection for physical address 0x01FC00000 through 0x1FC03FFF disabled bit 7 UBWPULOCK: Upper Boot Alias Write-protect Unlock bit 1 = UBWPx bits are not locked and can be modified 0 = UBWPx bits are locked and cannot be modified This bit is only user-clearable and cannot be set except by any reset. bit 6 Reserved: This bit is reserved for use by development tools bit 5 Unimplemented: Read as '0' **Note 1:** These bits are only available when the NVMKEY unlock sequence is performed and the associated Lock bit (LBWPULOCK or UBWPULOCK) is set. Note: The bits in this register are only writable when the NVMKEY unlock sequence is followed. #### REGISTER 5-7: NVMBWP: FLASH BOOT (PAGE) WRITE-PROTECT REGISTER - bit 4 **UBWP4**: Upper Boot Alias Page 4 Write-protect bit<sup>(1)</sup> - 1 = Write protection for physical address 0x01FC30000 through 0x1FC33FFF enabled - 0 = Write protection for physical address 0x01FC30000 through 0x1FC33FFF disabled - bit 3 **UBWP3:** Upper Boot Alias Page 3 Write-protect bit<sup>(1)</sup> - 1 = Write protection for physical address 0x01FC2C000 through 0x1FC2FFFF enabled - 0 = Write protection for physical address 0x01FC2C000 through 0x1FC2FFFF disabled - bit 2 **UBWP2:** Upper Boot Alias Page 2 Write-protect bit<sup>(1)</sup> - 1 = Write protection for physical address 0x01FC28000 through 0x1FC2BFFF enabled - 0 = Write protection for physical address 0x01FC28000 through 0x1FC2BFFF disabled - bit 1 **UBWP1:** Upper Boot Alias Page 1 Write-protect bit<sup>(1)</sup> - 1 = Write protection for physical address 0x01FC24000 through 0x1FC27FFF enabled - 0 = Write protection for physical address 0x01FC24000 through 0x1FC27FFF disabled - bit 0 **UBWP0:** Upper Boot Alias Page 0 Write-protect bit<sup>(1)</sup> - 1 = Write protection for physical address 0x01FC20000 through 0x1FC23FFF enabled - 0 = Write protection for physical address 0x01FC20000 through 0x1FC23FFF disabled - **Note 1:** These bits are only available when the NVMKEY unlock sequence is performed and the associated Lock bit (LBWPULOCK or UBWPULOCK) is set. Note: The bits in this register are only writable when the NVMKEY unlock sequence is followed. #### REGISTER 5-8: NVMCON2: FLASH PROGRAMMING CONTROL REGISTER 2 | Bit<br>Range | | | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|--------|---------|-----------------------|-----------------------|-------------------|------------------|------------------|---------| | 24.24 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | | 31:24 | | ERSCN | IT<3:0> | | _ | | _ | _ | | 00:40 | U-0 | U-0 | U-0 | r-1 | r-1 | r-1 | r-1 | r-1 | | 23:16 | _ | _ | _ | (Reser | ved, the user | must write a '1 | to these loc | ations) | | 45.0 | r-1 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | _ | _ | CREAD1 <sup>(1)</sup> | VREAD1 <sup>(1)</sup> | _ | _ | ERETR | Y<1:0> | | 7.0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 7:0 | SWAPLC | CK<1:0> | _ | _ | _ | _ | _ | _ | **Legend:** r = Reserved R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-28 ERSCNT<1:0>: Erase Retry State Count bits These bits can be used by software to track the erase retry state count in the event of a Master Clear or BOR. These bits are for software tracking and are not used by hardware. - bit 27-21 Unimplemented: Read as '0' - bit 20-16 Reserved: The user must always write a '1' to these bits - bit 15-14 Unimplemented: Read as '0' - bit 13 CREAD1: Compare Read of Logic 1 bit<sup>(1)</sup> - 1 = Compare Read is enabled (only if VERIFYREAD1 = 1) - 0 = Compare Read is disabled Compare Read 1 causes all bits in a Flash Word to be evaluated during the read. If all bits are '1', the lowest Word in the Flash Word evaluates to 0x00000001, all other words are 0x00010000. If any bit is '0', the read evaluates to 0x00000000 for all Words in the Flash Word. - bit 12 **VREAD1:** Verify Read of Logic 1 Control bit<sup>(1)</sup> - 1 = Selects Erase Retry Procedure with Verify Read - 0 = Selects Single Erase w/o Verify Read - bit 11-10 Unimplemented: Read as '0' - bit 9-8 **ERETRY<1:0>:** Erase Retry Control bits - 11 = Erase strength for last retry cycle - 10 = Erase strength for third retry cycle - 01 = Erase strength for second retry cycle - 00 = Erase strength for first retry cycle The user application should start with '00' (first retry cycle) and move on to higher strength if the programming does not complete. This bit is used only when VREAD1 = 1 and when VREAD1 = 1. - bit 7-6 **SWAPLOCK<1:0>:** Flash Memory Swap Lock Control bits - 11 = PFSWAP and BFSWAP are not writable and SWAPLOCK is not writable - 10 = PFSWAP and BFSWAP are not writable and SWAPLOCK is writable - 01 = PFSWAP and BFSWAP are not writable and SWAPLOCK is writable - 00 = PFSWAP and BFSWAP are writable and SWAPLOCK is writable - bit 5-0 **Unimplemented:** Read as '0' - Note 1: This bit can only be modified when the WREN bit = 0, and the NVMKEY unlock sequence is satisfied. | NOTES: | | <br> | | |--------|--|------|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 6.0 DATA EEPROM Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to 58. "Data Section EEPROM" (DS60001341), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The Data EEPROM module provides the following features: - 1K x 32-bit (4K x 8-bit) Emulated Data EEPROM using the 1K x 16 x 33-bit (66 KB) - · Register-based indirect access - Register-based, non-memory mapped, SFR Program/Erase/Read interface - · Read: - Byte or Word read - Read start Control bit and read complete status flag - Read complete interrupt - · Program/Erase: - No user erase required prior to program - Hardware Word program verify - Automatic page erase as part of wear-leveling scheme - Hardware page erase verify - Bulk and page erase - Write complete and error interrupts - · Brown-out protection for all commands - Concurrent Data EEPROM read with Program Flash read/write - · Endurance: - 160K program cycles per address location - Transparent wear-leveling scheme - No software overhead - Automatic page erase (once every 17 program write operations) - "Worn out" page detection and error flag - "Imminent Page Erase" prediction status flag to allow user to schedule wear leveling page erasure - Low-power features: - Always in stand-by unless accessed - Power down in Sleep and/or Idle mode - Independent Data EEPROM Flash power down in Idle Control bit #### 6.1 Data EEPROM Flash Table 6-1 provides the status of the data EEPROM Flash. TABLE 6-1: DATA EEPROM FLASH | Data EE Wait Status<br>EEWS<7:0> bits<br>(CFGCON2<7:0>) = | PBCLK (FSYSCLK /<br>PBDIV<6:0> bits<br>(PB2DIV<6:0>)) | |-----------------------------------------------------------|-------------------------------------------------------| | 0 | 0-39 MHz | | 1 | 40-59 MHz | | 2 | 60-79 MHz | | 3 | 80-97 MHz | | 4 | 98-117 MHz | | 5 | 118-120 MHz | - ote 1: The Data EEPROM Flash must have its calibration trim bits reinitialized after each cold power-up before any attempted accesses. Refer to Section 58. "Data EEPROM" (DS60001341) of the "PIC32 Family Reference Manual" for additional information. - 2: Before any attempts to access the Data EEPROM module, the user application must configure the appropriate number of Wait states by configuring the EEWS<7:0> bits (CFGCON2< 7:0>) according to Table 6-1. ### 6.2 Control Registers ### TABLE 6-2: DATA EEPROM SFR SUMMARY | ess | | | | Bits | | | | | | | | | | | | | s | | | |-----------------------------|-----------------------|-----------|---------------|-------|-------|-------|-------------------|-------|------|----------|------|------|------|-------|------|------|----------|------|-----------| | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | 9000 | EECON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | ON | RDY | SIDL | ABORT | _ | _ | _ | _ | RW | WREN | ERR | <1:0> | ILW | | CMD<2:0> | | 0000 | | 9010 | EEKEY <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | EEKEY<1 | 5:0> | | | | | | | | 0000 | | 9020 | EEADDR <sup>(3)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | EEADDR<11:0> 0000 | | | | | | | | | | 0000 | | | | 9030 | EEDATA | 31:16 | EEDATA<31:16> | | | | | | | | | | | 0000 | | | | | | | | | 15:0 | | | | | | | E | EEDATA<1 | 5:0> | | | | | | | | 0000 | **Legend:** — = unimplemented, read as '0'. Note 1: This register has corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PIC32MK GPK/MCM with CAN FD Family 2: This register is a write-only register. Reads always result in '0'. 3: Because the EEPROM word size is 32 bits, for reads and writes the last two bits (EEADDR<1:0>) must always be '0'. #### REGISTER 6-1: EECON: EEPROM CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|---------------------|-------------------|-------------------|-------------------|-------------------------|------------------|------------------|--| | 24.24 | U-0 | | 31:24 | _ | _ | _ | _ | | _ | _ | _ | | | 00.40 | U-0 | | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | 45.0 | R/W-0, HC | R-0 | R/W-0 | R/W-0, HC | U-0 | U-0 | U-0 | U-0 | | | 15:8 | ON | RDY | SIDL | ABORT | _ | _ | _ | _ | | | 7.0 | R/W-0, HC | R/W-0 | R/W-0, HS, HC | R/W-0, HS, HC | R/W-0, HS | R/W-0 | R/W-0 | R/W-0 | | | 7:0 | RW | WREN <sup>(1)</sup> | ERR• | <1:0> | ILW | CMD<2:0> <sup>(1)</sup> | | | | Legend:HS = Hardware settableHC = Hardware clearableR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is cleared bit 31-16 Unimplemented: Read as '0' bit 15 ON: Data EEPROM Power Control bit 1 = Data EEPROM is enabled 0 = Data EEPROM is disabled Attempting to clear this bit will have no effect if the RW bit is set. In addition, this bit is not cleared during Sleep if the FSLEEP bit in the DEVCFG register is set. bit 14 RDY: Data EEPROM Ready bit 1 = Data EEPROM is ready for access 0 = Data EEPROM is not ready for access RDY is cleared by hardware whenever a POR or BOR event occurs. It is set by hardware when the ON bit = 1 and the power-up timer has expired. bit 13 SIDL: Stop in Idle Mode bit 1 = Discontinue operation when CPU enters in Idle mode 0 = Continue operation in Idle mode bit 12 ABORT: Data EEPROM Abort Operation Control bit 1 = Set by software to abort the on-going write command as soon as possible 0 = Data EEPROM panel is ready/Normal operation bit 11-8 Unimplemented: Read as '0' bit 7 RW: Start Command Execution Control bit When WREN = 1: 1 = Start memory word program or erase command 0 = Cleared by hardware to indicate program or erase operation has completed When WREN = 0: 1 = Start memory word read command 0 = Cleared by hardware to indicate read operation has completed This bit cannot be set if the ON bit = 0, or if the ON bit = 1 and the power-up timer has not yet expired (i.e., EECON<RDY>=0). A BOR reset will indirectly clear this bit by forcing any executing command to terminate and to clear RW afterwards. bit 6 **WREN:** Data EEPROM Write Enable Control bit<sup>(1)</sup> 1 = Enables program or erase operations 0 = Disables program or erase of memory elements, and enables read operations **Note 1:** This bit (or bits) cannot be modified when the RW bit = 1. 2: The Configuration Write command (CMD<2:0> = 100) must be executed after any power-up before the Data EEPROM is ready for use. Refer to **Example 58-1**: "Data EEPROM Initialization Code" in Section 58. "Data EEPROM" (DS60001341) for details. ### REGISTER 6-1: EECON: EEPROM CONTROL REGISTER (CONTINUED) - bit 5-4 ERR<1:0>: Data EEPROM Sequence Error Status bits - 11 = A BOR event has occurred - 10 = An attempted execution of a read or write operation with an invalid write OR command with a misaligned address (EEADDR<1:0> ≠ 00) - 01 = A Bulk or Page Erase or a Word Program verify error has occurred - 0.0 = No error condition These bits can be cleared by software, or as the result of the successful execution of the next operation, or when the ON bit = 0. These bits may also be set by software (when the RW bit = 0) without affecting the operation of the module. - bit 3 ILW: Data EEPROM Imminent Long Write Status bit - 1 = The next write to the EEPROM address (held in the EEADDR register) will require more time (~ 20 ms) than usual - 0 = The next write to the EEPROM address (held in the EEADDR register) will be a normal write cycle This bit can be cleared by software, or as the result of a write to the EEADDR register. This bit is set by hardware after a write command. bit 2-0 CMD<2:0>: Data EEPROM Command Selection bits(1) These bits are cleared only on a POR event. - 111 = Reserved - ٠ - • - . - 100 = Configuration register Write command (WREN bit must be set)<sup>(2)</sup> - 011 = Data EEPROM memory Bulk Erase command (WREN bit must be set) - 010 = Data EEPROM memory Page Erase command (WREN bit must be set) - 001 = Word Write command (WREN bit must be set) - 000 = Word Read command (WREN bit must be clear) - **Note 1:** This bit (or bits) cannot be modified when the RW bit = 1. - 2: The Configuration Write command (CMD<2:0> = 100) must be executed after any power-up before the Data EEPROM is ready for use. Refer to **Example 58-1: "Data EEPROM Initialization Code"** in **Section 58. "Data EEPROM"** (DS60001341) for details. #### REGISTER 6-2: EEKEY: EEPROM KEY REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--| | 24.24 | U-0 | | | | | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | 23:16 | U-0 | | | | | 23.10 | _ | _ | - | _ | _ | _ | | _ | | | | | | 45.0 | W-0 | | | | | 15:8 | EEKEY<15:8> | | | | | | | | | | | | | 7.0 | W-0 | | | | | 7:0 | | | | EEKE' | Y<7:0> | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-16 Unimplemented: Read as '0' bit 15-0 **EEKEY<15:0>:** Data EEPROM Key bits Writing the value 0xEDB7 followed by writing the value 0x1248 to this register will unlock the EECON register for write/erase operations. Reads have no effect on this register and return '0'. Writing any other value will lock the EECON register. #### REGISTER 6-3: EEADDR: EEPROM ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|----------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 24.24 | U-0 | | | | 31:24 | _ | _ | - | _ | _ | - | | | | | | | 00.40 | U-0 | | | | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 45.0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 15:8 | _ | _ | _ | _ | EEADDR<11:8>(1,2) | | | | | | | | 7:0 | R/W-0 | | | | 7:0 | EEADDR<7:0> <sup>(1)</sup> | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-12 Unimplemented: Read as '0' bit 11-0 **EEADR<11:0>:** Data EEPROM Address bits<sup>(1)</sup> This register holds the address in the EEPROM memory upon which to operate. EEADDR<1:0> must always be '00' when the RW bit (EECON<7>) is set or an error will occur. Note 1: The bits in this register cannot be modified when the RW bit (EECON<7>) = 1. 2: EEDATA is organized in 32-bit words, not by byte, hence the EEADDR bit must always be 32-bit word address aligned. Check that the EEADDR<1:0> bits are = 0'b00 at the beginning of any command when the user sets EEGO to '1'. If the EEADDR<1:0> bits are not 0'b00, it will forcefully clear the EEGO bit to '0' and will also set the ERR<1:0> bits (EECON<5:4>) to 0'b10. #### REGISTER 6-4: EEDATA: EEPROM DATA REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|------------------------------|-------------------|-------------------|-------------------|-----------------------|-------------------|------------------|------------------|--|--|--|--|--| | 24.24 | R/W-0 | | | | | | 31:24 | EEDATA<31:24>(1) | | | | | | | | | | | | | | 00:40 | R/W-0 | | | | | | 23:16 | EEDATA<23:16> <sup>(1)</sup> | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | 15:8 | EEDATA<15:8> <sup>(1)</sup> | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | 7:0 | | _ | | EEDATA | \<7:0> <sup>(1)</sup> | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared ### bit 31-0 **EEDATA<31:0>:** Data EEPROM Data bits<sup>(1)</sup> This register holds the data in the EEPROM memory to store during write operations, or the data from memory after a read operation. **Note 1:** These bits cannot be modified when the RW bit (EECON<7>) = 1. In addition, reading this register, when the RW bit = 1 may not return valid data, as the read operation may not have completed. ### 7.0 RESETS Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 7.** "**Resets**" (DS60001118), which is available from the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). The Reset module combines all Reset sources and controls the device Main Reset signal, SYSRST. The device Reset sources are as follows: - · Power-on Reset (POR) - Master Clear Reset pin (MCLR) - · Software Reset (SWR) - Watchdog Timer Reset (WDTR) - · Brown-out Reset (BOR) - · Configuration Mismatch Reset (CMR) - Deadman Timer Reset (DMTR) A simplified block diagram of the Reset module is illustrated in Figure 7-1. FIGURE 7-1: SYSTEM RESET BLOCK DIAGRAM ### 7.1 Reset Control Registers ### TABLE 7-1: RESETS REGISTER MAP | SS | | | | | | | | | | Bits | | | | | | | | | | |-----------------------------|------------------|-----------|-------------------|-------|-------|-------|---------|----------|------|------|-------|----------|--------|---------|-------|------|------|-------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1240 | RCON | 31:16 | _ | _ | _ | _ | BCFGERR | BCFGFAIL | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | C000 | | 1240 | KCON | 15:0 | _ | _ | _ | _ | _ | _ | CMR | _ | EXTR | SWR | DMTO | WDTO | SLEEP | IDLE | BOR | POR | 0003 | | 1250 | RSWRST | 31:16 | _ | I | I | _ | _ | _ | 1 | 1 | I | I | _ | I | _ | 1 | 1 | I | 0000 | | 1230 | NOWNOT | 15:0 | _ | | _ | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | | | SWRST | 0000 | | 1260 | RNMICON | 31:16 | _ | I | I | _ | _ | _ | DMTO | WDTO | SWNMI | I | _ | I | GNMI | HLVD | CF | WDTS | 0000 | | 1200 | KINIMICON | 15:0 | NMICNT<15:0> 0000 | | | | | | | | | | | | | | | | | | 1270 | PWRCON | 31:16 | _ | I | 1 | _ | _ | - | 1 | - | - | 1 | _ | - | _ | _ | 1 | 1 | 0000 | | 1270 | 1 WILCON | 15:0 | _ | - | _ | _ | _ | _ | | _ | VREGR | RUN<1:0> | VREGSI | _P<1:0> | _ | _ | - | VREGS | 0000 | ### REGISTER 7-1: RCON: RESET CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|--------------------|--------------------| | 24.24 | U-1, HS | U-1, HS | U-0 | U-0 | R/W-0, HC | R/W-0, HC | U-0 | U-0 | | 31:24 | _ | _ | _ | _ | BCFGERR | BCFGFAIL | - | _ | | 22.40 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-1 | U-x | | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0, HS | U-0 | | 15:8 | _ | _ | _ | _ | _ | _ | CMR | _ | | 7.0 | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-0, HS | R/W-1, HS | R/W-1, HS | | 7:0 | EXTR | SWR | DMTO | WDTO | SLEEP | IDLE | BOR <sup>(2)</sup> | POR <sup>(2)</sup> | Legend:HS = Hardware SetHC = Hardware ClearedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-30 Reserved: Read as '1' on power up. bit 29-28 Unimplemented: Read as '0' bit 27 BCFGERR: Primary Configuration Registers Error Flag bit 1 = An error occurred during a read of the primary configuration registers 0 = No error occurred during a read of the primary configuration registers bit 26 BCFGFAIL: Primary/Secondary Configuration Registers Error Flag bit 1 = An error occurred during a read of the primary and alternate configuration registers 0 = No error occurred during a read of the primary and alternate configuration registers bit 25-10 Unimplemented: Read as '0' bit 9 CMR: Configuration Mismatch Reset Flag bit 1 = A Configuration Mismatch Reset has occurred 0 = A Configuration Mismatch Reset has not occurred bit 8 Unimplemented: Read as '0' bit 7 **EXTR:** External Reset (MCLR) Pin Flag bit 1 = Master Clear (pin) Reset has occurred 0 = Master Clear (pin) Reset has not occurred bit 6 **SWR:** Software Reset Flag bit 1 = Software Reset was executed 0 = Software Reset was not executed bit 5 DMTO: Deadman Timer Time-out Flag bit 1 = A DMT time-out has occurred 0 = A DMT time-out has not occurred bit 4 WDTO: Watchdog Timer Time-out Flag bit 1 = WDT Time-out has occurred 0 = WDT Time-out has not occurred bit 3 SLEEP: Wake From Sleep Flag bit 1 = Device was in Sleep mode 0 = Device was not in Sleep mode bit 2 IDLE: Wake From Idle Flag bit 1 = Device was in Idle mode 0 = Device was not in Idle mode Note 1: User software must clear this bit to view the next detection. ### REGISTER 7-1: RCON: RESET CONTROL REGISTER bit 1 **BOR:** Brown-out Reset Flag bit<sup>(1)</sup> 1 = Brown-out Reset has occurred 0 = Brown-out Reset has not occurred bit 0 **POR:** Power-on Reset Flag bit<sup>(1)</sup> 1 = Power-on Reset has occurred 0 = Power-on Reset has not occurred Note 1: User software must clear this bit to view the next detection. ### REGISTER 7-2: RSWRST: SOFTWARE RESET REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------------| | 24.04 | U-0 | 31:24 | _ | _ | - | _ | _ | | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | - | _ | _ | | _ | _ | | 7.0 | U-0 W-0, HC | | 7:0 | _ | _ | _ | _ | _ | _ | _ | SWRST <sup>(1,2)</sup> | **Legend:** HC = Hardware Cleared R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-1 Unimplemented: Read as '0' bit 0 **SWRST:** Software Reset Trigger bit<sup>(1,2)</sup> 1 = Enable software Reset event 0 = No effect Note 1: The system unlock sequence must be performed before the SWRST bit can be written. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details 2: Once this bit is set, any read of the RSWRST register will cause a Reset to occur. #### REGISTER 7-3: RNMICON: NON-MASKABLE INTERRUPT (NMI) CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--| | 24.04 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | | | | | 31:24 | _ | _ | _ | _ | | _ | DMTO | WDTO | | | | | | 00.46 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0, HS | R/W-0, HS, HC | R/W-0 | | | | | | 23:16 | SWNMI | _ | _ | _ | GNMI | HLVD | CF | WDTS | | | | | | 45.0 | R/W-0 | | | | | 15:8 | NMICNT<15:8> | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | 7:0 | | | • | NMICI | VT<7:0> | • | | | | | | | **Legend:** HC = Hardware Clear HS = Hardware Set R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-26 Unimplemented: Read as '0' bit 25 DMTO: Deadman Timer Time-out Flag bit 1 = DMT time-out has occurred and caused a NMI 0 = DMT time-out has not occurred Setting this bit will cause a DMT NMI event, and NMICNT will begin counting. bit 24 WDTO: Watchdog Timer Time-Out in Run mode Flag bit 1 = WDT time-out has occurred and caused a NMI. (This starts the NMI Reset Counter) 0 = WDT time-out has not occurred Note: Setting this bit either by software or by hardware causes WDT NMI event interrupt and NMICNT start countdown to reset. bit 23 **SWNMI:** Software NMI Trigger. 1 = An NMI will be generated 0 = An NMI will not be generated bit 22-20 **Unimplemented:** Read as '0' bit 19 **GNMI:** Ext or General NMI bit - 1 = A general NMI event has been detected or a user-initiated NMI event has occurred - 0 = A general NMI event has not been detected Setting GNMI to a '1' causes a user-initiated NMI event. This bit is also set by writing 0x4E to the NMIKEY<7:0> (INTCON<31:24>) bits. bit 18 **HLVD:** Programmable High/Low-Voltage Detect Status 1 = Indicates HLVD Event interrupt is active 0 = Indicates HLVD Event interrupt is not active Note: Users can write this bit to '1', and it cause a user initiated HLVD NMI event. Note 1: The system unlock sequence must be done before the RNMICON register to be written... - 2: The RNMICON register is reset (i.e., cleared) when the NMI Reset Counter (NMICNT) expires and a system reset is asserted. - 3: When a Watchdog Timer NMI event (when not in Sleep mode) or a Deadman Timer NMI event is triggered, the NMICNT will start decrementing every SYSCLK. When NMICNT reaches zero, the device is reset if the corresponding WDT or DMT flag is not cleared in SW. This NMI reset counter is only applicable to these two specific NMI events. The NMICNT cannot be updated or changed once in the NMI interrupt service routine by SW. ### REGISTER 7-3: RNMICON: NON-MASKABLE INTERRUPT (NMI) CONTROL REGISTER - 1 = FSCM has detected clock failure and caused an NMI - 0 = FSCM has not detected clock failure Note On a clock fail event if enabled by the FCKSM<1:0> bits (DEVCFG1<15:14>) = '0b11, this bit and the OSCCON<CF> bit will be set. The user software must clear both the bits inside the CF NMI before attempting to exit the ISR. Software or hardware settings of the CF bit (OSCCON<3>) will cause a CF NMI event and an automatic clock switch to the Backup FRC (BFRC) provided the FCKSM<1:0> = '0b11. Unlike the CF bit (OSCCON<3>), software or hardware settings of the CF bit (RNMICON<17>) will cause a CF NMI event but will not cause a clock switch to the BFRC. After a Clock Fail event, a successful user software clock switch if implemented, hardware will automatically clear the CF bit (RNMICON<17>), but not the CF bit (OSCCON<3>). The CF bit (OSCCON<3>) must be cleared by software using the OSCCON register unlock procedure. - bit 16 WDTS: Watchdog Timer Time-out in Sleep Mode Flag bit - 1 = WDT time-out has occurred during Sleep mode and caused a wake-up from sleep - 0 = WDT time-out has not occurred during Sleep mode Note: Setting this bit will cause a WDT NMI interrupt. bit 15-0 NMICNT<15:0>: NMI Reset Counter Value bits These bits specify the reload value used by the NMI reset counter. 11111111-00000001 = Number of SYSCLK cycles before a device Reset occurs<sup>(1)</sup> 00000000 = No delay between NMI assertion and device Reset event - Note 1: The system unlock sequence must be done before the RNMICON register to be written.. - 2: The RNMICON register is reset (i.e., cleared) when the NMI Reset Counter (NMICNT) expires and a system reset is asserted. - 3: When a Watchdog Timer NMI event (when not in Sleep mode) or a Deadman Timer NMI event is triggered, the NMICNT will start decrementing every SYSCLK. When NMICNT reaches zero, the device is reset if the corresponding WDT or DMT flag is not cleared in SW. This NMI reset counter is only applicable to these two specific NMI events. The NMICNT cannot be updated or changed once in the NMI interrupt service routine by SW. ### REGISTER 7-4: PWRCON: POWER CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | | _ | | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 R/W-0 | | 7:0 | _ | _ | _ | - | _ | | _ | VREGS | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-1 Unimplemented: Read as '0' bit 0 VREGS: Internal Voltage Regulator Stand-by Enable bit 1 = Voltage regulator will remain active during Sleep 0 = Voltage regulator will go to Stand-by mode during Sleep # 8.0 CPU EXCEPTIONS AND INTERRUPT CONTROLLER Note: sheet summarizes features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 8. "Interrupt Controller" (DS60001108) and Section 50. "CPU MIPS32® Devices with for microAptiv™ and M-Class Cores" (DS60001192), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). PIC32MK GPK/MCM with CAN FD Family of devices generate interrupt requests in response to interrupt events from peripheral modules. The Interrupt Controller module exists outside of the CPU and prioritizes the interrupt events before presenting them to the CPU. The CPU handles interrupt events as part of the exception handling mechanism, which is described in **8.1** "CPU Exceptions". The Interrupt Controller module includes the following features: - Up to 216 interrupt sources and vectors with dedicated programmable offsets, which eliminates the need for redirection - · Single and multi-vector mode operations - · Five external interrupts with edge polarity control - · Interrupt proximity timer - Seven user-selectable priority levels for each vector - Four user-selectable subpriority levels within each priority - Seven shadow register sets that can be used for any priority level, eliminating software context switch and reducing interrupt latency - · Software can generate any interrupt Table 8-1 provides Interrupt Service routine (ISR) latency information. TABLE 8-1: ISR LATENCY INFORMATION | | | | Optimal Perf | ormance Configu | ration | | Recommended Settings for Optimal Interrupt Performance | Comment | |----------------------------------------------------------------------------------------------|----------------------------------------|------------------------------|--------------|-----------------|--------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | Condition | CP0 REGISTER 16,<br>SELECT 0 <k0></k0> | PERCHEEN bit<br>(CHECON<26>) | | | | PFMWS <2:0> bits<br>CHECON<2:0>) | Note: The user is responsible for the ISR declaration for the fastest ISR latency response. | Interrupt Latency<br>(SYSCLK Cycles)<br>(Time from inter-<br>rupt event to first<br>user source code<br>instruction execu-<br>tion inside ISR). | | Reset Values | 0'b010 | 0'b1 | 0'b1 | 0'b1 | 0,000 | 0'b111 | <pre>voidISR(<vector n="" number="">, ipl7auto)ISR(void) { // "n" = Vector Number, see data sheet // User ISR code }</vector></pre> | 257 Instr Cycles | | Recommended<br>user optimized<br>CPU and ISR<br>Latency Set-<br>tings (see <b>Note</b><br>2) | 0'b011 | 0'b1 | 0'b1 | 0'b1 | 0'b01 | 0'b010 | <pre>(Refer to Note 3) voidattribute((interrupt(iplXsrs), at_vector(n), aligned(16))) isr () { // "n"=Vector Number, see data sheet // "X"=IPL 1-7 // User ISR code }</pre> | 30 + (7 – IPL)<br>Instr Cycles <sup>(3)</sup> | - Note 1: The CPU ISR latency can cause unexpected behavior in high data rate peripherals when a high repetitive rate of CPU interrupts. For example, it is possible that if multiple interrupt sources occur simultaneously, or if a high-speed peripheral like ADC occurs faster than the CPU can read the results from the first original interrupt, then that data may be overwritten by the second interrupt. If the possibility exists in user application that the CPU servicing requirements are less than the combined sum of all possible overlapping interrupt rate specified above, then to avoid buffer overflows or data overwrites it is recommended to use the DMA to service the data and buffer instead of the CPU. - 2: For the best optimized CPU and ISR performance, to complete the optimization, the user application must define ISRs that use the "at vector" attribute as shown in Table 8-1 In addition, if the ADC combined sum throughput rate of all the ADC modules in use is greater than (SYSCLK/43) = 2.8 Msps, it is recommended to use the ADC CPU early interrupt generation defined in the ADCxTIME and ADCEIENx registers. This will reduce the probability of the ADC results being overwritten by the next conversion before the CPU can read the previous ADC result if not using the DMA for ADC. Do not use the early interrupts if using the ADC in DMA mode. 3: For optimal interrupt performance (i.e., latency) the user must assign a unique shadow register set for each interrupt priority level by setting PRISS<PRIxSS> = IPL.. Figure 8-1 illustrates the block diagram of the Interrupt Controller and CPU exceptions. FIGURE 8-1: CPU EXCEPTIONS AND INTERRUPT CONTROLLER MODULE BLOCK DIAGRAM ### 8.1 CPU Exceptions CPU coprocessor 0 contains the logic for identifying and managing exceptions. Exceptions can be caused by a variety of sources, including boundary cases in data, external events or program errors. Table 8-2 lists the exception types in order of priority. TABLE 8-2: MIPS32<sup>®</sup> microAptiv™ MCU CORE EXCEPTION TYPES | Exception Type<br>(In Order of<br>Priority) | Description | Branches to | Status<br>Bits Set | Debug Bits<br>Set | EXCCODE | XC32 Function Name | |---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|-------------------|-----------------|----------------------------| | | | Highest Priority | | | | | | Reset | Assertion MCLR or a Power-on Reset (POR). | 0xBFC0_0000 | BEV, ERL | _ | _ | _on_reset | | Soft Reset | Assertion of a software Reset. | 0xBFC0_0000 | BEV, SR,<br>ERL | _ | _ | _on_reset | | DSS | EJTAG debug single step. | 0xBFC0_0480 | _ | DSS | _ | <del>-</del> | | DINT | EJTAG debug interrupt. Caused by the assertion of the external EJ_DINT input or by setting the EjtagBrk bit in the ECR register. | 0xBFC0_0480 | _ | DINT | _ | _ | | NMI | Assertion of NMI signal. | 0xBFC0_0000 | BEV, NMI,<br>ERL | _ | _ | _nmi_handler | | Interrupt | Assertion of unmasked hardware or software interrupt signal. | See Table 8-3. | IPL<2:0> | _ | 0x00 | See Table 8-3. | | Deferred Watch | Deferred watch (unmasked by K DM=>!(K DM) transition). | EBASE+0x180 | WP, EXL | _ | 0x17 | _general_exception_handler | | DIB | EJTAG debug hardware instruction break matched. | 0xBFC0_0480 | _ | DIB | _ | _ | | WATCH | A reference to an address that is in one of the Watch registers (fetch). | EBASE+0x180 | EXL | _ | 0x17 | _general_exception_handler | | AdEL | Fetch address alignment error. Fetch reference to protected address. | EBASE+0x180 | EXL | _ | 0x04 | _general_exception_handler | | IBE | Instruction fetch bus error. | EBASE+0x180 | EXL | _ | 0x06 | _general_exception_handler | | Instruction<br>Validity<br>Exceptions | An instruction could not be completed because it was not allowed to access the required resources (Coprocessor Unusable) or was illegal (Reserved Instruction). If both exceptions occur on the same instruction, the Coprocessor Unusable Exception takes priority over the Reserved Instruction Exception. | EBASE+0x180 | EXL | _ | 0x0A or<br>0x0B | _general_exception_handler | PIC32MK GPK/MCM with CAN FD Family $\textbf{MIPS32}^{\circledR}\ \textbf{microAptiv}^{\intercal}\ \textbf{MCU CORE EXCEPTION TYPES (CONTINUED)}$ **TABLE 8-2**: | Exception Type<br>(In Order of<br>Priority) | Description | Branches to | Status<br>Bits Set | Debug Bits<br>Set | EXCCODE | XC32 Function Name | | | | | |---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------|---------------------------------------------|-----------|----------------------------|--|--|--|--| | Execute<br>Exception | An instruction-based exception occurred: Integer overflow, trap, system call, breakpoint, floating point, or DSP ASE state disabled exception. | EBASE+0x180 | EXL | _ | 0x08-0x0C | _general_exception_handler | | | | | | Tr | Execution of a trap (when trap condition is true). | EBASE+0x180 | EXL | _ | 0x0D | _general_exception_handler | | | | | | DDBL/DDBS | EJTAG Data Address Break (address only) or<br>EJTAG data value break on store (address +<br>value). | 0xBFC0_0480 | _ | DDBL or<br>DDBS | _ | _ | | | | | | WATCH | A reference to an address that is in one of the Watch registers (data). | EBASE+0x180 | EXL | _ | 0x17 | _general_exception_handler | | | | | | AdEL | Load address alignment error. User mode load reference to kernel address. | EBASE+0x180 | EXL | _ | 0x04 | _general_exception_handler | | | | | | AdES | Store address alignment error. User mode store to kernel address. | EBASE+0x180 | EXL | _ | 0x05 | _general_exception_handler | | | | | | DBE | Load or store bus error. | EBASE+0x180 | EXL | _ | 0x07 | _general_exception_handler | | | | | | DDBL | EJTAG data hardware breakpoint matched in load data compare. | 0xBFC0_0480 | _ | DDBL | _ | _ | | | | | | CBrk | EJTAG complex breakpoint. | 0xBFC0_0480 | _ | DIBIMPR,<br>DDBLIMPR,<br>and/or<br>DDBSIMPR | _ | _ | | | | | | Lowest Priority | | | | | | | | | | | ### 8.2 Interrupts The PIC32MK GPK/MCM with CAN FD Family uses variable offsets for vector spacing. This allows the interrupt vector spacing to be configured according to application needs. A unique interrupt vector offset can be set for each vector using its associated OFFx register. For details on the Variable Offset feature, refer to **8.5.2 "Variable Offset"** in **Section 8. "Interrupt Controller"** (DS60001108) of the *"PIC32 Family Reference Manual"*. Table 8-3 provides the Interrupt IRQ, vector and bit location information. **TABLE 8-3:** INTERRUPT IRQ, VECTOR AND BIT LOCATION | Indo-mark 0 (1) | VO20 Veeter News | IRQ | V4# | | | Persistent | | | |-----------------------------------------|-----------------------------------|--------|------------------|----------|----------|-------------|--------------|-----------| | Interrupt Source <sup>(1)</sup> | XC32 Vector Name | # | Vector # | Flag | Enable | Priority | Sub-priority | Interrupt | | | Highest | Natura | I Order Priority | | | | | | | Core Timer Interrupt | _CORE_TIMER_VECTOR | 0 | OFF000<17:1> | IFS0<0> | IEC0<0> | IPC0<4:2> | IPC0<1:0> | No | | Core Software Interrupt 0 | _CORE_SOFTWARE_0_VECTOR | 1 | OFF001<17:1> | IFS0<1> | IEC0<1> | IPC0<12:10> | IPC0<9:8> | No | | Core Software Interrupt 1 | _CORE_SOFTWARE_1_VECTOR | 2 | OFF002<17:1> | IFS0<2> | IEC0<2> | IPC0<20:18> | IPC0<17:16> | No | | External Interrupt 0 | _EXTERNAL_0_VECTOR | 3 | OFF003<17:1> | IFS0<3> | IEC0<3> | IPC0<28:26> | IPC0<25:24> | No | | Timer1 | _TIMER_1_VECTOR | 4 | OFF004<17:1> | IFS0<4> | IEC0<4> | IPC1<4:2> | IPC1<1:0> | No | | Input Capture 1 Error | _INPUT_CAPTURE_1_ERROR_VECTOR | 5 | OFF005<17:1> | IFS0<5> | IEC0<5> | IPC1<12:10> | IPC1<9:8> | Yes | | Input Capture 1 | _INPUT_CAPTURE_1_VECTOR | 6 | OFF006<17:1> | IFS0<6> | IEC0<6> | IPC1<20:18> | IPC1<17:16> | Yes | | Output Compare 1 | _OUTPUT_COMPARE_1_VECTOR | 7 | OFF007<17:1> | IFS0<7> | IEC0<7> | IPC1<28:26> | IPC1<25:24> | No | | External Interrupt 1 | _EXTERNAL_1_VECTOR | 8 | OFF008<17:1> | IFS0<8> | IEC0<8> | IPC2<4:2> | IPC2<1:0> | No | | Timer2 | _TIMER_2_VECTOR | 9 | OFF009<17:1> | IFS0<9> | IEC0<9> | IPC2<12:10> | IPC2<9:8> | No | | Input Capture 2 Error | _INPUT_CAPTURE_2_ERROR_VECTOR | 10 | OFF010<17:1> | IFS0<10> | IEC0<10> | IPC2<20:18> | IPC2<17:16> | Yes | | Input Capture 2 | _INPUT_CAPTURE_2_VECTOR | 11 | OFF011<17:1> | IFS0<11> | IEC0<11> | IPC2<28:26> | IPC2<25:24> | Yes | | Output Compare 2 | _OUTPUT_COMPARE_2_VECTOR | 12 | OFF012<17:1> | IFS0<12> | IEC0<12> | IPC3<4:2> | IPC3<1:0> | No | | External Interrupt 2 | _EXTERNAL_2_VECTOR | 13 | OFF013<17:1> | IFS0<13> | IEC0<13> | IPC3<12:10> | IPC3<9:8> | No | | Timer3 | _TIMER_3_VECTOR | 14 | OFF014<17:1> | IFS0<14> | IEC0<14> | IPC3<20:18> | IPC3<17:16> | No | | Input Capture 3 Error | _INPUT_CAPTURE_3_ERROR_VECTOR | 15 | OFF015<17:1> | IFS0<15> | IEC0<15> | IPC3<28:26> | IPC3<25:24> | Yes | | Input Capture 3 | _INPUT_CAPTURE_3_VECTOR | 16 | OFF016<17:1> | IFS0<16> | IEC0<16> | IPC4<4:2> | IPC4<1:0> | Yes | | Output Compare 3 | _OUTPUT_COMPARE_3_VECTOR | 17 | OFF017<17:1> | IFS0<17> | IEC0<17> | IPC4<12:10> | IPC4<9:8> | No | | External Interrupt 3 | _EXTERNAL_3_VECTOR | 18 | OFF018<17:1> | IFS0<18> | IEC0<18> | IPC4<20:18> | IPC4<17:16> | No | | Timer4 | _TIMER_4_VECTOR | 19 | OFF019<17:1> | IFS0<19> | IEC0<19> | IPC4<28:26> | IPC4<25:24> | No | | Input Capture 4 Error | _INPUT_CAPTURE_4_ERROR_VECTOR | 20 | OFF020<17:1> | IFS0<20> | IEC0<20> | IPC5<4:2> | IPC5<1:0> | Yes | | Input Capture 4 | _INPUT_CAPTURE_4_VECTOR | 21 | OFF021<17:1> | IFS0<21> | IEC0<21> | IPC5<12:10> | IPC5<9:8> | Yes | | Output Compare 4 | _OUTPUT_COMPARE_4_VECTOR | 22 | OFF022<17:1> | IFS0<22> | IEC0<22> | IPC5<20:18> | IPC5<17:16> | No | | External Interrupt 4 | _EXTERNAL_4_VECTOR | 23 | OFF023<17:1> | IFS0<23> | IEC0<23> | IPC5<28:26> | IPC5<25:24> | No | | Timer5 | _TIMER_5_VECTOR | 24 | OFF024<17:1> | IFS0<24> | IEC0<24> | IPC6<4:2> | IPC6<1:0> | No | | Input Capture 5 Error | | | OFF025<17:1> | IFS0<25> | IEC0<25> | IPC6<12:10> | IPC6<9:8> | Yes | | Input Capture 5 | t Capture 5INPUT_CAPTURE_5_VECTOR | | OFF026<17:1> | IFS0<26> | IEC0<26> | IPC6<20:18> | IPC6<17:16> | Yes | | Output Compare 5OUTPUT_COMPARE_5_VECTOR | | | OFF027<17:1> | IFS0<27> | IEC0<27> | IPC6<28:26> | IPC6<25:24> | No | | Reserved | _ | 28 | _ | | _ | _ | _ | _ | <sup>2:</sup> This interrupt source is not available on 64-pin devices. <sup>3:</sup> This interrupt source is not available on 100-pin devices. TABLE 8-3: INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Intermed Course (1) | VC22 Vester Name | IRQ | Vanta v # | | Interru | ıpt Bit Location | 1 | Persistent | | |---------------------------------|-------------------------|-----|--------------|----------|----------|------------------|--------------|------------|--| | Interrupt Source <sup>(1)</sup> | XC32 Vector Name | # | Vector # | Flag | Enable | Priority | Sub-priority | Interrupt | | | Reserved | _ | 29 | _ | _ | _ | _ | _ | _ | | | Real Time Clock | _RTCC_VECTOR | 30 | OFF030<17:1> | IFS0<30> | IEC0<30> | IPC7<20:18> | IPC7<17:16> | Yes | | | Flash Control Event | _FLASH_CONTROL_VECTOR | 31 | OFF031<17:1> | IFS0<31> | IEC0<31> | IPC7<28:26> | IPC7<25:24> | No | | | Comparator 1 Interrupt | _COMPARATOR_1_VECTOR | 32 | OFF032<17:1> | IFS1<0> | IEC1<0> | IPC8<4:2> | IPC8<1:0> | No | | | Comparator 2 Interrupt | _COMPARATOR_2_VECTOR | 33 | OFF033<17:1> | IFS1<1> | IEC1<1> | IPC8<12:10> | IPC8<9:8> | No | | | USB1 Interrupts | _USB_1_VECTOR | 34 | OFF034<17:1> | IFS1<2> | IEC1<2> | IPC8<20:18> | IPC8<17:16> | Yes | | | SPI1 Fault | _SPI1_FAULT_VECTOR | 35 | OFF035<17:1> | IFS1<3> | IEC1<3> | IPC8<28:26> | IPC8<25:24> | Yes | | | SPI1 Receive Done | _SPI1_RX_VECTOR | 36 | OFF036<17:1> | IFS1<4> | IEC1<4> | IPC9<4:2> | IPC9<1:0> | Yes | | | SPI1 Transfer Done | _SPI1_TX_VECTOR | 37 | OFF037<17:1> | IFS1<5> | IEC1<5> | IPC9<12:10> | IPC9<9:8> | Yes | | | UART1 Fault | _UART1_FAULT_VECTOR | 38 | OFF038<17:1> | IFS1<6> | IEC1<6> | IPC9<20:18> | IPC9<17:16> | Yes | | | UART1 Receive Done | _UART1_RX_VECTOR | 39 | OFF039<17:1> | IFS1<7> | IEC1<7> | IPC9<28:26> | IPC9<25:24> | Yes | | | UART1 Transfer Done | _UART1_TX_VECTOR | 40 | OFF040<17:1> | IFS1<8> | IEC1<8> | IPC10<4:2> | IPC10<1:0> | Yes | | | I1C1 Bus Collision Event | I2C1 BUS VECTOR | | OFF041<17:1> | IFS1<9> | IEC1<9> | IPC9<12:10> | IPC9<9:8> | Yes | | | I2C1 Client Event | _I2C1_SLAVE_VECTOR | 42 | OFF042<17:1> | IFS1<10> | IEC1<10> | IPC9<20:18> | IPC9<17:16> | Yes | | | I2C1 Host Event | _I2C1_MASTER_VECTOR | 43 | OFF043<17:1> | IFS1<11> | IEC1<11> | IPC10<28:26> | IPC10<25:24> | No | | | PORTA Input Change Interrupt | _CHANGE_NOTICE_A_VECTOR | 44 | OFF044<17:1> | IFS1<12> | IEC1<12> | IPC11<4:2> | IPC11<1:0> | Yes | | | PORTB Input Change Interrupt | _CHANGE_NOTICE_B_VECTOR | 45 | OFF045<17:1> | IFS1<13> | IEC1<13> | IPC11<12:10> | IPC11<9:8> | Yes | | | PORTC Input Change Interrupt | _CHANGE_NOTICE_C_VECTOR | 46 | OFF046<17:1> | IFS1<14> | IEC1<14> | IPC11<20:18> | IPC11<17:16> | Yes | | | PORTD Input Change Interrupt | _CHANGE_NOTICE_D_VECTOR | 47 | OFF047<17:1> | IFS1<15> | IEC1<15> | IPC11<28:26> | IPC11<25:24> | Yes | | | PORTE Input Change Interrupt | _CHANGE_NOTICE_E_VECTOR | 48 | OFF048<17:1> | IFS1<16> | IEC1<16> | IPC12<4:2> | IPC12<1:0> | Yes | | | PORTF Input Change Interrupt | _CHANGE_NOTICE_F_VECTOR | 49 | OFF049<17:1> | IFS1<17> | IEC1<17> | IPC12<12:10> | IPC12<9:8> | Yes | | | PORTG Input Change Interrupt | _CHANGE_NOTICE_G_VECTOR | 50 | OFF050<17:1> | IFS1<18> | IEC1<18> | IPC12<20:18> | IPC12<17:16> | Yes | | | Parallel Master Port | _PMP_VECTOR | 51 | OFF051<17:1> | IFS1<19> | IEC1<19> | IPC12<28:26> | IPC12<25:24> | Yes | | | Parallel Master Port Error | _PMP_ERROR_VECTOR | 52 | OFF052<17:1> | IFS1<20> | IEC1<20> | IPC13<4:2> | IPC13<1:0> | Yes | | <sup>2:</sup> This interrupt source is not available on 64-pin devices. <sup>3:</sup> This interrupt source is not available on 100-pin devices. DS60001519E-page 129 **TABLE 8-3:** INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Interrupt Source <sup>(1)</sup> | XC32 Vector Name | IRQ | Vector# | | 1 | Persistent | | | |---------------------------------|-------------------------------|-----|--------------|----------|----------|--------------|--------------|-----------| | interrupt Source | AC32 Vector Name | # | vector# | Flag | Enable | Priority | Sub-priority | Interrupt | | SPI2 Fault | _SPI2_FAULT_VECTOR | 53 | OFF053<17:1> | IFS1<21> | IEC1<21> | IPC13<12:10> | IPC13<9:8> | Yes | | SPI2 Receive Done | _SPI2_RX_VECTOR | 54 | OFF054<17:1> | IFS1<22> | IEC1<22> | IPC13<20:18> | IPC13<17:16> | Yes | | SPI2 Transfer Done | _SPI2_TX_VECTOR | 55 | OFF055<17:1> | IFS1<23> | IEC1<23> | IPC13<28:26> | IPC13<25:24> | Yes | | UART2 Fault | _UART2_FAULT_VECTOR | 56 | OFF056<17:1> | IFS1<24> | IEC1<24> | IPC14<4:2> | IPC14<1:0> | Yes | | UART2 Receive Done | _UART2_RX_VECTOR | 57 | OFF057<17:1> | IFS1<25> | IEC1<25> | IPC14<12:10> | IPC14<9:8> | Yes | | UART2 Transfer Done | _UART2_TX_VECTOR | 58 | OFF058<17:1> | IFS1<26> | IEC1<26> | IPC14<20:18> | IPC14<17:16> | Yes | | I1C2 Bus Collision Event | _I2C2_BUS_VECTOR | 59 | OFF059<17:1> | IFS1<27> | IEC1<27> | IPC14<28:26> | IPC14<25:24> | Yes | | I2C2 Client Event | _I2C2_SLAVE_VECTOR | 60 | OFF060<17:1> | IFS1<28> | IEC1<28> | IPC15<4:2> | IPC15<1:0> | Yes | | I2C2 Host Event | _I2C2_MASTER_VECTOR | 61 | OFF061<17:1> | IFS1<29> | IEC1<29> | IPC15<12:10> | IPC15<9:8> | Yes | | UART3 Fault | _UART3_FAULT_VECTOR | 62 | OFF062<17:1> | IFS1<30> | IEC1<30> | IPC15<20:18> | IPC15<17:16> | Yes | | UART3 Receive Done | _UART3_RX_VECTOR | 63 | OFF063<17:1> | IFS1<31> | IEC1<31> | IPC15<28:26> | IPC15<25:24> | Yes | | UART3 Transfer Done | _UART3_TX_VECTOR | 64 | OFF064<17:1> | IFS2<0> | IEC2<0> | IPC16<4:2> | IPC16<1:0> | Yes | | UART4 Fault | _UART4_FAULT_VECTOR | 65 | OFF065<17:1> | IFS2<1> | IEC2<1> | IPC16<12:10> | IPC16<9:8> | Yes | | UART4 Receive Done | _UART4_RX_VECTOR | 66 | OFF066<17:1> | IFS2<2> | IEC2<2> | IPC16<20:18> | IPC16<17:16> | Yes | | UART4 Transfer Done | _UART4_TX_VECTOR | 67 | OFF067<17:1> | IFS2<3> | IEC2<3> | IPC16<28:26> | IPC16<25:24> | Yes | | UART5 Fault | _UART5_FAULT_VECTOR | 68 | OFF068<17:1> | IFS2<4> | IEC2<4> | IPC17<4:2> | IPC17<1:0> | Yes | | UART5 Receive Done | _UART5_RX_VECTOR | 69 | OFF069<17:1> | IFS2<5> | IEC2<5> | IPC17<12:10> | IPC17<9:8> | Yes | | UART5 Transfer Done | _UART5_TX_VECTOR | 70 | OFF070<17:1> | IFS2<6> | IEC2<6> | IPC17<20:18> | IPC17<17:16> | Yes | | CTMU Interrupt | _CTMU_VECTOR | 71 | OFF071<17:1> | IFS2<7> | IEC2<7> | IPC17<28:26> | IPC17<25:24> | Yes | | DMA Channel 0 | _DMA0_VECTOR | 72 | OFF072<17:1> | IFS2<8> | IEC2<8> | IPC18<4:2> | IPC18<1:0> | Yes | | DMA Channel 1 | _DMA1_VECTOR | 73 | OFF073<17:1> | IFS2<9> | IEC2<9> | IPC18<12:10> | IPC18<9:8> | Yes | | DMA Channel 2 | _DMA2_VECTOR | 74 | OFF074<17:1> | IFS2<10> | IEC2<10> | IPC18<20:18> | IPC18<17:16> | Yes | | DMA Channel 3 | _DMA3_VECTOR | 75 | OFF075<17:1> | IFS2<11> | IEC2<11> | IPC18<28:26> | IPC18<25:24> | Yes | | Timer6 | _TIMER_6_VECTOR | 76 | OFF076<17:1> | IFS2<12> | IEC2<12> | IPC19<4:2> | IPC19<1:0> | Yes | | Input Capture 6 Error | _INPUT_CAPTURE_6_ERROR_VECTOR | 77 | OFF077<17:1> | IFS2<13> | IEC2<13> | IPC19<12:10> | IPC19<9:8> | Yes | | Input Capture 6 | _INPUT_CAPTURE_6_VECTOR | 78 | OFF078<17:1> | IFS2<14> | IEC2<14> | IPC19<20:18> | IPC19<17:16> | Yes | | Output Compare 6 | _OUTPUT_COMPARE_6_VECTOR | 79 | OFF079<17:1> | IFS2<15> | IEC2<15> | IPC19<28:26> | IPC19<25:24> | Yes | | Timer7 | _TIMER_7_VECTOR | 80 | OFF080<17:1> | IFS2<16> | IEC2<16> | IPC20<4:2> | IPC20<1:0> | Yes | | Input Capture 7 Error | _INPUT_CAPTURE_7_ERROR_VECTOR | 81 | OFF081<17:1> | IFS2<17> | IEC2<17> | IPC20<12:10> | IPC20<9:8> | Yes | | Input Capture 7 | _INPUT_CAPTURE_7_VECTOR | 82 | OFF082<17:1> | IFS2<18> | IEC2<18> | IPC20<20:18> | IPC20<17:16> | Yes | | Output Compare 7 | _OUTPUT_COMPARE_7_VECTOR | 83 | OFF083<17:1> | IFS2<19> | IEC2<19> | IPC20<28:26> | IPC20<25:24> | Yes | <sup>2:</sup> This interrupt source is not available on 64-pin devices. This interrupt source is not available on 100-pin devices. TABLE 8-3: INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Interrupt Source <sup>(1)</sup> | XC32 Vector Name | IRQ | Vector # | | Interru | ıpt Bit Location | | Persistent | |---------------------------------|-------------------------------|-----|--------------|----------|----------|------------------|--------------|------------| | interrupt Source | AC32 Vector Name | # | vector# | Flag | Enable | Priority | Sub-priority | Interrupt | | Timer8 | _TIMER_8_VECTOR | 84 | OFF084<17:1> | IFS2<20> | IEC2<20> | IPC21<4:2> | IPC21<1:0> | Yes | | Input Capture 8 Error | _INPUT_CAPTURE_8_ERROR_VECTOR | 85 | OFF085<17:1> | IFS2<21> | IEC2<21> | IPC21<12:10> | IPC21<9:8> | Yes | | Input Capture 8 | _INPUT_CAPTURE_8_VECTOR | 86 | OFF086<17:1> | IFS2<22> | IEC2<22> | IPC21<20:18> | IPC21<17:16> | Yes | | Output Compare 8 | _OUTPUT_COMPARE_8_VECTOR | 87 | OFF087<17:1> | IFS2<23> | IEC2<23> | IPC21<28:26> | IPC21<25:24> | Yes | | Timer9 | _TIMER_9_VECTOR | 88 | OFF088<17:1> | IFS2<24> | IEC2<24> | IPC22<4:2> | IPC22<1:0> | Yes | | Input Capture 9 Error | _INPUT_CAPTURE_9_ERROR_VECTOR | 89 | OFF089<17:1> | IFS2<25> | IEC2<25> | IPC22<12:10> | IPC22<9:8> | Yes | | Input Capture 9 | _INPUT_CAPTURE_9_VECTOR | 90 | OFF090<17:1> | IFS2<26> | IEC2<26> | IPC22<20:18> | IPC22<17:16> | Yes | | Output Compare 9 | _OUTPUT_COMPARE_9_VECTOR | 91 | OFF091<17:1> | IFS2<27> | IEC2<27> | IPC22<28:26> | IPC22<25:24> | Yes | | ADC Global Interrupt | _ADC_VECTOR | 92 | OFF092<17:1> | IFS2<28> | IEC2<28> | IPC23<4:2> | IPC23<1:0> | Yes | | Reserved | _ | 93 | _ | _ | _ | _ | <u>—</u> | _ | | ADC Digital Comparator 1 | _ADC_DC1_VECTOR | 94 | OFF094<17:1> | IFS2<30> | IEC2<30> | IPC23<20:18> | IPC23<17:16> | Yes | | ADC Digital Comparator 2 | _ADC_DC2_VECTOR | 95 | OFF095<17:1> | IFS2<31> | IEC2<31> | IPC23<28:26> | IPC23<25:24> | Yes | | ADC Digital Filter 1 | _ADC_DF1_VECTOR | 96 | OFF096<17:1> | IFS3<0> | IEC3<0> | IPC24<4:2> | IPC24<1:0> | Yes | | ADC Digital Filter 2 | _ADC_DF2_VECTOR | 97 | OFF097<17:1> | IFS3<1> | IEC3<1> | IPC24<12:10> | IPC24<9:8> | Yes | | ADC Digital Filter 3 | _ADC_DF3_VECTOR | 98 | OFF098<17:1> | IFS3<2> | IEC3<2> | IPC24<20:18> | IPC24<17:16> | Yes | | ADC Digital Filter 4 | _ADC_DF4_VECTOR | 99 | OFF099<17:1> | IFS3<3> | IEC3<3> | IPC24<28:26> | IPC24<25:24> | Yes | | ADC Fault | _ADC_FAULT_VECTOR | 100 | OFF100<17:1> | IFS3<4> | IEC3<4> | IPC25<4:2> | IPC25<1:0> | Yes | | ADC End of Scan | _ADC_EOS_VECTOR | 101 | OFF101<17:1> | IFS3<5> | IEC3<5> | IPC25<12:10> | IPC25<9:8> | Yes | | ADC Ready | _ADC_ARDY_VECTOR | 102 | OFF102<17:1> | IFS3<6> | IEC3<6> | IPC25<20:18> | IPC25<17:16> | Yes | | ADC Update Ready After Suspend | _ADC_URDY_VECTOR | 103 | OFF103<17:1> | IFS3<7> | IEC3<7> | IPC25<28:26> | IPC25<25:24> | Yes | | ADC First Class Channels DMA | _ADC_DMA_VECTOR | 104 | OFF104<17:1> | IFS3<8> | IEC3<8> | IPC26<4:2> | IPC26<1:0> | No | | ADC Early Group Interrupt | _ADC_EARLY_VECTOR | 105 | OFF105<17:1> | IFS3<9> | IEC3<9> | IPC26<12:10> | IPC26<9:8> | Yes | | ADC Data 0 | _ADC_DATA0_VECTOR | 106 | OFF106<17:1> | IFS3<10> | IEC3<10> | IPC26<20:18> | IPC26<17:16> | Yes | | ADC Data 1 | _ADC_DATA1_VECTOR | 107 | OFF107<17:1> | IFS3<11> | IEC3<11> | IPC26<28:26> | IPC26<25:24> | Yes | | ADC Data 2 | _ADC_DATA2_VECTOR | 108 | OFF108<17:1> | IFS3<12> | IEC3<12> | IPC26<4:2> | IPC27<1:0> | Yes | | ADC Data 3 | _ADC_DATA3_VECTOR | 109 | OFF109<17:1> | IFS3<13> | IEC3<13> | IPC27<12:10> | IPC27<9:8> | Yes | | ADC Data 4 | _ADC_DATA4_VECTOR | 110 | OFF110<17:1> | IFS3<14> | IEC3<14> | IPC27<20:18> | IPC27<17:16> | Yes | | ADC Data 5 | _ADC_DATA5_VECTOR | 111 | OFF111<17:1> | IFS3<15> | IEC3<15> | IPC27<28:26> | IPC27<25:24> | Yes | | ADC Data 6 | _ADC_DATA6_VECTOR | 112 | OFF112<17:1> | IFS3<16> | IEC3<16> | IPC28<4:2> | IPC28<1:0> | Yes | | ADC Data 7 | _ADC_DATA7_VECTOR | 113 | OFF113<17:1> | IFS3<17> | IEC3<17> | IPC28<12:10> | IPC28<9:8> | Yes | | ADC Data 8 | _ADC_DATA8_VECTOR | 114 | OFF114<17:1> | IFS3<18> | IEC3<18> | IPC28<20:18> | IPC28<17:16> | Yes | <sup>2:</sup> This interrupt source is not available on 64-pin devices. <sup>3:</sup> This interrupt source is not available on 100-pin devices. DS60001519E-page 131 **TABLE 8-3**: INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Interrupt Source <sup>(1)</sup> | XC32 Vector Name | IRQ | Vector# | | Interru | upt Bit Location | | Persistent | |---------------------------------|--------------------|-----|--------------|----------|----------|------------------|--------------|------------| | interrupt Source | AC32 Vector Name | # | vector# | Flag | Enable | Priority | Sub-priority | Interrupt | | ADC Data 9 | _ADC_DATA9_VECTOR | 115 | OFF115<17:1> | IFS3<19> | IEC3<19> | IPC28<28:26> | IPC28<25:24> | Yes | | ADC Data 10 | _ADC_DATA10_VECTOR | 116 | OFF116<17:1> | IFS3<20> | IEC3<20> | IPC29<4:2> | IPC29<1:0> | Yes | | ADC Data 11 | _ADC_DATA11_VECTOR | 117 | OFF117<17:1> | IFS3<21> | IEC3<21> | IPC29<12:10> | IPC29<9:8> | Yes | | ADC Data 12 | _ADC_DATA12_VECTOR | 118 | OFF118<17:1> | IFS3<22> | IEC3<22> | IPC29<20:18> | IPC29<17:16> | Yes | | ADC Data 13 | _ADC_DATA13_VECTOR | 119 | OFF119<17:1> | IFS3<23> | IEC3<23> | IPC29<28:26> | IPC29<25:24> | Yes | | ADC Data 14 | _ADC_DATA14_VECTOR | 120 | OFF120<17:1> | IFS3<24> | IEC3<24> | IPC30<4:2> | IPC30<1:0> | Yes | | ADC Data 15 | _ADC_DATA15_VECTOR | 121 | OFF121<17:1> | IFS3<25> | IEC3<25> | IPC30<12:10> | IPC30<9:8> | Yes | | ADC Data 16 | _ADC_DATA16_VECTOR | 122 | OFF122<17:1> | IFS3<26> | IEC3<26> | IPC30<20:18> | IPC30<17:16> | Yes | | ADC Data 17 | _ADC_DATA17_VECTOR | 123 | OFF123<17:1> | IFS3<27> | IEC3<27> | IPC30<28:26> | IPC30<25:24> | Yes | | ADC Data 18 | _ADC_DATA18_VECTOR | 124 | OFF124<17:1> | IFS3<28> | IEC3<28> | IPC31<4:2> | IPC31<1:0> | Yes | | ADC Data 19 | _ADC_DATA19_VECTOR | 125 | OFF125<17:1> | IFS3<29> | IEC3<29> | IPC31<12:10> | IPC31<9:8> | Yes | | ADC Data 20 | _ADC_DATA20_VECTOR | 126 | OFF126<17:1> | IFS3<30> | IEC3<30> | IPC31<20:18> | IPC31<17:16> | Yes | | ADC Data 21 | _ADC_DATA21_VECTOR | 127 | OFF127<17:1> | IFS3<31> | IEC3<31> | IPC31<28:26> | IPC31<25:24> | Yes | | ADC Data 22 | _ADC_DATA22_VECTOR | 128 | OFF128<17:1> | IFS4<0> | IEC4<0> | IPC32<4:2> | IPC32<1:0> | Yes | | ADC Data 23 | _ADC_DATA23_VECTOR | 129 | OFF129<17:1> | IFS4<1> | IEC4<1> | IPC32<12:10> | IPC32<9:8> | Yes | | ADC Data 24 | _ADC_DATA24_VECTOR | 130 | OFF130<17:1> | IFS4<2> | IEC4<2> | IPC32<20:18> | IPC32<17:16> | Yes | | ADC Data 25 | _ADC_DATA25_VECTOR | 131 | OFF131<17:1> | IFS4<3> | IEC4<3> | IPC32<28:26> | IPC32<25:24> | Yes | | ADC Data 26 | _ADC_DATA26_VECTOR | 132 | OFF132<17:1> | IFS4<4> | IEC4<4> | IPC33<4:2> | IPC33<1:0> | Yes | | ADC Data 27 | _ADC_DATA27_VECTOR | 133 | OFF133<17:1> | IFS4<5> | IEC4<5> | IPC33<12:10> | IPC33<9:8> | Yes | | Reserved | _ | 134 | _ | _ | _ | _ | _ | _ | | Reserved | <del>-</del> | 135 | _ | _ | _ | _ | _ | _ | | Reserved | _ | 136 | _ | _ | _ | _ | _ | _ | | Reserved | _ | 137 | _ | _ | _ | _ | _ | _ | | Reserved | <del>-</del> | 138 | _ | _ | _ | _ | _ | _ | | ADC Data 33 | _ADC_DATA33_VECTOR | 139 | OFF139<17:1> | IFS4<11> | IEC4<11> | IPC34<28:26> | IPC34<25:24> | Yes | | ADC Data 34 | _ADC_DATA34_VECTOR | 140 | OFF140<17:1> | IFS4<12> | IEC4<12> | IPC35<4:2> | IPC35<1:0> | Yes | | ADC Data 35 | _ADC_DATA35_VECTOR | 141 | OFF141<17:1> | IFS4<13> | IEC4<13> | IPC35<12:10> | IPC35<9:8> | Yes | | ADC Data 36 | _ADC_DATA36_VECTOR | 142 | OFF142<17:1> | IFS4<14> | IEC4<14> | IPC35<20:18> | IPC35<17:16> | Yes | | ADC Data 37 | _ADC_DATA37_VECTOR | 143 | OFF143<17:1> | IFS4<15> | IEC4<15> | IPC35<28:26> | IPC35<25:24> | Yes | | ADC Data 38 | _ADC_DATA38_VECTOR | 144 | OFF144<17:1> | IFS4<16> | IEC4<16> | IPC36<4:2> | IPC36<1:0> | Yes | | ADC Data 39 | _ADC_DATA39_VECTOR | 145 | OFF145<17:1> | IFS4<17> | IEC4<17> | IPC36<12:10> | IPC36<9:8> | Yes | This interrupt source is not available on 64-pin devices. <sup>3:</sup> This interrupt source is not available on 100-pin devices. TABLE 8-3: INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Interrupt Source <sup>(1)</sup> | VC22 Vester News | IRQ | Vooton# | | Interru | ıpt Bit Location | | Persistent | |-----------------------------------------------------------------|----------------------|-----|--------------|----------|----------|------------------|--------------|------------| | interrupt Source | XC32 Vector Name | # | Vector # | Flag | Enable | Priority | Sub-priority | Interrupt | | ADC Data 40 | _ADC_DATA40_VECTOR | 146 | OFF146<17:1> | IFS4<18> | IEC4<18> | IPC36<20:18> | IPC36<17:16> | Yes | | ADC Data 41 | _ADC_DATA41_VECTOR | 147 | OFF147<17:1> | IFS4<19> | IEC4<19> | IPC36<28:26> | IPC36<25:24> | Yes | | Reserved | _ | 148 | _ | _ | _ | _ | _ | _ | | Reserved | _ | 149 | _ | _ | | _ | _ | _ | | Reserved | _ | 150 | _ | _ | | _ | _ | _ | | ADC Data 45 | _ADC_DATA45_VECTOR | 151 | OFF151<17:1> | IFS4<23> | IEC4<23> | IPC37<28:26> | IPC37<25:24> | Yes | | ADC Data 46 | _ADC_DATA46_VECTOR | 152 | OFF152<17:1> | IFS4<24> | IEC4<24> | IPC38<4:2> | IPC38<1:0> | Yes | | ADC Data 47 | _ADC_DATA47_VECTOR | 153 | OFF153<17:1> | IFS4<25> | IEC4<25> | IPC38<12:10> | IPC38<9:8> | Yes | | ADC Data 48 | _ADC_DATA48_VECTOR | 154 | OFF154<17:1> | IFS4<26> | IEC4<26> | IPC38<20:18> | IPC38<17:16> | Yes | | ADC Data 49 | _ADC_DATA49_VECTOR | 155 | OFF155<17:1> | IFS4<27> | IEC4<27> | IPC38<28:26> | IPC38<25:24> | Yes | | ADC Data 50 | _ADC_DATA50_VECTOR | 156 | OFF156<17:1> | IFS4<28> | IEC4<28> | IPC39<4:2> | IPC39<1:0> | Yes | | Reserved | _ | 157 | _ | _ | _ | _ | _ | _ | | Reserved | _ | 158 | _ | _ | | _ | _ | _ | | ADC Data 53 | _ADC_DATA53_VECTOR | 159 | OFF159<17:1> | IFS4<31> | IEC4<31> | IPC39<28:26> | IPC39<25:24> | Yes | | Comparator 3 Interrupt | _COMPARATOR_3_VECTOR | 160 | OFF160<17:1> | IFS5<0> | IEC5<0> | IPC40<4:2> | IPC40<1:0> | No | | Comparator 4 Interrupt | _COMPARATOR_4_VECTOR | 161 | OFF161<17:1> | IFS5<1> | IEC5<1> | IPC40<12:10> | IPC40<9:8> | No | | Comparator 5 Interrupt | _COMPARATOR_5_VECTOR | 162 | OFF162<17:1> | IFS5<2> | IEC5<2> | IPC40<20:18> | IPC40<17:16> | No | | Reserved | _ | 163 | _ | _ | _ | _ | _ | _ | | UART6 Fault | _UART6_FAULT_VECTOR | 164 | OFF164<17:1> | IFS5<4> | IEC5<4> | IPC41<4:2> | IPC41<1:0> | Yes | | UART6 Receive Done | _UART6_RX_VECTOR | 165 | OFF165<17:1> | IFS5<5> | IEC5<5> | IPC41<12:10> | IPC41<9:8> | Yes | | UART6 Transfer Done | _UART6_TX_VECTOR | 166 | OFF166<17:1> | IFS5<6> | IEC5<6> | IPC41<20:18> | IPC41<17:16> | Yes | | CAN1 Global Interrupt | _CAN1_VECTOR | 167 | OFF167<17:1> | IFS5<7> | IEC5<7> | IPC41<28:26> | IPC41<25:24> | Yes | | CAN2 Global Interrupt | _CAN2_VECTOR | 168 | OFF168<17:1> | IFS5<8> | IEC5<8> | IPC42<4:2> | IPC42<1:0> | Yes | | QEI1 Interrupt | _QEI1_VECTOR | 169 | OFF169<17:1> | IFS5<9> | IEC5<9> | IPC42<12:10> | IPC42<9:8> | Yes | | QEI2 Interrupt | _QEI2_VECTOR | 170 | OFF170<17:1> | IFS5<10> | IEC5<10> | IPC42<20:18> | IPC42<17:16> | Yes | | PWM Primary Event | _PWM_PRI_VECTOR | 171 | OFF171<17:1> | IFS5<11> | IEC5<11> | IPC42<28:26> | IPC42<25:24> | No | | PWM Sec Event | _PWM_SEC_VECTOR | 172 | OFF172<17:1> | IFS5<12> | IEC5<12> | IPC43<4:2> | IPC43<1:0> | No | | PWM1 Combined Interrupt (Period, Fault, Trigger, Current-Limit) | _PWM1_VECTOR | 173 | OFF173<17:1> | IFS5<13> | IEC5<13> | IPC43<12:10> | IPC43<9:8> | No | | PWM2 Combined Interrupt (Period, Fault, Trigger, Current-Limit) | _PWM2_VECTOR | 174 | OFF174<17:1> | IFS5<14> | IEC5<14> | IPC43<20:18> | IPC43<17:16> | No | <sup>2:</sup> This interrupt source is not available on 64-pin devices. <sup>3:</sup> This interrupt source is not available on 100-pin devices. **TABLE 8-3:** INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Interrupt Source <sup>(1)</sup> | XC32 Vector Name | IRQ | Vector # | | Interru | upt Bit Location | | Persistent | |-----------------------------------------------------------------|--------------------------------|-----|---------------|----------|----------|------------------|--------------|------------| | interrupt Source. | AC32 Vector Name | # | vector # | Flag | Enable | Priority | Sub-priority | Interrupt | | PWM3 Combined Interrupt (Period, Fault, Trigger, Current-Limit) | _PWM3_VECTOR | 175 | OFF175<17:1> | IFS5<15> | IEC5<15> | IPC43<28:26> | IPC43<25:24> | No | | PWM4 Combined Interrupt (Period, Fault, Trigger, Current-Limit) | _PWM4_VECTOR | 176 | OFF176<17:1> | IFS5<16> | IEC5<16> | IPC44<4:2> | IPC44<1:0> | No | | PWM5 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM5_VECTOR | 177 | OFF177<17:1> | IFS5<17> | IEC5<17> | IPC44<12:10> | IPC44<9:8> | No | | PWM6 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM6_VECTOR | 178 | OFF178<17:1> | IFS5<18> | IEC5<18> | IPC44<20:18> | IPC44<17:16> | No | | I2C3 Bus Collision Event | _I2C3_BUS_VECTOR | 179 | OFF0179<17:1> | IFS5<19> | IEC5<19> | IPC44<28:26> | IPC44<25:24> | Yes | | I2C3 Client Event | _I2C3_SLAVE_VECTOR | 180 | OFF0180<17:1> | IFS5<20> | IEC5<20> | IPC45<4:2> | IPC45<1:0> | Yes | | I2C3 Host Event | _I2C3_MASTER_VECTOR | 181 | OFF0181<17:1> | IFS5<21> | IEC5<21> | IPC45<12:10> | IPC45<9:8> | Yes | | DMA Channel 4 | _DMA4_VECTOR | 182 | OFF182<17:1> | IFS5<22> | IEC5<22> | IPC45<20:18> | IPC45<17:16> | Yes | | DMA Channel 5 | _DMA5_VECTOR | 183 | OFF183<17:1> | IFS5<23> | IEC5<23> | IPC45<28:26> | IPC45<25:24> | Yes | | DMA Channel 6 | _DMA6_VECTOR | 184 | OFF184<17:1> | IFS5<24> | IEC5<24> | IPC46<4:2> | IPC46<1:0> | Yes | | DMA Channel 7 | _DMA7_VECTOR | 185 | OFF185<17:1> | IFS5<25> | IEC5<25> | IPC46<12:10> | IPC46<9:8> | Yes | | Data EEPROM Global Interrupt | _DATA_EE_VECTOR | 186 | OFF186<17:1> | IFS5<26> | IEC5<26> | IPC46<20:18> | IPC46<17:16> | Yes | | CAN3 Global Interrupt | _CAN3_VECTOR | 187 | OFF187<17:1> | IFS5<27> | IEC5<27> | IPC46<28:26> | IPC46<25:24> | Yes | | CAN4 Global Interrupt | _CAN4_VECTOR | 188 | OFF188<17:1> | IFS5<28> | IEC5<28> | IPC47<4:2> | IPC47<1:0> | Yes | | QEI3 Interrupt | _QEI2_VECTOR | 189 | OFF189<17:1> | IFS5<29> | IEC5<29> | IPC47<12:10> | IPC47<9:8> | Yes | | QEI4 Interrupt | _QEI3_VECTOR | 190 | OFF190<17:1> | IFS5<30> | IEC5<30> | IPC47<20:18> | IPC47<17:16> | Yes | | QEI5 Interrupt | _QEI5_VECTOR | 191 | OFF191<17:1> | IFS5<31> | IEC5<31> | IPC47<28:26> | IPC47<25:24> | Yes | | QEI6 Interrupt | _QEI6_VECTOR | 192 | OFF192<17:1> | IFS6<0> | IEC6<0> | IPC48<4:2> | IPC48<1:0> | Yes | | Reserved | _ | 193 | _ | _ | _ | _ | _ | _ | | I2C4 Bus Collision Event | _I2C4_BUS_VECTOR | 194 | OFF0194<17:1> | IFS6<2> | IEC6<2> | IPC48<20:18> | IPC48<17:16> | Yes | | I2C4 Client Event | _I2C4_SLAVE_VECTOR | 195 | OFF0195<17:1> | IFS6<3> | IEC6<3> | IPC48<28:26> | IPC48<25:24> | Yes | | I2C4 Host Event | _i2C4_MASTER_VECTOR | | OFF0196<17:1> | IFS6<4> | IEC6<4> | IPC49<4:2> | IPC49<1:0> | Yes | | Input Capture 10 Error | orINPUT_CAPTURE_10_ERROR_VECT | | OFF197<17:1> | IFS6<5> | IEC6<5> | IPC49<12:10> | IPC49<9:8> | Yes | | Input Capture 10 | _INPUT_CAPTURE_10_VECTOR | 198 | OFF198<17:1> | IFS6<6> | IE6<6> | IPC49<20:18> | IPC49<17:16> | Yes | | Output Compare 10 | _OUTPUT_COMPARE_10_VECTOR | 199 | OFF199<17:1> | IFS6<7> | IEC6<7> | IPC49<28:26> | IPC49<25:24> | Yes | | Input Capture 11 Error | _INPUT_CAPTURE_11_ERROR_VECTOR | 200 | OFF200<17:1> | IFS6<8> | IEC6<8> | IPC50<4:2> | IPC50<1:0> | Yes | | Input Capture 11 | _INPUT_CAPTURE_11_VECTOR | 201 | OFF201<17:1> | IFS6<9> | IEC6<9> | IPC50<12:10> | IPC50<9:8> | Yes | Not all interrupt sources are available on all devices. See TABLE 1: "PIC32MK General Purpose (GP) Family Features" for the list of available peripherals. Note 1: This interrupt source is not available on 64-pin devices. 2: <sup>3:</sup> This interrupt source is not available on 100-pin devices. TABLE 8-3: INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Interrupt Source <sup>(1)</sup> | XC32 Vector Name | IRQ | Vector # | | Interru | ıpt Bit Location | | Persistent | |---------------------------------|--------------------------------|-----|--------------|----------|----------|------------------|--------------|------------| | Interrupt Source | AC32 Vector Name | # | vector # | Flag | Enable | Priority | Sub-priority | Interrupt | | Output Compare 11 | _OUTPUT_COMPARE_11_VECTOR | 202 | OFF202<17:1> | IFS6<10> | IEC6<10> | IPC50<20:18> | IPC50<17:16> | Yes | | Input Capture 12 Error | _INPUT_CAPTURE_12_ERROR_VECTOR | 203 | OFF203<17:1> | IFS6<11> | IEC6<11> | IPC50<28:26> | IPC50<25:24> | Yes | | Input Capture 12 | _INPUT_CAPTURE_12_VECTOR | 204 | OFF204<17:1> | IFS6<12> | IEC6<12> | IPC51<4:2> | IPC51<1:0> | Yes | | Output Compare 12 | _OUTPUT_COMPARE_12_VECTOR | 205 | OFF205<17:1> | IFS6<13> | IEC6<13> | IPC51<12:10> | IPC51<9:8> | Yes | | Input Capture 13 Error | _INPUT_CAPTURE_13_ERROR_VECTOR | 206 | OFF206<17:1> | IFS6<14> | IEC6<14> | IPC51<20:18> | IPC51<17:16> | Yes | | Input Capture 13 | _INPUT_CAPTURE_13_VECTOR | 207 | OFF207<17:1> | IFS6<15> | IEC6<15> | IPC51<28:26> | IPC51<25:24> | Yes | | Output Compare 13 | _OUTPUT_COMPARE_13_VECTOR | 208 | OFF208<17:1> | IFS6<16> | IEC6<16> | IPC52<4:2> | IPC52<1:0> | Yes | | Input Capture 14 Error | _INPUT_CAPTURE_14_ERROR_VECTOR | 209 | OFF209<17:1> | IFS6<17> | IEC6<17> | IPC52<12:10> | IPC52<9:8> | Yes | | Input Capture 14 | _INPUT_CAPTURE_14_VECTOR | 210 | OFF210<17:1> | IFS6<18> | IEC6<18> | IPC52<20:18> | IPC52<17:16> | Yes | | Output Compare 14 | _OUTPUT_COMPARE_14_VECTOR | 211 | OFF211<17:1> | IFS6<19> | IEC6<19> | IPC52<28:26> | IPC52<25:24> | Yes | | Input Capture 15 Error | _INPUT_CAPTURE_15_ERROR_VECTOR | 212 | OFF212<17:1> | IFS6<20> | IEC6<20> | IPC53<4:2> | IPC53<1:0> | Yes | | Input Capture 15 | _INPUT_CAPTURE_15_VECTOR | 213 | OFF213<17:1> | IFS6<21> | IEC6<21> | IPC53<12:10> | IPC53<9:8> | Yes | | Output Compare 15 | _OUTPUT_COMPARE_15_VECTOR | 214 | OFF214<17:1> | IFS6<22> | IEC6<22> | IPC53<20:18> | IPC53<17:16> | Yes | | Input Capture 16 Error | _INPUT_CAPTURE_16_ERROR_VECTOR | 215 | OFF215<17:1> | IFS6<23> | IEC6<23> | IPC53<28:26> | IPC53<25:24> | Yes | | Input Capture 16 | _INPUT_CAPTURE_16_VECTOR | 216 | OFF216<17:1> | IFS6<24> | IEC6<24> | IPC54<4:2> | IPC54<1:0> | Yes | | Output Compare 16 | _OUTPUT_COMPARE_16_VECTOR | 217 | OFF217<17:1> | IFS6<25> | IEC6<25> | IPC54<12:10> | IPC54<9:8> | Yes | | SPI3 Fault | _SPI3_FAULT_VECTOR | 218 | OFF218<17:1> | IFS6<26> | IEC6<26> | IPC54<20:18> | IPC54<17:16> | Yes | | SPI3 Receive Done | _SPI3_RX_VECTOR | 219 | OFF219<17:1> | IFS6<27> | IEC6<27> | IPC54<28:26> | IPC54<25:24> | Yes | | SPI3 Transfer Done | _SPI3_TX_VECTOR | 220 | OFF220<17:1> | IFS6<28> | IEC6<28> | IPC55<4:2> | IPC55<1:0> | Yes | | SPI4 Fault | _SPI4_FAULT_VECTOR | 221 | OFF221<17:1> | IFS6<29> | IEC6<29> | IPC55<12:10> | IPC55<9:8> | Yes | | SPI4 Receive Done | _SPI4_RX_VECTOR | 222 | OFF222<17:1> | IFS6<30> | IEC6<30> | IPC55<20:18> | IPC55<17:16> | Yes | | SPI4 Transfer Done | _SPI4_TX_VECTOR | 223 | OFF223<17:1> | IFS6<31> | IEC6<31> | IPC55<28:26> | IPC55<25:24> | Yes | | SPI5 Fault | _SPI5_FAULT_VECTOR | 224 | OFF224<17:1> | IFS7<0> | IEC7<0> | IPC56<4:2> | IPC56<1:0> | Yes | | SPI5 Receive Done | _SPI5_RX_VECTOR | 225 | OFF225<17:1> | IFS7<1> | IEC7<1> | IPC56<12:10> | IPC56<9:8> | Yes | | SPI5 Transfer Done | _SPI5_TX_VECTOR | 226 | OFF226<17:1> | IFS7<2> | IEC7<2> | IPC56<20:18> | IPC56<17:16> | Yes | | SPI6 Fault | _SPI6_FAULT_VECTOR | 227 | OFF227<17:1> | IFS7<3> | IEC7<3> | IPC56<28:26> | IPC56<25:24> | Yes | | SPI6 Receive Done | _SPI6_RX_VECTOR | 228 | OFF228<17:1> | IFS7<4> | IEC7<4> | IPC57<4:2> | IPC57<1:0> | Yes | | SPI6 Transfer Done | _SPI6_TX_VECTOR | 229 | OFF229<17:1> | IFS7<5> | IEC7<5> | IPC57<12:10> | IPC57<9:8> | Yes | | System Bus Protection Violation | _SYSTEM_BUS_PROTECTION_VECTOR | 230 | OFF230<17:1> | IFS7<6> | IEC7<6> | IPC57<20:18> | IPC57<17:16> | Yes | | Reserved | _ | 231 | _ | _ | _ | _ | _ | _ | | Reserved | _ | 232 | _ | _ | _ | _ | _ | _ | <sup>2:</sup> This interrupt source is not available on 64-pin devices. <sup>3:</sup> This interrupt source is not available on 100-pin devices. DS60001519E-page 135 **TABLE 8-3**: INTERRUPT IRQ, VECTOR AND BIT LOCATION (CONTINUED) | Interrupt Source <sup>(1)</sup> | VC22 Vastar Nama | IRQ | V | | Interru | ıpt Bit Location | | Persistent | |------------------------------------------------------------|------------------------------|-----|--------------|----------|----------|------------------|--------------|------------| | Interrupt Source | XC32 Vector Name | # | Vector # | Flag | Enable | Priority | Sub-priority | Interrupt | | Reserved | | 233 | _ | _ | _ | _ | _ | _ | | Reserved | _ | 234 | | _ | | _ | _ | _ | | Reserved | _ | 235 | | _ | | _ | _ | _ | | Reserved | _ | 236 | | _ | | _ | _ | _ | | Reserved | _ | 237 | | _ | | _ | _ | _ | | PWM7 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM7_VECTOR | 238 | OFF238<17:1> | IFS7<14> | IEC7<14> | IPC59<20:18> | IPC59<17:16> | No | | PWM8 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM8_VECTOR | 239 | OFF239<17:1> | IFS7<15> | IEC7<15> | IPC59<28:26> | IPC59<25:24> | No | | PWM9 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM9_VECTOR | 240 | OFF240<17:1> | IFS7<16> | IEC7<16> | IPC60<4:2> | IPC60<1:0> | No | | PWM10 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM10_VECTOR | 241 | OFF241<17:1> | IFS7<17> | IEC7<17> | IPC60<12:10> | IPC60<9:8> | No | | PWM11 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM11_VECTOR | 242 | OFF242<17:1> | IFS7<18> | IEC7<18> | IPC60<20:18> | IPC60<17:16> | No | | PWM12 Interrupt (Period, Fault,<br>Trigger, Current-Limit) | _PWM12_VECTOR | | OFF243<17:1> | IFS7<19> | IEC7<19> | IPC60<28:26> | IPC60<25:24> | No | | USB2 Combined Interrupt <sup>(2)</sup> | _USB_2_VECTOR | 244 | OFF244<17:1> | IFS7<20> | IEC7<20> | IPC61<4:2> | IPC61<1:0> | Yes | | ADC Digital Comparator 3 | _ADC_DC3_VECTOR | 245 | OFF245<17:1> | IFS7<21> | IEC7<21> | IPC61<12:10> | IPC61<9:8> | Yes | | ADC Digital Comparator 4 | _ADC_DC4_VECTOR | 246 | OFF246<17:1> | IFS7<22> | IEC7<22> | IPC61<20:18> | IPC61<17:16> | Yes | | Prefetch Cache Event | _PCACHE_VECTOR | 247 | OFF247<17:1> | IFS7<23> | IEC7<23> | IPC61<28:26> | IPC61<25:24> | Yes | | Reserved | I | 248 | 1 | _ | 1 | 1 | _ | _ | | Reserved | ı | 249 | 1 | _ | 1 | 1 | | _ | | Reserved | I | 250 | 1 | _ | 1 | 1 | _ | _ | | Reserved | | 251 | _ | _ | _ | _ | _ | _ | | Reserved | | 252 | _ | _ | _ | _ | _ | _ | | Reserved | | 253 | | _ | _ | _ | _ | _ | | Core Performance Counter Interrupt | _CORE_PERF_COUNT_VECTOR | 254 | OFF254<17:1> | IFS7<30> | IEC7<30> | IPC63<20:18> | IPC63<17:16> | _ | | Fast Debug Channel Interrupt | _CORE_FAST_DEBUG_CHAN_VECTOR | 255 | OFF255<17:1> | IFS7<31> | IEC7<31> | IPC63<28:26> | IPC63<25:24> | _ | Lowest Natural Order Priority <sup>2:</sup> This interrupt source is not available on 64-pin devices. <sup>3:</sup> This interrupt source is not available on 100-pin devices. ### 8.3 Interrupt Control Registers ### TABLE 8-4: INTERRUPT REGISTER MAP | ess) | | 9 | | | | | | | | В | its | | | | | | | | Ø | |-----------------------------|---------------------------------|---------------|----------|----------|----------|-----------------------|-----------------------|----------|------------|-----------------------|-----------------------|----------|----------|-----------------------|----------|----------|----------|----------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0000 | INTCON | 31:16 | | | | SWNN | IIKEY<7:0> | | | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 0000 | INTCON | 15:0 | _ | | _ | MVEC | _ | | TPC<2:0> | | _ | _ | - | INT4EP | INT3EP | INT2EP | INT1EP | INT0EP | 0000 | | 0010 | PRISS | 31:16 | | PRI7S | S<3:0> | | | PRI6SS | S<3:0> | | | PRI5S | S<3:0> | | | PRI4S | S<3:0> | | 0000 | | 0010 | FNISS | 15:0 | | PRI3S | S<3:0> | | | PRI2SS | S<3:0> | | | PRI1S | S<3:0> | | _ | _ | _ | SS0 | 0000 | | 0020 | INTSTAT | 31:16 | _ | | _ | _ | _ | | _ | _ | _ | _ | - | - | _ | _ | _ | _ | 0000 | | 0020 | INTOTAL | 15:0 | _ | - | _ | _ | _ | | SRIPL<2:0> | | | | | SIRQ< | 7:0> | | | | 0000 | | 0030 | IPTMR | 31:16<br>15:0 | | | | | | | | IPTMR | <31:0> | | | | | | | | 0000 | | 0040 | IFS0 <sup>(7)</sup> | 31:16 | FCEIF | RTCCIF | _ | _ | OC5IF | IC5IF | IC5EIF | T5IF | INT4IF | OC4IF | IC4IF | IC4EIF | T4IF | INT3IF | OC3IF | IC3IF | 0000 | | | | 15:0 | IC3EIF | T3IF | INT2IF | OC2IF | IC2IF | IC2EIF | T2IF | INT1IF | OC1IF | IC1IF | IC1EIF | T1IF | INT0IF | CS1IF | CS0IF | CTIF | 0000 | | 0050 | IFS1 <sup>(7)</sup> | 31:16 | U3RXIF | U3EIF | _ | _ | | U2TXIF | U2RXIF | U2EIF | SPI2TXIF | SPI2RXIF | SPI2EIF | PMPEIF | PMPIF | CNGIF | CNFIF | CNEIF | 0000 | | | | 15:0 | CNDIF | CNCIF | CNBIF | CNAIF | 1 | _ | _ | U1TXIF | U1RXIF | U1EIF | SPI1TXIF | SPI1RXIF | SPI1EIF | USB1IF | CMP2IF | CMP1IF | 0000 | | 0060 | IFS2 <sup>(7)</sup> | 31:16 | AD1DC2IF | AD1DC1IF | _ | AD1IF | OC9IF | IC9IF | IC9EIF | T9IF | OC8IF | IC8IF | IC8EIF | T8IF | OC7IF | IC7IF | IC7EIF | T7IF | 0000 | | | | 15:0 | OC6IF | IC6IF | IC6EIF | T6IF | DMA3IF | DMA2IF | DMA1IF | DMA0IF | CTMUIF | U5TXIF | U5RXIF | U5EIF | U4TXIF | U4RXIF | U4EIF | U3TXIF | 0000 | | 0070 | IFS3 <sup>(7)</sup> | 31:16 | AD1D21IF | AD1D20IF | AD1D19IF | AD1D18IF | AD1D17IF | AD1D16IF | AD1D15IF | AD1D14IF | AD1D13IF | AD1D12IF | AD1D11IF | AD1D10IF | AD1D9IF | AD1D8IF | AD1D7IF | AD1D6IF | 0000 | | | | 15:0 | AD1D5IF | AD1D4IF | AD1D3IF | AD1D2IF | AD1D1IF | AD1D0IF | AD1G1IF | AD1FCBTIF | AD1RSIF | AD1ARIF | AD1EOSIF | AD1F1IF | AD1DF4IF | AD1DF3IF | AD1DF2IF | AD1DF1IF | 0000 | | 0800 | IFS4 <sup>(7)</sup> | 31:16 | AD1D53IF | | _ | AD1D50IF | AD1D49IF | AD1D48IF | AD1D47IF | AD1D46IF | AD1D45IF | _ | - | - | AD1D41IF | AD1D40IF | AD1D39IF | AD1D38IF | 0000 | | | | 15:0 | AD1D37IF | AD1D36IF | | AD1D34IF | AD1D33IF | _ | _ | _ | | _ | AD1D27IF | AD1D26IF | AD1D25IF | AD1D24IF | AD1D23IF | AD1D22IF | 0000 | | 0090 | IFS5 <sup>(7)</sup> | 31:16 | QEI5IF | QEI4IF | QEI3IF | CAN4IF <sup>(3)</sup> | CAN3IF <sup>(3)</sup> | DATAEEIF | DMA7IF | DMA6IF | DMA5IF | DMA4IF | _ | _ | _ | PWM6IF | PWM5IF | PWM4IF | 0000 | | | | 15:0 | PWM3IF | PWM2IF | PWM1IF | PWM<br>SEVTIF | PWM<br>PEVTIF | QEI2IF | QEI1IF | CAN2IF <sup>(3)</sup> | CAN1IF <sup>(3)</sup> | U6TXIF | U6RXIF | U6EIF | _ | CMP5IF | CMP4IF | CMP3IF | 0000 | | 00A0 | IFS6 <sup>(7)</sup> | 31:16 | SPI4TXIF | SPI4RXIF | SPI4EIF | SPI3TXIF | SPI3RXIF | SPI3EIF | OC16IF | IC16IF | IC16EIF | OC15IF | IC15IF | IC15EIF | OC14IF | C14IF | IC14EIF | OC13IF | 0000 | | | | 15:0 | IC13IF | IC13EIF | OC12IF | IC12IF | IC12EIF | OC11IF | IC11IF | IC11EIF | OC10IF | IC10IF | IC10EIF | _ | _ | _ | _ | QEI6IF | 0000 | | 00B0 | IFS7 <sup>(7)</sup> | 31:16 | _ | CPCIF | _ | _ | | - | _ | _ | _ | AD1DC4IF | AD1DC3IF | USB2IF <sup>(2)</sup> | PWM12IF | PWM11IF | PWM10IF | PWM9IF | 0000 | | | | 15:0 | PWM8IF | PWM7IF | _ | _ | _ | _ | _ | _ | | SBIF | SPI6TXIF | SPI6RXIF | SPI6EIF | SPI5TXIF | SPI5RXIF | SPI5EIF | 0000 | | 00C0 | IEC0 | 31:16 | FCEIE | RTCCIE | - | - | OC5IE | IC5IE | IC5EIE | T5IE | INT4IE | OC4IE | IC4IE | IC4EIE | T4IE | INT3IE | OC3IE | IC3IE | 0000 | | | | 15:0 | IC3EIE | T3IE | INT2IE | OC2IE | IC2IE | IC2EIE | T2IE | INT1IE | OC1IE | IC1IE | IC1EIE | T1IE | INT0IE | CS1IE | CS0IE | CTIE | 0000 | PIC32MK GPK/MCM with CAN FD Family - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. - 2: This bit is not available on 64-pin devices. - 3: This bit is not available on devices without a CAN module. - 4: This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - 6: Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. **INTERRUPT REGISTER MAP (CONTINUED) TABLE 8-4:** | ress<br>t) | ١. | <u>e</u> | | | | | | | | В | its | | | | | | | | ţ | |-----------------------------|---------------------------------|-----------|----------|----------|----------|-----------------------|-----------------------|----------|------------|-----------------------|-----------------------|----------|----------|-----------------------|-------------|----------------|----------|----------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 00D0 | IEC1 | 31:16 | U3RXIE | U3EIE | _ | _ | _ | U2TXIE | U2RXIE | U2EIE | SPI2TXIE | SPI2RXIE | SPI2EIE | PMPEIE | PMPIE | CNGIE | CNFIE | CNEIE | 0000 | | | | 15:0 | CNDIE | CNCIE | CNBIE | CNAIE | _ | _ | _ | U1TXIE | U1RXIE | U1EIE | SPI1TXIE | SPI1RXIE | SPI1EIE | USB1IE | CMP2IE | CMP1IE | 0000 | | 00E0 | IEC2 | 31:16 | AD1DC2IE | AD1DC1IE | - | AD1IE | OC9IE | IC9IE | IC9EIE | T9IE | OC8IE | IC8IE | IC8EIE | T8IE | OC7IE | IC7IE | IC7EIE | T7IE | 0000 | | | | 15:0 | OC6IE | IC6IE | IC6EIE | T6IE | DMA3IE | DMA2IE | DMA1IE | DMA0IE | CTMUIE | U5TXIE | U5RXIE | U5EIE | U4TXIE | U4RXIE | U4EIE | U3TXIE | 0000 | | 00F0 | IEC3 | 31:16 | AD1D21IE | AD1D20IE | AD1D19IE | AD1D18IE | AD1D17IE | AD1D16IE | AD1D15IE | AD1D14IE | AD1D13IE | AD1D12IE | AD1D11IE | AD1D10IE | AD1D09IE | AD1D08IE | AD1D07IE | AD1D06IE | 0000 | | | | 15:0 | AD1D05IE | AD1D04IE | AD1D03IE | AD1D02IE | AD1D01IE | AD1D00IE | AD1G1IE | AD1FCBTIE | AD1RSIE | AD1ARIE | AD1EOSIE | AD1F1IE | AD1DF4IE | AD1DF3IE | AD1DF2IE | AD1DF1IE | 0000 | | 0100 | IEC4 | 31:16 | AD1D53IE | | | AD1D50IE | AD1D49IE | AD1D48IE | AD1D47IE | AD1D46IE | AD1D45IE | _ | _ | 1 | AD1D41IE | AD1D40IE | AD1D39IE | AD1D38IE | 0000 | | | | 15:0 | AD1D37IE | AD1D36IE | AD1D35IE | AD1D34IE | AD1D33IE | | 1 | _ | _ | _ | AD1D27IE | AD1D26IE | AD1D25IE | AD1D24IE | AD1D23IE | AD1D22IE | 0000 | | 0110 | IEC5 | 31:16 | QEI5IE | QEI4IE | QEI3IE | CAN4IE <sup>(3)</sup> | CAN3IE <sup>(3)</sup> | DATAEEIE | DMA7IE | DMA6IE | DMA5IE | DMA4IE | _ | - | _ | PWM6IE | PWM5IE | PWM4IE | 0000 | | | | 15:0 | PWM3IE | PWM2IE | PWM1IE | PWM<br>SEVTIE | PWM<br>PEVTIE | QEI2IE | QEI1IE | CAN2IE <sup>(3)</sup> | CAN1IE <sup>(3)</sup> | U6TXIE | U6RXIE | U6EIE | _ | CMP5IE | CMP4IE | CMP3IE | 0000 | | 0120 | IEC6 | 31:16 | SPI4TXIE | SPI4RXIE | SPI4EIE | SPI3TXIE | SPI3RXIE | SPI3EIE | OC16IE | IC16IE | IC16EIE | OC15IE | IC15IE | IC15EIE | OC14IE | C14IE | IC14EIE | OC13IE | 0000 | | | | 15:0 | IC13IE | IC13EIE | OC12IE | IC12IE | IC12EIE | OC11IE | IC11IE | IC11EIE | OC10IE | IC10IE | IC10EIE | | _ | _ | _ | QEI6IE | 0000 | | 0130 | IEC7 | 31:16 | _ | CPCIE | _ | _ | | _ | _ | _ | _ | AD1DC4IE | AD1DC3IE | USB2IE <sup>(2)</sup> | PWM12IE | PWM11IE | PWM10IE | PWM9IE | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | SBIE | SPI6TXIE | SPI6RXIE | SPI6EIE | SPI5TXIE | SPI5RXIE | SPI5EIE | 0000 | | 0140 | IPC0 | 31:16 | _ | _ | _ | | INT0IP<2:0> | | INT0IS | S<1:0> | _ | _ | _ | | CS1IP<2:0> | | CS1IS | <1:0> | 0000 | | 0140 | IPCU | 15:0 | _ | _ | _ | | CS0IP<2:0> | | CS0IS<1:0> | | _ | _ | _ | CTIP<2:0> | | CTIP<2:0> CTIS | | <1:0> | 0000 | | 0150 | IPC1 | 31:16 | _ | _ | _ | | OC1IP<2:0> | • | OC1IS | S<1:0> | _ | _ | _ | | IC1IP<2:0> | | IC1IS- | <1:0> | 0000 | | 0130 | IFCI | 15:0 | _ | _ | _ | | IC1EIP<2:0> | • | IC1EIS | S<1:0> | _ | _ | _ | | T1IP<2:0> | | T1IS< | :1:0> | 0000 | | 0160 | IPC2 | 31:16 | _ | | _ | | IC2IP<2:0> | | IC2IS | <1:0> | _ | _ | _ | | IC2EIP<2:0 | > | IC2EIS | <1:0> | 0000 | | 0160 | IPC2 | 15:0 | _ | _ | _ | | T2IP<2:0> | | T2IS< | <1:0> | _ | _ | _ | | INT1IP<2:0> | > | INT1IS | i<1:0> | 0000 | | 0170 | IPC3 | 31:16 | _ | _ | _ | | IC3EIP<2:0> | • | IC3EIS | S<1:0> | _ | _ | _ | | T3IP<2:0> | | T3IS< | :1:0> | 0000 | | 0170 | IF C3 | 15:0 | _ | | _ | | INT2IP<2:0> | • | INT2IS | S<1:0> | _ | _ | _ | | OC2IP<2:0> | • | OC2IS | <1:0> | 0000 | | 0180 | IPC4 | 31:16 | _ | | | | T4IP<2:0> | | T4IS< | <1:0> | _ | _ | _ | | INT3IP<2:0> | > | INT3IS | <1:0> | 0000 | | 0100 | IFC4 | 15:0 | _ | I | _ | | OC3IP<2:0> | | OC3IS | S<1:0> | _ | _ | _ | | IC3IP<2:0> | | IC3IS- | <1:0> | 0000 | | 0190 | IPC5 | 31:16 | _ | 1 | _ | | INT4IP<2:0> | | INT4IS | S<1:0> | _ | _ | _ | | OC4IP<2:0> | • | OC4IS | <1:0> | 0000 | | 0190 | 11 00 | 15:0 | _ | _ | _ | | IC4IP<2:0> | | IC4IS | <1:0> | | _ | _ | | IC4EIP<2:0 | > | IC4EIS | S<1:0> | 0000 | | 01A0 | IPC6 | 31:16 | _ | _ | _ | | OC5IP<2:0> | • | OC5IS | S<1:0> | _ | _ | _ | | IC5IP<2:0> | | IC5IS- | <1:0> | 0000 | | OIAU | 00 | 15:0 | _ | _ | _ | | IC5EIP<2:0> | • | IC5EIS | S<1:0> | _ | _ | _ | | T5IP<2:0> | | T5IS< | <1:0> | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and **INV Registers**" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. TABLE 8-4: INTERRUPT REGISTER MAP (CONTINUED) | ress<br>:) | <b>L</b> _ | е | | | | | | | | Е | its | | | | | | | | S | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|--------------|-------|---------|--------|------|------|------|------|------------|------|---------|---------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 01B0 | IPC7 | 31:16 | _ | _ | _ | | FCEIP<2:0> | | FCEIS | <1:0> | _ | _ | _ | ı | RTCCIP<2:0 | > | RTCCIS | S<1:0> | 0000 | | 0160 | IPC/ | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 01C0 | IPC8 | 31:16 | | _ | _ | | SPI1EIP<2:0 | > | SPI1EIS | S<1:0> | _ | - | - | | USB1IP<2:0 | > | USB1IS | S<1:0> | 0000 | | 0100 | 0 | 15:0 | _ | _ | _ | | CMP2IP<2:0 | > | CMP2IS | S<1:0> | _ | _ | _ | ( | CMP1IP<2:0 | > | CMP1IS | S<1:0> | 0000 | | 01D0 | IPC9 | 31:16 | | 1 | - | | U1RXIP<2:0 | > | U1RXIS | S<1:0> | _ | 1 | 1 | | U1EIP<2:0 | | U1EIS | <1:0> | 0000 | | OIDO | 11 03 | 15:0 | _ | _ | | | SPI1TXIP<2:0 | )> | SPI1TXI | S<1:0> | _ | _ | _ | S | PI1RXIP<2: | 0> | SPI1RXI | IS<1:0> | 0000 | | 01E0 | IPC10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | OILO | 11 010 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | U1TXIP<2:0 | > | U1TXIS | S<1:0> | 0000 | | 01F0 | IPC11 | 31:16 | | _ | _ | | CNDIP<2:0> | • | CNDIS | <1:0> | _ | - | - | | CNCIP<2:0 | > | CNCIS | <1:0> | 0000 | | 011 0 | | 15:0 | _ | _ | _ | | CNBIP<2:0> | • | CNBIS | <1:0> | _ | _ | _ | | CNAIP<2:0 | > | CNAIS | <1:0> | 0000 | | 0200 | IPC12 | 31:16 | _ | _ | _ | | PMPIP<2:0> | • | PMPIS | <1:0> | _ | _ | _ | | CNGIP<2:0 | > | CNGIS | S<1:0> | 0000 | | 0200 | 11 012 | 15:0 | _ | _ | | | CNFIP<2:0> | | CNFIS | <1:0> | _ | _ | _ | | CNEIP<2:0 | • | CNEIS | <1:0> | 0000 | | 0210 | IPC13 | 31:16 | _ | _ | | | SPI2TXIP<2:0 | )> | SPI2TXI | S<1:0> | _ | _ | _ | S | PI2RXIP<2: | 0> | SPI2RXI | IS<1:0> | 0000 | | 0210 | 11 010 | 15:0 | _ | _ | _ | | SPI2EIP<2:0 | > | SPI2EIS | S<1:0> | _ | _ | _ | F | PMPEIP<2:0 | > | PMPEIS | S<1:0> | 0000 | | 0220 | IPC14 | 31:16 | _ | _ | | _ | _ | _ | _ | | _ | _ | _ | | U2TXIP<2:0 | > | U2TXIS | S<1:0> | 0000 | | 0220 | 11 014 | 15:0 | _ | _ | _ | | U2RXIP<2:0 | > | U2RXIS | S<1:0> | _ | _ | _ | | U2EIP<2:0 | • | U2EIS | <1:0> | 0000 | | 0230 | IPC15 | 31:16 | _ | _ | _ | | U3RXIP<2:0 | > | U3RXIS | S<1:0> | _ | _ | _ | | U3EIP<2:0> | | U3EIS | <1:0> | 0000 | | 0200 | 11 010 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0240 | IPC16 | 31:16 | _ | _ | _ | | U4TXIP<2:0 | > | U4TXIS | S<1:0> | _ | _ | _ | | U4RXIP<2:0 | > | U4RXIS | S<1:0> | 0000 | | 0240 | 11 010 | 15:0 | _ | _ | _ | | U4EIP<2:0> | • | U4EIS | <1:0> | _ | _ | _ | | U3TXIP<2:0 | > | U3TXIS | S<1:0> | 0000 | | 0250 | IPC17 | 31:16 | _ | _ | | | CTMUIP<2:0 | > | CTMUIS | S<1:0> | _ | _ | _ | | U5TXIP<2:0 | > | U5TXIS | S<1:0> | 0000 | | 0250 | 11 017 | 15:0 | _ | _ | | | U5RXIP<2:0: | > | U5RXIS | S<1:0> | _ | _ | _ | | U5EIP<2:0> | • | U5EIS | <1:0> | 0000 | | 0260 | IPC18 | 31:16 | _ | _ | _ | | DMA3IP<2:0 | > | DMA3IS | S<1:0> | _ | _ | _ | [ | DMA2IP<2:0 | > | DMA2IS | S<1:0> | 0000 | | 0200 | 11 010 | 15:0 | _ | _ | _ | | DMA1IP<2:0 | > | DMA1IS | S<1:0> | _ | _ | _ | I | DMA0IP<2:0 | > | DMA0IS | S<1:0> | 0000 | | 0270 | IPC19 | 31:16 | _ | _ | _ | | OC6IP<2:0> | • | OC6IS | <1:0> | _ | _ | _ | | IC6IP<2:0> | | IC6IS | <1:0> | 0000 | | 0270 | 1-019 | 15:0 | | _ | _ | | IC6EIP<2:0> | • | IC6EIS | <1:0> | _ | _ | - | | T6IP<2:0> | | T6IS< | :1:0> | 0000 | | 0280 | IPC20 | 31:16 | _ | _ | _ | | OC7IP<2:0> | | OC7IS | <1:0> | _ | _ | _ | | IC7IP<2:0> | | IC7IS | <1:0> | 0000 | | 0200 | IF 020 | 15:0 | _ | _ | _ | | IC7EIP<2:0> | • | IC7EIS | <1:0> | _ | _ | _ | | T7IP<2:0> | | T7IS< | :1:0> | 0000 | - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. - 2: This bit is not available on 64-pin devices. - 3: This bit is not available on devices without a CAN module. - 4: This bit is not available on 100-pin devices. - 5: Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - 6: Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. **INTERRUPT REGISTER MAP (CONTINUED) TABLE 8-4:** | ress<br>t) | ٠. | 9 | | | | | | | | Е | lits | | | | | | | | S | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|---------------|-------|---------------|---------|------|------|------|----------------|------------|---------|-------------|---------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0200 | IPC21 | 31:16 | _ | _ | _ | | OC8IP<2:0> | , | OC8IS | <1:0> | _ | _ | _ | | IC8IP<2:0> | | IC8IS< | <1:0> | 0000 | | 0290 | IPC21 | 15:0 | _ | _ | _ | | IC8EIP<2:0> | > | IC8EIS | <1:0> | _ | _ | _ | | T8IP<2:0> | | T8IS< | :1:0> | 0000 | | 02A0 | IPC22 | 31:16 | _ | _ | _ | | OC9IP<2:0> | • | OC9IS | <1:0> | _ | _ | _ | | IC9IP<2:0> | | IC9IS | <1:0> | 0000 | | 02A0 | 11-022 | 15:0 | _ | | _ | | IC9EIP<2:0> | > | IC9EIS | <1:0> | _ | - | | | T9IP<2:0> | | T9IS< | :1:0> | 0000 | | 02B0 | IPC23 | 31:16 | _ | | - | P | AD1DC2IP<2: | 0> | AD1DC2 | IS<1:0> | _ | 1 | 1 | Al | D1DC1IP<2: | 0> | AD1DC1 | IS<1:0> | 0000 | | 0260 | IF 023 | 15:0 | _ | | _ | _ | - | _ | _ | _ | _ | - | - | | AD1IP<2:0> | | AD1IS | <1:0> | 0000 | | 02C0 | IPC24 | 31:16 | _ | _ | _ | A | AD1DF4IP<2: | 0> | AD1DF4 | IS<1:0> | _ | _ | _ | Al | D1DF3IP<2: | 0> | AD1DF3 | IS<1:0> | 0000 | | 0200 | 11 024 | 15:0 | _ | _ | _ | A | AD1DF2IP<2: | 0> | AD1DF2 | IS<1:0> | _ | _ | _ | Al | D1DF1IP<2: | 0> | AD1DF1 | IS<1:0> | 0000 | | 02D0 | IPC25 | 31:16 | _ | _ | | | AD1RSIP<2:0> | | AD1RSI | S<1:0> | _ | _ | _ | AD1ARIP<2:0> | | | AD1ARIS<1 | | 0000 | | 0200 | 11 020 | 15:0 | _ | _ | | Α | AD1EOSIP<2:0> | | AD1EOS | IS<1:0> | _ | _ | _ | AD1F1IP<2:0> | | | AD1F1IS<1:0 | | 0000 | | 02E0 | IPC26 | 31:16 | _ | _ | _ | A | AD1D01IP<2:0> | | AD1D01 | IS<1:0> | _ | _ | _ | AD1D00IP<2:0> | | | AD1D00IS<1 | | 0000 | | OZLO | 11 020 | 15:0 | _ | _ | | | AD1G1IP<2:0 | )> | AD1G1I | S<1:0> | _ | _ | _ | AD1FCBTIP<2:0> | | AD1FCB1 | TIS<1:0> | 0000 | | | 02F0 | IPC27 | 31:16 | _ | _ | | _ | _ | _ | _ | | _ | _ | _ | AD1D04IP<2:0> | | AD1D04 | IS<1:0> | 0000 | | | 021 0 | 11 027 | 15:0 | _ | _ | | F | AD1D03IP<2: | 0> | AD1D03IS<1:0> | | _ | _ | _ | AD1D02IP<2:0> | | AD1D02 | IS<1:0> | 0000 | | | 0300 | IPC28 | 31:16 | _ | _ | _ | P | AD1D09IP<2: | 0> | AD1D09IS<1:0> | | _ | _ | _ | AD1D08IP<2:0> | | AD1D08 | IS<1:0> | 0000 | | | 0000 | 11 020 | 15:0 | _ | _ | | P | AD1D07IP<2: | 0> | AD1D07 | IS<1:0> | _ | _ | _ | A | D1D06IP<2: | 0> | AD1D06 | IS<1:0> | 0000 | | 0310 | IPC29 | 31:16 | _ | _ | | F | AD1D13IP<2: | 0> | AD1D13 | IS<1:0> | _ | _ | _ | Α | D1D12IP<2: | 0> | AD1D12 | IS<1:0> | 0000 | | 0310 | 11 029 | 15:0 | _ | _ | | A | AD1D11IP<2: | 0> | AD1D11 | IS<1:0> | _ | _ | _ | A | D1D10IP<2: | 0> | AD1D10 | IS<1:0> | 0000 | | 0320 | IPC30 | 31:16 | _ | _ | | F | AD1D17IP<2: | 0> | AD1D17 | IS<1:0> | _ | _ | _ | Α | D1D16IP<2: | 0> | AD1D16 | IS<1:0> | 0000 | | 0320 | 11 030 | 15:0 | _ | _ | _ | A | AD1D15IP<2: | 0> | AD1D15 | IS<1:0> | _ | _ | _ | Α | D1D14IP<2: | 0> | AD1D14 | IS<1:0> | 0000 | | 0330 | IPC31 | 31:16 | _ | _ | _ | A | AD1D21IP<2: | 0> | AD1D21 | IS<1:0> | _ | _ | _ | A | D1D20IP<2: | 0> | AD1D20 | IS<1:0> | 0000 | | 0330 | 1 031 | 15:0 | _ | _ | _ | A | AD1D19IP<2: | 0> | AD1D19 | IS<1:0> | _ | _ | _ | A | D1D18IP<2: | 0> | AD1D18 | IS<1:0> | 0000 | | 0340 | IPC32 | 31:16 | _ | | - | A | AD1D25IP<2: | 0> | AD1D25 | IS<1:0> | _ | 1 | 1 | A | D1D24IP<2: | 0> | AD1D24 | IS<1:0> | 0000 | | 0340 | 11 032 | 15:0 | _ | I | - | A | AD1D23IP<2: | 0> | AD1D23 | IS<1:0> | _ | - | ı | A | D1D22IP<2: | 0> | AD1D22 | IS<1:0> | 0000 | | 0350 | IPC33 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0330 | 12033 | 15:0 | _ | _ | _ | - A | AD1D27IP<2: | 0> | AD1D27 | IS<1:0> | _ | _ | _ | A | D1D26IP<2: | 0> | AD1D26 | IS<1:0> | 0000 | | 0360 | IPC34 | 31:16 | _ | - | _ | | AD1D33IP<2: | 0> | AD1D33 | IS<1:0> | _ | | _ | | _ | | _ | _ | 0000 | | 0360 | 12034 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | TABLE 8-4: INTERRUPT REGISTER MAP | (CONTINUED) | |-----------------------------------|-------------| |-----------------------------------|-------------| | ddress | <b>-</b> - | 0 | | Bits | | | | | | | | | | | | | | ι | | |------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------------|-------|---------|----------------------|------|------|------|------|-------------|------|---------------------|----------------------|------------| | Virtual Add<br>(BF81_# | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | IPC35 | 31:16 | _ | _ | _ | F | AD1D37IP<2: | 0> | AD1D37 | IS<1:0> | _ | _ | _ | А | D1D36IP<2: | :0> | AD1D36 | IS<1:0> | 000 | | 0370 | IPC35 | 15:0 | _ | _ | _ | P | AD1D35IP<2: | 0> | AD1D35 | IS<1:0> | _ | _ | _ | A | D1D34IP<2: | :0> | AD1D34 | IS<1:0> | 000 | | 0380 | IPC36 | 31:16 | _ | _ | _ | F | AD1D41IP<2: | 0> | AD1D41 | IS<1:0> | _ | _ | _ | A | D1D40IP<2: | :0> | AD1D40 | IS<1:0> | 000 | | 0360 | IF C30 | 15:0 | _ | _ | _ | A | AD1D39IP<2: | 0> | AD1D39 | IS<1:0> | _ | - | _ | A | D1D38IP<2: | <0> | AD1D38 | IS<1:0> | 000 | | 0390 | IPC37 | 31:16 | _ | - | _ | A | AD1D45IP<2: | 0> | AD1D45 | IS<1:0> | _ | - | _ | _ | _ | _ | _ | _ | 000 | | 0030 | 11 037 | 15:0 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 000 | | 03A0 | IPC38 | 31:16 | _ | _ | _ | F | AD1D49IP<2: | 0> | AD1D49 | IS<1:0> | _ | _ | _ | A | D1D48IP<2: | :0> | AD1D48 | IS<1:0> | 000 | | OOAO | 11 000 | 15:0 | _ | _ | _ | F | AD1D47IP<2: | 0> | AD1D47 | IS<1:0> | _ | _ | _ | A | D1D46IP<2: | 0> | AD1D46 | IS<1:0> | 000 | | 03B0 | IPC39 | 31:16 | _ | _ | _ | A | AD1D53IP<2: | 0> | AD1D53 | IS<1:0> | _ | _ | _ | _ | _ | _ | _ | _ | 000 | | ООВО | 11 000 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | A | D1D50IP<2: | 0> | AD1D50 | IS<1:0> | 000 | | 03C0 | IPC40 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ( | CMP5IP<2:0 | )> | CMP5IS | S<1:0> | 000 | | 0300 | 11 040 | 15:0 | _ | _ | _ | | CMP4IP<2:0 | | CMP4IS | | _ | _ | _ | ( | CMP3IP<2:0 | )> | CMP3I | S<1:0> | 000 | | 03D0 | IPC41 | 31:16 | _ | _ | _ | ( | CAN1IP<2:0> | .(3) | CAN1IS- | <1:0> <sup>(3)</sup> | _ | _ | _ | l | U6TXIP<2:0 | > | U6TXIS | S<1:0> | 000 | | 0000 | 11 041 | 15:0 | _ | _ | _ | | U6RXIP<2:0 | > | U6RXIS | S<1:0> | _ | _ | _ | | U6EIP<2:0> | > | U6EIS | <1:0> | 000 | | 03E0 | IPC42 | 31:16 | _ | _ | _ | P۱ | NMPEVTIP<2 | 2:0> | PWMSEV | TIP<1:0> | _ | _ | _ | II . | QEI2IP<2:0: | | QEI2SI | | 000 | | OOLO | 11 042 | 15:0 | _ | _ | _ | | QEI1IP<2:0 | > | QEI1SII | P<1:0> | _ | _ | _ | C | AN2IP<2:0> | .(3) | CAN2IS | <1:0> <sup>(3)</sup> | 000 | | 03F0 | IPC43 | 31:16 | _ | _ | _ | | PWM3IP<2:0 | )> | PWM3S | IP<1:0> | _ | _ | _ | F | PWM2IP<2:0 | )> | PWM2S | IP<1:0> | 000 | | 001 0 | 11 040 | 15:0 | _ | _ | _ | | PWM1IP<2:0 | )> | PWM1S | IP<1:0> | _ | _ | _ | PW | /MSEVTIP< | 2:0> | PWMSEV <sup>*</sup> | TSIP<1:0> | 000 | | 0400 | IPC44 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | F | PWM6IP<2:0 | )> | PWM6S | IP<1:0> | 000 | | 0400 | 11 044 | 15:0 | _ | _ | _ | | PWM5IP<2:0 | )> | PWM5S | IP<1:0> | _ | _ | _ | F | PWM4IP<2:0 | )> | PWM4S | IP<1:0> | 000 | | 0410 | IPC45 | 31:16 | _ | _ | _ | | DMA5IP<2:0 | )> | DMA5IS | S<1:0> | _ | _ | _ | | DMA4IP<2:0 | )> | DMA4I | S<1:0> | 000 | | 0410 | 11 040 | 15:0 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 000 | | 0420 | IPC46 | 31:16 | _ | _ | _ | ( | CAN3IP<2:0> | .(3) | CAN3IS- | <1:0> <sup>(3)</sup> | _ | _ | _ | D. | ATAEEIP<2: | :0> | DATAEE | IS<1:0> | 000 | | 0420 | 11 040 | 15:0 | _ | _ | _ | | DMA7IP<2:0 | > | DMA7IS | S<1:0> | _ | _ | _ | [ | DMA6IP<2:0 | )> | DMA6IS | S<1:0> | 000 | | 0430 | IPC47 | 31:16 | _ | _ | _ | | QEI5IP<2:0 | > | QEI5SII | P<1:0> | _ | _ | _ | | QEI4IP<2:0 | | QEI4SI | | 000 | | 0400 | 11 047 | 15:0 | - | _ | _ | | QEI3IP<2:0 | > | QEI3SII | P<1:0> | _ | _ | _ | С | AN4IP<2:0> | (3) | CAN4IS | <1:0> <sup>(3)</sup> | 000 | | 0440 | IPC48 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 000 | | U <del>-1-1</del> U | 11 040 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEI6IP<2:0 | > | QEI6SI | P<1:0> | 000 | - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and **INV Registers**" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. **INTERRUPT REGISTER MAP (CONTINUED) TABLE 8-4**: | ress<br>t) | ١. | <u>e</u> | | | | | | | | Е | its | | | | | | | | ŝ | |-----------------------------|---------------------------------|-----------|-------|-------|-------|---------------|--------------------------|-------|---------------|----------|------|------|------|---------------|------------|--------|----------------|----------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0450 | IPC49 | 31:16 | _ | _ | _ | | OC10IP<2:0 | > | OC10IS | S<1:0> | _ | _ | _ | | IC10IP<2:0 | > | IC10IS | S<1:0> | 0000 | | 0430 | IF C49 | 15:0 | | | | | IC10EIP<2:0 | > | IC10EI | S<1:0> | _ | 1 | _ | _ | _ | _ | _ | _ | 0000 | | 0460 | IPC50 | 31:16 | _ | | _ | | IC12EIP<2:0 | > | IC12EI | S<1:0> | _ | - | _ | ( | OC11IP<2:0 | > | OC111 | S<1:0> | 0000 | | 0400 | IF C50 | 15:0 | _ | | _ | | IC11IP<2:0> | • | IC11IS | S<1:0> | _ | ı | _ | ı | C11EIP<2:0 | > | IC11EI | S<1:0> | 0000 | | 0470 | IPC51 | 31:16 | | | | | IC13IP<2:0> | | IC13IS | S<1:0> | _ | 1 | _ | I | C13EIP<2:0 | > | IC13EI | S<1:0> | 0000 | | 0470 | IFCST | 15:0 | _ | | _ | | OC12IP<2:0 | > | OC1218 | S<1:0> | _ | - | _ | | IC12IP<2:0 | > | IC12IS | S<1:0> | 0000 | | 0480 | IPC52 | 31:16 | | | | | OC14IP<2:0 | > | OC14IS | S<1:0> | _ | 1 | _ | | C14IP<2:0> | | C14IS | <1:0> | 0000 | | 0480 | IF C52 | 15:0 | | | | | IC14EIP<2:0 | > | IC14EI | S<1:0> | _ | 1 | _ | ( | OC13IP<2:0 | > | OC131 | S<1:0> | 0000 | | 0490 | IPC53 | 31:16 | _ | | _ | | IC16EIP<2:0> IC15IP<2:0> | | | S<1:0> | _ | - | _ | ( | OC15IP<2:0 | > | OC15I | S<1:0> | 0000 | | 0490 | 11 000 | 15:0 | _ | _ | _ | | 17.7 | | | S<1:0> | _ | _ | _ | IC15EIP<2:0> | | | IC15EIS<1:0 | | 0000 | | 04A0 | IPC54 | 31:16 | _ | 1 | _ | • | SPI3RXIP<2:0> | | | IS<1:0> | _ | _ | _ | SPI3EIP<2:0> | | | SPI3EIS<1:0> | | 0000 | | 0470 | 11 034 | 15:0 | _ | | _ | | OC16IP<2:0> | | | S<1:0> | _ | - | _ | IC16IP<2:0 | | | IC16IS | S<1:0> | 0000 | | 04B0 | IPC55 | 31:16 | _ | _ | _ | ; | SPI4TXIP<2:0 | )> | SPI4TX | IS<1:0> | _ | _ | _ | SPI4RXIP<2:0> | | | SPI4RX | IS<1:0> | 0000 | | 0400 | 11 000 | 15:0 | _ | _ | _ | | SPI4EIP<2:0 | > | SPI4EIS<1:0> | | _ | _ | _ | S | PI3TXIP<2: | 0> | SPI3TX | IS<1:0> | 0000 | | 04C0 | IPC56 | 31:16 | _ | _ | _ | | SPI6EIP<2:0 | > | SPI6EIS<1:0> | | _ | _ | _ | SPI5TXIP<2:0> | | SPI5TX | IS<1:0> | 0000 | | | 0400 | 11 030 | 15:0 | _ | _ | _ | Ş | SPI5RXIP<2:0 | )> | SPI5RXIS<1:0> | | _ | _ | _ | SPI5EIP<2:0> | | SPI5EI | S<1:0> | 0000 | | | 04D0 | IPC57 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SBIP<2:0> | | SBIS | <1:0> | 0000 | | 0400 | IFC57 | 15:0 | _ | | _ | •• | SPI6TXIP<2:0 | )> | SPI6TX | IS<1:0> | _ | - | _ | S | PI6RXIP<2: | 0> | SPI6RX | IS<1:0> | 0000 | | 04F0 | IPC59 | 31:16 | _ | _ | _ | | PWM8IP<2:0 | > | PWM8S | IP<1:0> | _ | _ | _ | F | PWM7IP<2:0 | )> | PWM7S | IP<1:0> | 0000 | | 041 0 | 11 009 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0500 | IPC60 | 31:16 | _ | _ | _ | ı | PWM12IP<2:0 | )> | PWM12S | SIP<1:0> | _ | _ | _ | Р | WM11IP<2: | 0> | PWM118 | SIP<1:0> | 0000 | | 0300 | 11 000 | 15:0 | _ | _ | _ | ı | PWM10IP<2:0 | )> | PWM108 | SIP<1:0> | _ | _ | _ | F | PWM9IP<2:0 | )> | PWM9S | IP<1:0> | 0000 | | 0510 | IPC61 | 31:16 | _ | 1 | _ | 1 | | | | _ | _ | _ | _ | | D1DC4IP<2: | | AD1DC4 | 4IS<1:0> | 0000 | | 0310 | IFCOI | 15:0 | _ | | _ | AD1DC3IP<2:0> | | | AD1DC3 | 3IS<1:0> | _ | - | _ | U | SB2IP<2:0> | (2) | USB2IS<1:0>(2) | | 0000 | | 0530 | IPC63 | 31:16 | _ | | _ | | | | _ | _ | _ | _ | _ | | CPCIP<2:0 | > | CPCIS | S<1:0> | 0000 | | 0000 | 11 000 | 15:0 | _ | | | | | | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | 0000 | | 0540 | OFF000 | 31:16 | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0340 | OFF000 | 15:0 | | | | | | | VOFF<15:1> | | | | | | | _ | 0000 | | | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | TABLE 8-4: | INTERRUPT | REGISTER | MAP ( | (CONTINUED) | |------------|-----------|----------|-------|-------------| |------------|-----------|----------|-------|-------------| | ress<br>t) | ٠. | 9 | | | | | | | | В | its | | | | | | | | ş | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF001 | 31:16 | _ | _ | _ | _ | ı | _ | _ | _ | ı | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0344 | OFFOOT | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 05/18 | OFF002 | 31:16 | _ | _ | _ | _ | | _ | - | _ | | - | _ | - | _ | _ | VOFF< | 17:16> | 0000 | | 0340 | 011002 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0540 | OFF003 | 31:16 | _ | _ | _ | _ | 1 | _ | | _ | 1 | _ | _ | - | _ | _ | VOFF< | 17:16> | 0000 | | 054C | OFF003 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0550 | OFF004 | 31:16 | _ | | _ | _ | 1 | _ | 1 | _ | ı | 1 | _ | 1 | _ | _ | VOFF< | 17:16> | 0000 | | 0550 | OFF004 | 15:0 | | | | | | _ | | VOFF<15:1 | > | | | | | | _ | _ | 0000 | | OEE4 | OFF005 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0554 | OFF005 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0550 | OFF006 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0556 | OFF006 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | ٥٢٢٥ | OFF007 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0550 | OFF007 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | OEGO | OFF008 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0300 | OFF006 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0564 | OFF009 | 31:16 | _ | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0504 | OFF009 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0560 | OFF010 | 31:16 | _ | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0500 | OFFUIU | 15:0 | | | | | | _ | | VOFF<15:1 | > | | | | | | _ | _ | 0000 | | 0ECC | OFF011 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0560 | OFFUII | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0570 | OFF012 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0570 | OFF012 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0574 | OFF013 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 05/4 | OFF013 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0570 | 055044 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 05/8 | OFF014 | 15:0 | | | | | | • | | VOFF<15:1 | > | | • | | | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: **INV Registers**" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | | J | |---------------|---| | ũ | j | | ō | Ì | | č | ٥ | | | ) | | 2 | ) | | | ١ | | ū | ٦ | | _ | ١ | | ď | ) | | п | 1 | | | | | $\frac{1}{2}$ | | | -ba | | | :-pag | | | :-page | | | | | | | | | -page 143 | | | <b>TABLE 8-4</b> : | INTERRUPT REGISTER | MAP (CONTINUED) | |--------------------|--------------------|-----------------| | | | | | res | ٠. | <u>e</u> | | | | | | | | В | its | | | | | | | | ţ | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF015 | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0370 | 011013 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0580 | OFF016 | 31:16 | _ | _ | _ | _ | | _ | - | _ | - | - | _ | - | _ | _ | VOFF< | 17:16> | 0000 | | 0300 | 011010 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0594 | OFF017 | 31:16 | _ | _ | _ | _ | 1 | _ | | _ | 1 | _ | _ | - | _ | _ | VOFF< | 17:16> | 0000 | | 0364 | OFFUIT | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0500 | OFF018 | 31:16 | _ | - | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0500 | OFF016 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0500 / | OFF019 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0560 | OFF019 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0500 | OFF020 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0590 | OFF020 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0594 | 055004 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0594 | OFF021 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0500 | OFF022 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0598 | OFF022 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0500 | 055000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0590 | OFF023 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0540 | 055004 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | USAU | OFF024 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0544 | 055005 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 05A4 ( | OFF025 | 15:0 | • | | | | | | | VOFF<15:1 | > | | • | | • | | • | _ | 0000 | | 0540 | 055000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 05A8 | OFF026 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0540 | 055007 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | U5AC ( | OFF027 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0500 | 055000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 05B8 ( | OFF030 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | • | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | 0 | ) | |---------------------|----| | _ | 3 | | 0 | 5 | | _ | Š | | _ | J | | | • | | <u> </u> | 2 | | $\subseteq$ | 2 | | 707- | נ | | _ | ١ | | = | | | _ | | | Microcnip | | | = | | | $\sim$ | | | ~ | | | = | ١. | | $\sigma$ | | | _ | | | _ | | | ~ | | | $\stackrel{\sim}{}$ | | | = | | | $\overline{}$ | | | echnology | | | .0 | | | <u>u</u> | | | < | | | = | | | ogy Inc. | | | <b>TABLE 8-4</b> : | INTERRUPT REGISTER MAP | (CONTINUED) | |--------------------|------------------------|-------------| |--------------------|------------------------|-------------| | ress<br>t) | ٠. | <u>o</u> | | | | | | | | В | its | | | | | | | | ts | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF031 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | VOFF< | 17:16> | 0000 | | USBC | OFF031 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0500 | OFF032 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | | _ | _ | - | VOFF< | 17:16> | 0000 | | 0300 | 011032 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0504 | OFF033 | 31:16 | _ | _ | - | _ | _ | _ | 1 | _ | _ | 1 | 1 | _ | | I | VOFF< | 17:16> | 0000 | | 0504 | OFF033 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | | 0000 | | 0500 | OFF034 | 31:16 | _ | _ | - | _ | _ | _ | 1 | _ | _ | 1 | 1 | _ | | I | VOFF< | 17:16> | 0000 | | 0500 | OFF034 | 15:0 | | _ | | | | _ | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0ECC | OFF035 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0500 | OFF035 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | OEDO | OFF036 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0300 | OFF036 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0504 | OFF037 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0504 | OFF037 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0ED0 | OFF038 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0300 | OFF036 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0EDC | OFF039 | 31:16 | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | - | VOFF< | 17:16> | 0000 | | USDC | OFF039 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | OFFO | OFF040 | 31:16 | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | - | VOFF< | 17:16> | 0000 | | 03E0 | OFF040 | 15:0 | | _ | | | | _ | | VOFF<15:1 | > | | | _ | | | | _ | 0000 | | 0554 | OFF041 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 03E4 | OFF041 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | OFFO | OFF042 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 03E0 | OFF042 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | ٥٢٥٥ | 055042 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | UDEC | OFF043 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | ٥٢٥٥ | 055044 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | U5F0 | OFF044 | 15:0 | | | | | • | • | | VOFF<15:1 | > | | | | | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: **INV Registers**" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | Ō | |---------------| | 0 | | 0 | | 0 | | 0 | | $\rightarrow$ | | 5 | | _ | | 9 | | Щ | | <u> </u> | | O | | а | | В | | Ф | | $\rightarrow$ | | _ | | | | 55 | | ress<br>t) | , | 9 | | | | | | | | В | its | | | | | | | | ts. | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|---------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF045 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 05F4 | OFF045 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | | 0000 | | 05E8 | OFF046 | 31:16 | _ | _ | _ | | - | _ | _ | _ | | _ | _ | _ | _ | - | VOFF< | :17:16> | 0000 | | 03F6 | OFF040 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | OFFC | OFF047 | 31:16 | | 1 | _ | 1 | 1 | 1 | - | _ | ı | _ | _ | _ | _ | 1 | VOFF< | :17:16> | 0000 | | USFC | OFF047 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0600 | OFF048 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0000 | OFF046 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | a. | | | _ | 0000 | | 0604 | OFF049 | 31:16 | _ | _ | _ | | - | _ | _ | _ | | _ | _ | _ | _ | - | VOFF< | :17:16> | 0000 | | 0004 | 011049 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0608 | OFF050 | 31:16 | _ | _ | _ | 1 | - | | - | _ | 1 | _ | _ | _ | _ | - | VOFF< | :17:16> | 0000 | | 0000 | 011030 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0600 | OFF051 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0000 | 011031 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0610 | OFF052 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0010 | 011002 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0614 | OFF053 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0014 | 011000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0618 | OFF054 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0010 | 011001 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 061C | OFF055 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 00.0 | 0 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0620 | OFF056 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 3020 | 511000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0624 | OFF057 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 3024 | C1 1 007 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0628 | OFF058 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0020 | OI 1 036 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | ress<br>t) | ٠. | <u>o</u> | | | | | | | | В | its | | | | | | | | र | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF059 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0020 | 011009 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0630 | OFF060 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0634 | OFF061 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0004 | 011001 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0638 | OFF062 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011002 | 15:0 | - | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 063C | OFF063 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0640 | OFF064 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | | 000. | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0644 | OFF065 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | | 0 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0648 | OFF066 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | | | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 064C | OFF067 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0010 | | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0650 | OFF068 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011000 | 15:0 | - | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0654 | OFF069 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | | 0 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0658 | OFF070 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | | 0 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 065C | OFF071 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 3 07 1 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0660 | OFF072 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011012 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. - 2: This bit is not available on 64-pin devices. - 3: This bit is not available on devices without a CAN module. - 4: This bit is not available on 100-pin devices. - 5: Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - 6: Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | τ | Ξ | | |----|----|---| | 9 | Ţ | | | | Š | ١ | | 0 | | | | ( | Ξ | | | | Ξ | | | - | | | | • | 7 | | | - | _ | ١ | | ( | 2 | | | ſ | · | | | 7 | ÷ | | | ٠, | | | | , | 'n | | | C | 2 | | | | D | | | | | | | - | _ | ١ | | | 4 | | | | : | ĺ | | | 7 | ۱ | | | | | | | | | | TABLE 8-4: INTERRUPT REGISTER MAP (CONTINUED) | TABLE 8-4: | INTERRUPT | REGISTER | MAP | (CONTINUED) | |-----------------------------------------------|------------|-----------|----------|-----|-------------| |-----------------------------------------------|------------|-----------|----------|-----|-------------| | ress<br>t) | , | le | | | | | | | | В | its | | | | | | | | ts. | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF073 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0004 | OFF0/3 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0668 | OFF074 | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | OFF074 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0660 | OFF075 | 31:16 | - | _ | _ | _ | 1 | 1 | - | _ | ı | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | OFF073 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0670 | OFF076 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0070 | OFF070 | 15:0 | | | ā. | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0674 | OFF077 | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0074 | 011077 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0678 | OFF078 | 31:16 | _ | _ | _ | _ | - | | - | _ | 1 | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0070 | 011070 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0670 | OFF079 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0070 | 011079 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0680 | OFF080 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0684 | OFF081 | 31:16 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0004 | 011001 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0688 | OFF082 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011002 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 068C | OFF083 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | - | 0 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0690 | OFF084 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 3030 | 51 1 004 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0694 | OFF085 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 3034 | C1 1 000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0698 | OFF086 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0090 | OI 1 000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | <b>TABLE 8-4:</b> | <b>INTERRUPT REGISTER MAP (</b> | (CONTINUED) | |-------------------|---------------------------------|-------------| | | | | | ress<br>t) | <b>-</b> . | <u>e</u> | | | | | | | | В | its | | | | | | | | ŝ | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF087 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0090 | OFF007 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0640 | OFF088 | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | OOAO | 011000 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 06 \ 4 | OFF089 | 31:16 | _ | | _ | | 1 | _ | 1 | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 00A4 | OFF009 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 06 4 9 | OFF090 | 31:16 | _ | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | UOAo | OFF090 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0040 | OFF091 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | UbAC | OFF091 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | OFF092 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | OFF092 | 15:0 | • | | | | | • | | VOFF<15:1 | > | | • | • | • | • | | _ | 0000 | | 0000 | 055004 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0688 | OFF094 | 15:0 | • | | | | | • | | VOFF<15:1 | > | | • | • | • | • | | _ | 0000 | | 0000 | 055005 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 06BC | OFF095 | 15:0 | • | | | | | • | | VOFF<15:1 | > | | • | • | • | • | | _ | 0000 | | 2222 | 055000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 06C0 | OFF096 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 2224 | 055007 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 06C4 | OFF097 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 2222 | 055000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 06C8 | OFF098 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 06CC | OFF099 | 15:0 | ı | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 06D0 | OFF100 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | 1 | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 06D4 | OFF101 | 15:0 | | | | | | | | VOFF<15:1 | | | | | | | | _ | 0000 | | | | | | Dt. | | | | | | | | | | | | | | | 10000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | ress<br>() | , | е | | | | | | | | В | its | | | | | | | | ž. | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF102 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | OFF 102 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | UEDC | OFF103 | 31:16 | _ | | _ | _ | | _ | _ | _ | | - | _ | _ | _ | - | VOFF< | 17:16> | 0000 | | OODC | OFF 103 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 06E0 | OFF104 | 31:16 | _ | | _ | _ | 1 | _ | - | _ | ı | 1 | _ | _ | _ | I | VOFF< | 17:16> | 0000 | | 0000 | OFF 104 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 06E4 | OFF105 | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | 1 | VOFF< | 17:16> | 0000 | | 00E4 | OFF 103 | 15:0 | | | a | | | | | VOFF<15:1 | > | | | | a. | | | _ | 0000 | | 06E8 | OFF106 | 31:16 | _ | | _ | _ | | _ | _ | _ | | - | _ | _ | _ | - | VOFF< | 17:16> | 0000 | | OOLO | 011100 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | OSEC | OFF107 | 31:16 | _ | 1 | _ | _ | 1 | _ | - | _ | 1 | _ | _ | _ | _ | 1 | VOFF< | 17:16> | 0000 | | OOLO | 011107 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0650 | OFF108 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 001 0 | 011100 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 06F4 | OFF109 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 001 4 | 011 103 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 06E8 | OFF110 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 001 0 | 011110 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 06EC | OFF111 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 001 0 | 011111 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | OFF112 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0700 | 011112 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0704 | OFF113 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0704 | 011110 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0708 | OFF114 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0700 | 511114 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | OFF115 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0700 | 511115 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. TABLE 8-4: INTERRUPT REGISTER MAP (CONTINUED) | ress | | <u>o</u> | | | | | | | | В | its | | | | | | | | ŝ | |-----------------------------|---------------------------------|-----------|----------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF116 | 31:16 | _ | _ | _ | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0710 | OFFIIO | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | - | 0000 | | 0714 | OFF117 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | VOFF< | 17:16> | 0000 | | 07 14 | OFF117 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0710 | OFF110 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0718 | OFF118 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0740 | 055440 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0710 | OFF119 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0720 | OFF120 | 15:0 | | | • | | • | | • | VOFF<15:1 | > | | | | | | • | _ | 0000 | | 0704 | 055404 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0724 | OFF121 | 15:0 | <u>'</u> | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0728 | OFF122 | 15:0 | <u>'</u> | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 2700 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 072C | OFF123 | 15:0 | ' | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0730 | OFF124 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0704 | 055405 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0734 | OFF125 | 15:0 | ' | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0738 | OFF126 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 2700 | 055407 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0/3C | OFF127 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | l. | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0740 | OFF128 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0744 | OFF129 | 15:0 | | | ! | ! | | | ļ. | VOFF<15:1 | > | | | | ! | | ļ | _ | 0000 | | | l . | | | | | | | | | | | | | | | | | | | - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. - 2: This bit is not available on 64-pin devices. - 3: This bit is not available on devices without a CAN module. - 4: This bit is not available on 100-pin devices. - 5: Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - 6: Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | <b>TABLE 8-4:</b> | INTERRUPT REGIS | STER MAP | (CONTINUED) | |-------------------|-----------------|----------|-------------| | | | | | | ress<br>:) | <b>.</b> . | • | Bits g | | | | | | | | | | | | | | | | | |-----------------------------|---------------------------------|-----------|--------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF130 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0746 | OFF 130 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0740 | OFF131 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0740 | OFFISI | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0750 | OFF132 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0750 | OFF 132 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0754 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0754 | OFF133 | 15:0 | | | • | | • | | | VOFF<15:1 | > | | | • | • | | | _ | 0000 | | 0700 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0760 | OFF139 | 15:0 | | | • | | • | | | VOFF<15:1 | > | | | • | • | | | _ | 0000 | | 0770 | 055440 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0770 | OFF140 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0774 | 055444 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0774 | OFF141 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0770 | 055440 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0778 | OFF142 | 15:0 | | | • | | • | | | VOFF<15:1 | > | | | • | • | | | _ | 0000 | | | 055440 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0770 | OFF143 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | 055444 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0780 | OFF144 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0704 | 055445 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0784 | OFF145 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0788 | OFF146 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0707 | 0554:- | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 078C | OFF147 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0790 | OFF148 | 15:0 | | | ! | ! | | | | VOFF<15:1 | > | | | | ! | | ! | _ | 0000 | | L | l | 1 | | | | | | | | | | | | | | | | | | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. TABLE 8-4: INTERRUPT REGISTER MAP (CONTINUED) | ress<br>t) | ٠. | <u>o</u> | | | | | | | | В | its | | | | | | | | ţ | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|---------------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF149 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ı | _ | _ | ı | VOFF< | 17:16> | 0000 | | 0794 | OFF 149 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | | 0000 | | 0709 | OFF150 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 1 | VOFF< | 17:16> | 0000 | | 0790 | OFF 130 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | OFF151 | 31:16 | _ | 1 | _ | _ | | 1 | _ | _ | 1 | _ | - | _ | _ | - | VOFF< | 17:16> | 0000 | | 0790 | OFFISI | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0740 | OFF152 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | UTAU | OFF 152 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0744 | OFF153 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | U/A4 | OFF 153 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0740 | OFF154 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | U/A8 | OFF 154 | 15:0 | • | | | | | | | VOFF<15:1 | > | • | | • | | | | _ | 0000 | | 0740 | 055455 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | U/AC | OFF155 | 15:0 | • | | | | | | | VOFF<15:1 | > | • | | • | | | | _ | 0000 | | 0700 | OFF156 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0780 | OFF 156 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0700 | 055450 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0788 | OFF158 | 15:0 | • | | | | | | | VOFF<15:1 | > | • | | • | | | | _ | 0000 | | 0700 | 055450 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 07BC | OFF159 | 15:0 | • | | | | | | | VOFF<15:1 | > | • | | • | | | | _ | 0000 | | 0700 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0700 | OFF160 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0704 | 055404 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 07C4 | OFF161 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 07C8 | OFF162 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 07D0 | OFF164 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | l | | | | | | d == (0) D=== | | | | | | | | | | | | | - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. - 2: This bit is not available on 64-pin devices. - 3: This bit is not available on devices without a CAN module. - 4: This bit is not available on 100-pin devices. - 5: Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - 6: Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | <b>TABLE 8-4:</b> | INTERRUPT REGISTER MAP ( | (CONTINUED) | |-------------------|--------------------------|-------------| | | | | | ress<br>:) | <b>L</b> _ | 9 | | Bits | | | | | | | | | | | | S | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|--------------|-------|------|-----------|------|------|------|------|------|------|-------|---------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF165 | 31:16 | 1 | 1 | _ | _ | I | 1 | 1 | _ | 1 | 1 | _ | | _ | _ | VOFF< | :17:16> | 0000 | | 07.04 | OFF 103 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 07D8 | OFF166 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 07 00 | 011 100 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 07DC | OFF167 | 31:16 | _ | - | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | Orbc | 011107 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 07E0 | OFF168 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 07 20 | 011 100 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 07F4 | OFF169 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 07 = 1 | 011100 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 07F8 | OFF170 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0.20 | | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 07EC | OFF171 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | 0.20 | | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 07F0 | OFF172 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | | | 15:0 | | | ı | | | | | VOFF<15:1 | > | | 1 | | | | | _ | 0000 | | 07F4 | OFF173 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | | | 15:0 | | | 1 | | | | | VOFF<15:1 | > | | | | | | _ | _ | 0000 | | 07F8 | OFF174 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | | | 15:0 | | | 1 | | | | | VOFF<15:1 | > | | 1 | | | | | _ | 0000 | | 07FC | OFF175 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | | | 15:0 | | | 1 | | | | | VOFF<15:1 | > | | | | | | _ | _ | 0000 | | 0800 | OFF176 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | | 0000 | | | | 15:0 | | | 1 | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0804 | OFF177 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | VOFF< | | 0000 | | | | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | 1 | _ | 0000 | | 0808 | OFF178 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | :17:16> | 0000 | | | | 15:0 | | | | | das 'n' Pasa | | | VOFF<15:1 | > | | | | | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. **TABLE 8-4: INTERRUPT REGISTER MAP (CONTINUED)** | ress<br>t) | ٠. | <u>e</u> | | | | | | | | В | its | | | | | | | | Į. | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|---------------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF179 | 31:16 | _ | _ | _ | _ | _ | ı | _ | _ | _ | _ | ı | _ | _ | ı | VOFF< | 17:16> | 0000 | | 0000 | OFFITS | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | | 0000 | | 0010 | OFF180 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 1 | VOFF< | 17:16> | 0000 | | 0010 | OFF 160 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0014 | OFF181 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0014 | OFFIOI | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0040 | OFF182 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0818 | OFF 182 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0040 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0810 | OFF183 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | 055404 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0820 | OFF184 | 15:0 | | | | | | | | VOFF<15:1 | > | • | | | | | | _ | 0000 | | 0004 | 055405 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0824 | OFF185 | 15:0 | | | | | | | | VOFF<15:1 | > | • | | | | | | _ | 0000 | | 0000 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0828 | OFF186 | 15:0 | | | | | | | | VOFF<15:1 | > | • | | | | | | _ | 0000 | | 2000 | 055407 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 082C | OFF187 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0830 | OFF188 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0004 | 055400 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0834 | OFF189 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0848 | OFF194 | 15:0 | ı | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 084C | OFF195 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0850 | OFF196 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | l | 11 | | | | | d == (o) D=== | | | | | | | | | | | | | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | <b>TABLE 8-4</b> : | INTERRUPT REGISTER MAP | (CONTINUED) | |--------------------|------------------------|-------------| | | | | | ess) | | Ф | | | | | | | | В | its | | | | | | | | s | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF197 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0054 | OFF 191 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0858 | OFF198 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011 130 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0850 | OFF199 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | 1 | VOFF< | 17:16> | 0000 | | 0050 | OFF 199 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0060 | OFF200 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | 1 | VOFF< | 17:16> | 0000 | | 0000 | OFF200 | 15:0 | | | _ | | | _ | | VOFF<15:1 | > | | | _ | _ | | | _ | 0000 | | 0064 | OFF201 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 1 | VOFF< | 17:16> | 0000 | | 0004 | OFF201 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0060 | OFF202 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | OFFZUZ | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | OFF203 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | OFF203 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0070 | OFF204 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0070 | OFF204 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0074 | OFF205 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0074 | OFF205 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0070 | OFF206 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | 1 | _ | _ | I | VOFF< | 17:16> | 0000 | | 0070 | OFF200 | 15:0 | | | | | | | _ | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0070 | OFF207 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 1 | VOFF< | 17:16> | 0000 | | 0070 | OFF201 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | OFF208 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | U88U | OFF208 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0004 | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0084 | OFF209 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | 055340 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0888 | OFF210 | 15:0 | • | | • | • | • | • | • | VOFF<15:1 | > | | | • | • | | | _ | 0000 | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: INV Registers" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | 0 | |------------| | 201 | | 7-2021 | | Microchip | | Technology | | nc. | | <b>TABLE 8-4:</b> | INTERRUPT REGIS | STER MAP | (CONTINUED) | |-------------------|-----------------|----------|-------------| | | | | | | ress<br>t) | ٠. | <u>o</u> | | | | | | | | В | its | | | | | | | | ts | |-----------------------------|---------------------------------|-----------|-------|----------|-------|-------|---------------|-------|------|-----------|------|------|------|------|------|------|-------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF211 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ı | _ | _ | ı | VOFF< | 17:16> | 0000 | | 0000 | OFFZII | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | OFF212 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | - | VOFF< | 17:16> | 0000 | | 0090 | OFFZIZ | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0004 | OFF213 | 31:16 | _ | _ | _ | _ | | 1 | _ | _ | 1 | _ | - | _ | _ | - | VOFF< | 17:16> | 0000 | | 0094 | OFF213 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | OFF214 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0898 | OFF214 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | OFF215 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 089C | OFF215 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0040 | OFF216 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | U8AU | OFF216 | 15:0 | • | | | | | | | VOFF<15:1 | > | • | | | | | | _ | 0000 | | 0044 | 055047 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 08A4 | OFF217 | 15:0 | • | | | | | | | VOFF<15:1 | > | • | | | | | | _ | 0000 | | 0040 | OFF218 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | USAS | OFF218 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0040 | 055040 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | UBAC | OFF219 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | 055000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0880 | OFF220 | 15:0 | • | | | | | | | VOFF<15:1 | > | • | | | | | | _ | 0000 | | 0004 | 055004 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 08B4 | OFF221 | 15:0 | | <u> </u> | | | | | | VOFF<15:1 | > | | | | | | I. | _ | 0000 | | 0000 | 055000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0888 | OFF222 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 08BC | OFF223 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | 1 | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 08C0 | OFF224 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | | l | 11 | | | | | d == (0) D=== | | | | | | | | | | | | | - All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and Note 1: **INV Registers**" for more information. - This bit is not available on 64-pin devices. - This bit is not available on devices without a CAN module. - This bit is not available on 100-pin devices. - Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. | TABLE 8-4: | INTERRUPT REGISTER MAP | (CONTINUED) | | |------------|-------------------------|-------------|--| | IADEE V T. | INTICIONAL INCOMENTAL I | | | | ress<br>t) | ٠. | <u>o</u> | | | | | - | | | В | its | | | | | | | | ş | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|-------|--------------|------|------|------|------|------|------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OFF225 | 31:16 | _ | _ | _ | | - | | | _ | | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 08C4 | UFF225 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0808 | OFF226 | 31:16 | _ | _ | _ | _ | _ | _ | - | _ | - | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | OFF220 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | USCC | OFF227 | 31:16 | _ | _ | _ | | | 1 | I | _ | 1 | 1 | _ | - | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011221 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0800 | OFF228 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0000 | 011220 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 08D4 | OFF229 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | | | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 08D8 | OFF230 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | | | 15:0 | | | 1 | | | | | VOFF<15:1 | > | | ı | | | | | _ | 0000 | | 000 | OFF238 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 0010 | OFF236 | 15:0 | | | | | | | VOFI | F<15:1> | | | | | | | VOFF<17:16 VOFF<17:16 VOFF<17:16 VOFF<17:16 VOFF<17:16 VOFF<17:16 VOFF<17:16 | | | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 08FC | OFF239 | 15:0 | | | | | | | VOFI | F<15:1> | | | | | | | | VOFF<17:16> VOFF<17:16> VOFF<17:16> VOFF<17:16> VOFF<17:16> VOFF<17:16> VOFF<17:16> VOFF<17:16> | | | | | | _ | | | | | _ | | _ | _ | | | _ | _ | _ | | | | | 0900 | OFF240 | 31:16 | | | | | | | | | | | | | | | | | | | | | 15:0 | | | ı | | | | VOFI | F<15:1> | | | | | | 1 | | | | | 0004 | 055044 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 0904 | OFF241 | 15:0 | | | | | | | VOFI | F<15:1> | | | | | | | | | | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 0908 | OFF242 | 15:0 | | | | | | | \/051 | I<br>F<15:1> | | | | | | | | | | | | | | | | | | | | VOFI | | | | | | | | | | | | 090C | OFF243 | 31:16 | | _ | | _ | _ | _ | _ | _ | _ | | _ | | _ | _ | | | | | | 22.0 | 15:0 | | | | | | | VOFI | F<15:1> | | | | | | | | | | | 0010 | OFF244 | 31:16 | _ | _ | _ | _ | | | - | _ | | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0910 | OFF244 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. - 2: This bit is not available on 64-pin devices. - 3: This bit is not available on devices without a CAN module. - : This bit is not available on 100-pin devices. - 5: Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - 6: Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. ### TABLE 8-4: INTERRUPT REGISTER MAP (CONTINUED) | S | | | | | | | • | , | | | :4- | | | | | | | | $\Box$ | |---------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-----------|------|------|------|------|------|------|-------|--------|----------| | ± ë | <b>5</b> - | e e | | | | | | | | В | its | | | | | | | | ets | | Virtual Addre<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Rese | | 0014 | OFF245 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0914 | UFF245 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0010 | OFF246 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0910 | OFF246 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 0000 | OFF254 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 0938 | OFF254 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | | 00300 | OFF255 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | 0000 | | 09360 | OFF255 | 15:0 | | | | | | | | VOFF<15:1 | > | | | | | | | _ | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. - Note 1: All registers in this table with the exception of the OFFx registers, have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. - 2: This bit is not available on 64-pin devices. - 3: This bit is not available on devices without a CAN module. - 4: This bit is not available on 100-pin devices. - 5: Bits 31 and 30 are not available on 64-pin and 100-pin devices; bits 29 through 14 are not available on 64-pin devices. - 6: Bits 31, 30, 29, and bits 5 through 0 are not available on 64-pin and 100-pin devices; bit 22 is not available on 64-pin devices. - 7: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition is occurred. The IFSx bits are persistent, hence they must be cleared if they are set by user software after an IFSx user bit interrogation. PIC32MK GPK/MCM with CAN FD Family ### REGISTER 8-1: INTCON: INTERRUPT CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R/W-0 | 31:24 | | • | • | NMIKI | EY<7:0> | • | • | | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | U-0 | U-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 15.6 | _ | _ | _ | MVEC | _ | | TPC<2:0> | | | 7:0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7.0 | _ | _ | _ | INT4EP | INT3EP | INT2EP | INT1EP | INT0EP | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 NMIKEY<7:0>: Software Generated NMI Key Register bits Software NMI event when the correct key (4Eh) is written. Software NMI event not generated when any other value (not the key) is written. bit 23-13 Unimplemented: Read as '0' bit 12 MVEC: Multi Vector Configuration bit 1 = Interrupt controller configured for multi vectored mode 0 = Interrupt controller configured for single vectored mode bit 11 Unimplemented: Read as '0' bit 10-8 TPC<2:0>: Interrupt Proximity Timer Control bits 111 =Interrupts of group priority 7 or lower start the Interrupt Proximity timer 110 =Interrupts of group priority 6 or lower start the Interrupt Proximity timer 101 =Interrupts of group priority 5 or lower start the Interrupt Proximity timer 100 =Interrupts of group priority 4 or lower start the Interrupt Proximity timer 011 =Interrupts of group priority 3 or lower start the Interrupt Proximity timer 010 =Interrupts of group priority 2 or lower start the Interrupt Proximity timer 001 =Interrupts of group priority 1 start the Interrupt Proximity timer 000 =Disables Interrupt Proximity timer bit 7-5 Unimplemented: Read as '0' bit 4 INT4EP: External Interrupt 4 Edge Polarity Control bit 1 = Rising edge 0 = Falling edge bit 3 INT3EP: External Interrupt 3 Edge Polarity Control bit 1 = Rising edge 0 = Falling edge bit 2 INT2EP: External Interrupt 2 Edge Polarity Control bit 1 = Rising edge 0 = Falling edge bit 1 INT1EP: External Interrupt 1 Edge Polarity Control bit 1 = Rising edge 0 = Falling edge bit 0 INT0EP: External Interrupt 0 Edge Polarity Control bit 1 = Rising edge 0 = Falling edge ### REGISTER 8-2: PRISS: PRIORITY SHADOW SELECT REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|----------------------|-------------------|-------------------|-------------------|----------------------|------------------| | 24.24 | R/W-0 | 31:24 | | PRI7SS | <3:0> <sup>(1)</sup> | | | PRI6SS | <3:0> <sup>(1)</sup> | | | 22.46 | R/W-0 | 23:16 | | PRI5SS | <3:0> <sup>(1)</sup> | | | PRI4SS | <3:0> <sup>(1)</sup> | | | 45.0 | R/W-0 | 15:8 | | PRI3S | S<3:0> | | | PRI2SS | <3:0> <sup>(1)</sup> | | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | | 7:0 | | PRI1SS | <3:0> <sup>(1)</sup> | | _ | _ | _ | SS0 | ``` R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 PRI7SS<3:0>: Interrupt with Priority Level 7 Shadow Set bits(1) 1xxx = Reserved (by default, an interrupt with a priority level of 7 uses Shadow Set 0) 0111 = Interrupt with a priority level of 7 uses Shadow Set 7 0110 = Interrupt with a priority level of 7 uses Shadow Set 6 0001 = Interrupt with a priority level of 7 uses Shadow Set 1 0000 = Interrupt with a priority level of 7 uses Shadow Set 0 (default) bit 27-24 PRI6SS<3:0>: Interrupt with Priority Level 6 Shadow Set bits<sup>(1)</sup> 1xxx = Reserved (by default, an interrupt with a priority level of 6 uses Shadow Set 0) 0111 = Interrupt with a priority level of 6 uses Shadow Set 7 0110 = Interrupt with a priority level of 6 uses Shadow Set 6 0001 = Interrupt with a priority level of 6 uses Shadow Set 1 0000 = Interrupt with a priority level of 6 uses Shadow Set 0 (default) bit 23-20 PRI5SS<3:0>: Interrupt with Priority Level 5 Shadow Set bits<sup>(1)</sup> 1xxx = Reserved (by default, an interrupt with a priority level of 5 uses Shadow Set 0) 0111 = Interrupt with a priority level of 5 uses Shadow Set 7 0110 = Interrupt with a priority level of 5 uses Shadow Set 6 0001 = Interrupt with a priority level of 5 uses Shadow Set 1 0000 = Interrupt with a priority level of 5 uses Shadow Set 0 (default) ``` **Note 1:** These bits are ignored if the MVEC bit (INTCON<12>) = 0. Legend: ``` PRISS: PRIORITY SHADOW SELECT REGISTER (CONTINUED) REGISTER 8-2: bit 19-16 PRI4SS<3:0>: Interrupt with Priority Level 4 Shadow Set bits(1) 1xxx = Reserved (by default, an interrupt with a priority level of 4 uses Shadow Set 0) 0111 = Interrupt with a priority level of 4 uses Shadow Set 7 0110 = Interrupt with a priority level of 4 uses Shadow Set 6 0001 = Interrupt with a priority level of 4 uses Shadow Set 1 0000 = Interrupt with a priority level of 4 uses Shadow Set 0 (default) bit 15-12 PRI3SS<3:0>: Interrupt with Priority Level 3 Shadow Set bits<sup>(1)</sup> 1xxx = Reserved (by default, an interrupt with a priority level of 3 uses Shadow Set 0) 0111 = Interrupt with a priority level of 3 uses Shadow Set 7 0110 = Interrupt with a priority level of 3 uses Shadow Set 6 0001 = Interrupt with a priority level of 3 uses Shadow Set 1 0000 = Interrupt with a priority level of 3 uses Shadow Set 0 (default) PRI2SS<3:0>: Interrupt with Priority Level 2 Shadow Set bits<sup>(1)</sup> 1xxx = Reserved (by default, an interrupt with a priority level of 2 uses Shadow Set 0) 0111 = Interrupt with a priority level of 2 uses Shadow Set 7 0110 = Interrupt with a priority level of 2 uses Shadow Set 6 0001 = Interrupt with a priority level of 2 uses Shadow Set 1 0000 = Interrupt with a priority level of 2 uses Shadow Set 0 (default) PRI1SS<3:0>: Interrupt with Priority Level 1 Shadow Set bits<sup>(1)</sup> bit 7-4 1xxx = Reserved (by default, an interrupt with a priority level of 1 uses Shadow Set 0) 0111 = Interrupt with a priority level of 1 uses Shadow Set 7 0110 = Interrupt with a priority level of 1 uses Shadow Set 6 0001 = Interrupt with a priority level of 1 uses Shadow Set 1 0000 = Interrupt with a priority level of 1 uses Shadow Set 0 (default) bit 3-1 Unimplemented: Read as '0' bit 0 SS0: Single Vector Shadow Register Set bit 1 = Single vector is presented with a shadow set 0 = Single vector is not presented with a shadow set ``` **Note 1:** These bits are ignored if the MVEC bit (INTCON<12>) = 0. ### REGISTER 8-3: INTSTAT: INTERRUPT STATUS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | | | | _ | | 22.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | | | | 15.0 | U-0 | U-0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | | 15:8 | _ | _ | | _ | - | | SRIPL<2:0> | | | 7.0 | R-0 | 7:0 | | | | SIRC | Q<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-11 Unimplemented: Read as '0' bit 10-8 SRIPL<2:0>: Requested Priority Level bits for Single Vector Mode bits 111-000 = The priority level of the latest interrupt presented to the CPU bit 7-6 Unimplemented: Read as '0' bit 7-0 **SIRQ<7:0>:** Last Interrupt Request Serviced Status bits 11111111-00000000 = The last interrupt request number serviced by the CPU ### REGISTER 8-4: IPTMR: INTERRUPT PROXIMITY TIMER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 04:04 | R/W-0 | 31:24 | | | | IPTMF | R<31:24> | | | | | 00:40 | R/W-0 | 23:16 | | | | IPTMF | <23:16> | | | | | 45.0 | R/W-0 | 15:8 | | | | IPTMI | R<15:8> | | | | | 7.0 | R/W-0 | 7:0 | | | | IPTM | R<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-0 IPTMR<31:0>: Interrupt Proximity Timer Reload bits Used by the Interrupt Proximity Timer as a reload value when the Interrupt Proximity timer is triggered by an interrupt event. ### REGISTER 8-5: IFSx: INTERRUPT FLAG STATUS REGISTER 'x' ('x' = 0-7) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R/W-0 | 31:24 | IFS31 | IFS30 | IFS29 | IFS28 | IFS27 | IFS26 | IFS25 | IFS24 | | 23:16 | R/W-0 | 23:16 | IFS23 | IFS22 | IFS21 | IFS20 | IFS19 | IFS18 | IFS17 | IFS16 | | 45.0 | R/W-0 | 15:8 | IFS15 | IFS14 | IFS13 | IFS12 | IFS11 | IFS10 | IFS9 | IFS8 | | 7.0 | R/W-0 | 7:0 | IFS7 | IFS6 | IFS5 | IFS4 | IFS3 | IFS2 | IFS1 | IFS0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 IFS31-IFS0: Interrupt Flag Status bits 1 = Interrupt request has occurred 0 = No interrupt request has occurred **Note:** This register represents a generic definition of the IFSx register. Refer to Table 8-3 for the exact bit definitions. ### REGISTER 8-6: IECx: INTERRUPT ENABLE CONTROL REGISTER 'x' ('x' = 0-7) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | R/W-0 | 31:24 | IEC31 | IEC30 | IEC29 | IEC28 | IEC27 | IEC26 | IEC25 | IEC24 | | 00.40 | R/W-0 | 23:16 | IEC23 | IEC22 | IEC21 | IEC20 | IEC19 | IEC18 | IEC17 | IEC16 | | 45.0 | R/W-0 | 15:8 | IEC15 | IEC14 | IEC13 | IEC12 | IEC11 | IEC10 | IEC9 | IEC8 | | 7.0 | R/W-0 | 7:0 | IEC7 | IEC6 | IEC5 | IEC4 | IEC3 | IEC2 | IEC1 | IEC0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 **IEC31-IEC0:** Interrupt Enable bits 1 = Interrupt is enabled0 = Interrupt is disabled **Note:** This register represents a generic definition of the IECx register. Refer to Table 8-3 for the exact bit definitions. ### REGISTER 8-7: IPCx: INTERRUPT PRIORITY CONTROL REGISTER 'x' ('x' = 0-63) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|----------------------------------------------------------------------|------------------|------------------| | 24.24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31:24 | _ | _ | _ | | IP3<2:0> | | IS3< | :1:0> | | 23:16 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | _ | _ | _ | | IP2<2:0> | | IS2< | :1:0> | | 45.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | 19/11/3 26/18/10/2 25/17/9/1 2 2 2 2 2 2 2 2 2 | R/W-0 | | | 15:8 | _ | _ | _ | | IP1<2:0> | | IS1< | :1:0> | | 7.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | _ | _ | | IP0<2:0> | | IS0< | :1:0> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 **Unimplemented:** Read as '0' bit 28-26 IP3<2:0>: Interrupt Priority bits 111 = Interrupt priority is 7 • 010 = Interrupt priority is 2 001 = Interrupt priority is 1 000 = Interrupt is disabled bit 25-24 IS3<1:0>: Interrupt Subpriority bits 11 = Interrupt subpriority is 3 10 = Interrupt subpriority is 2 01 = Interrupt subpriority is 1 00 = Interrupt subpriority is 0 bit 23-21 Unimplemented: Read as '0' bit 20-18 IP2<2:0>: Interrupt Priority bits 111 = Interrupt priority is 7 • 010 = Interrupt priority is 2 001 = Interrupt priority is 1 000 = Interrupt is disabled bit 17-16 IS2<1:0>: Interrupt Subpriority bits 11 = Interrupt subpriority is 3 10 = Interrupt subpriority is 2 01 = Interrupt subpriority is 1 00 = Interrupt subpriority is 0 bit 15-13 Unimplemented: Read as '0' **Note:** This register represents a generic definition of the IPCx register. Refer to Table 8-3 for the exact bit definitions. ### REGISTER 8-7: IPCx: INTERRUPT PRIORITY CONTROL REGISTER 'x' ('x' = 0-63) (CONTINUED) ``` bit 12-10 IP1<2:0>: Interrupt Priority bits 111 = Interrupt priority is 7 010 = Interrupt priority is 2 001 = Interrupt priority is 1 000 = Interrupt is disabled bit 9-8 IS1<1:0>: Interrupt Subpriority bits 11 =Interrupt subpriority is 3 10 =Interrupt subpriority is 2 01 =Interrupt subpriority is 1 00 =Interrupt subpriority is 0 bit 7-5 Unimplemented: Read as '0' bit 4-2 IP0<2:0>: Interrupt Priority bits 111 = Interrupt priority is 7 010 = Interrupt priority is 2 001 = Interrupt priority is 1 000 = Interrupt is disabled bit 1-0 IS0<1:0>: Interrupt Subpriority bits 11 = Interrupt subpriority is 3 10 = Interrupt subpriority is 2 01 = Interrupt subpriority is 1 00 = Interrupt subpriority is 0 ``` **Note:** This register represents a generic definition of the IPCx register. Refer to Table 8-3 for the exact bit definitions. REGISTER 8-8: OFFx: INTERRUPT VECTOR ADDRESS OFFSET REGISTER (x = 0-190) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|---------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 23.10 | _ | _ | _ | _ | _ | _ | VOFF< | 17:16> | | 15:8 | R/W-0 | 15.6 | | | | VOFF | <del>-</del> <15:8> | | | | | 7:0 | R/W-0 U-0 | | 7.0 | | | | VOFF<7:1> | • | | | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 17-1 VOFF<17:1>: Interrupt Vector 'x' Address Offset bits bit 0 Unimplemented: Read as '0' # 9.0 OSCILLATOR CONFIGURATION Note: data sheet summarizes features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual", which is available from the Microchip web site (www.microchip.com/PIC32). The PIC32MK GPK/MCM with CAN FD Family oscillator system has the following modules and features: - Five external and internal oscillator options as clock sources - On-Chip PLL with user-selectable input divider, multiplier and output divider to boost operating frequency on select internal and external oscillator sources - On-Chip user-selectable divisor postscaler on select oscillator sources - Software-controllable switching between various clock sources - A Fail-Safe Clock Monitor (FSCM) that detects clock failure and permits safe application recovery or shutdown with dedicated Backup FRC (BFRC) - Dedicated On-Chip PLL for USB modules - · Flexible reference clock output - Multiple clock branches for peripherals for better performance flexibility A block diagram of the oscillator system is provided in Figure 9-1. The clock distribution is shown in Table 9-1. FIGURE 9-1: PIC32MK GPK/MCM WITH CAN FD FAMILY OSCILLATOR DIAGRAM - Refer to 2.0 "Guidelines for Getting Started with 32-bit MCUs" for recommended external crystal component values and restrictions. - The internal POSC feedback resistor, RF, is typically in the range of 2 to 10 M. 2: - The maximum PBCLK6 clock rate to the peripherals in the low power domain is 30 MHz. This is not the power-up default and must be configured by the user before attempting any access to those 3: - 4: Refer to Table 37-16 in 37.0 "Electrical Characteristics" for PBCLK6 frequency limitations. - CLKO on OSC2 pin, if enabled in configuration word, available in EC & FRC mode is PBCLK1 / 2. TABLE 9-1: SYSTEM AND PERIPHERAL CLOCK DISTRIBUTION | Peripheral | | | | | | | С | lock S | Source | е | | | | | | | |----------------------|-----|------|------|------|--------|------|------|-----------------------|--------|--------|--------|--------|----------|----------|----------|----------| | | FRC | LPRC | SOSC | POSC | SYSCLK | SPLL | UPLL | PBCLK1 <sup>(1)</sup> | PBCLK2 | PBCLK3 | PBCLK4 | PBCLK6 | REFCLK01 | REFCLK02 | REFCLK03 | REFCLK04 | | ADC1-ADC7 | | | | | Х | | | | | | | | | | Х | | | CAN1-CAN4 | | | | | Х | | | | | | | | | | | Х | | CFG PMD | | | | | | | | Х | | | | | | | | | | CLKO(5) | | | | | | | | Х | | | | | | | | | | Comparator 1-5 | | | | | | | | | Х | | | | | | | | | CPU | Χ | Х | Х | Х | Х | Х | Х | | | | | | | | | | | CRU | | | | | | | | Х | | | | | | | | | | CTMU | | | | | | | | | Х | | | | | | | | | CDAC1 | | | | | | | | | Х | | | | | | | | | CDAC2-CDAC3 | | | | | | | | | | Х | | | | | | | | DATAEE | Х | | | | | | | | Х | | | | | | | | | DMA | | | | | Х | | | | | | | | | | | | | DMT | | | | | | | | Х | | | | | | | | | | EVIC | | | | | Х | | | | | | | | | | | | | Flash | Х | | | | Х | | | Х | | | | | | | | | | Input Capture 10-16 | | | | | | | | | | Х | | | | | | | | Input Capture 1-9 | | | | | | | | | Х | | | | | | | | | ICD | | | | | | | | Х | | | | | | | | | | Output Compare 10-16 | | | | | | | | | | Х | | | | | | | | Output Compare 1-9 | | | | | | | | | Х | | | | | | | | | Op amp 1-3, 5 | | | | | | | | | Х | | | | | | | | | PMP | | | | | | | | | Х | | | | | | | | | PORTA-PORTG | | | | | | | | | | | Х | | | | | | | PPS | | | | | | | | Х | | | | | Х | Х | Х | Х | | RTCC | | Х | Х | | | | | | | | | Х | | | | | | SPI1-SPI2 | | | | | | | | | Х | | | | Х | | | | | SPI3-SPI6 | | | | | | | | | | Х | | | Х | | | | | SSX Control | | | | | Х | | | | | | | | | | | | | Timer1 | | Х | Х | | | | | | Х | | | | | | | | | Timer2-Timer9 | | | | | | | | | Х | | | | | | | | | UART1-UART2 | Х | | | | Х | | | | Х | | | | Х | | | | | UART3-UART6 | Х | | | | Х | | | | | Х | | | Х | | | | | USB1-USB2 | Х | | | Х | Х | | Х | | | | | | | | | | | WDT | | Х | | | | | | Х | | | | | | | | | - Note 1: PBCLK1 is used by system modules and cannot be turned off. - 2: SYSCLK is used to fetch data from/to the Flash Controller, while the FRC clock is used for programming. - 3: Special Function Register (SFR) access only. - 4: Timer1 only. - **5:** PBCLK1 divided by 2 is available on CLKO function pin on oscillator in EC or FRC mode. ### 9.1 Fail-Safe Clock Monitor (FSCM) The PIC32MK GPK/MCM with CAN FD Family oscillator system includes a Fail-safe Clock Monitor (FSCM). The FSCM monitors the SYSCLK for continuous operation. If it detects that the SYSCLK has failed, it switches the SYSCLK over to the BFRC oscillator and triggers a NMI. When the NMI is executed, software can attempt to restart the main oscillator or shut down the system. In Sleep mode both the SYSCLK and the FSCM halt, which prevents FSCM detection. #### **Oscillator Control Registers** 9.2 #### **TABLE 9-2: OSCILLATOR CONFIGURATION REGISTER MAP** | SSS | | | | | | | | | | | Bits | | | | | | | | _ | |-----------------------------|-----------------------|---------------|-------|-------|-----------|-------|-------------|-------|-------------|--------------|---------------------------------------|------|---------|-------|-----------|--------|-------------|-------|---------------------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets <sup>(1)</sup> | | 1200 | OSCCON | 31:16 | _ | _ | _ | _ | _ | | FRCDIV<2:0 | > | DRMEN | | SLP2SPD | _ | _ | _ | _ | _ | 0xx0 | | 1200 | 0000011 | 15:0 | _ | | COSC<2:0> | | _ | | NOSC<2:0> | | CLKLOCK | ı | _ | SLPEN | CF | UFRCEN | SOSCEN | OSWEN | xxxx | | 1210 | OSCTUN | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | | | N<5:0> | | | 0020 | | 1220 | SPLLCON | 31:16 | _ | _ | _ | _ | _ | | PLLODIV<2:0 | | _ | | | P | LLMULT<6 | | | | 0xxx | | | | 15:0 | _ | _ | _ | _ | _ | | PLLIDIV<2:0 | | PLLICLK | _ | _ | | | | LLRANGE<2:0 | > | 0xxx | | 1230 | UPLLCON | 31:16 | _ | _ | UPOSCEN | _ | _ | | PLLODIV<2:0 | | _ | | | | LLMULT<6 | | | | 0xxx | | | | 15:0 | _ | _ | _ | _ | _ | | PLLIDIV<2:0 | > | | _ | _ | _ | _ | Р | LLRANGE<2:0 | > | 0x0x | | 1280 | REFO1CON | 31:16 | _ | | | | | | | | RODIV<14:0 | )> | | | | | | | 0000 | | | | 15:0 | ON | _ | SIDL | OE | RSLP | _ | DIVSWEN | ACTIVE | _ | _ | _ | | | 1 | EL<3:0> | | 0000 | | 1290 | REFO1TRIM | 31:16 | | | | 1 | ROTRIM<8:0 | | | | | _ | _ | _ | | _ | | _ | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | _ | _ | — — — — — — — — — — — — — — — — — — — | _ | _ | _ | _ | _ | _ | _ | 0000 | | 12A0 | REFO2CON | 31:16 | - | | l olbi | 0.5 | DOLD. | | D. 1014/EN | A O.T.I) (F. | RODIV<14:0 | | | | | 200 | FI 00 | | 0000 | | | | 15:0 | ON | _ | SIDL | OE | RSLP | | DIVSWEN | ACTIVE | _ | | _ | | | | EL<3:0> | | 0000 | | 12B0 | REFO2TRIM | 31:16 | | | | | ROTRIM<8:0 | | | | | | _ | | | | | _ | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | _ | _ | RODIV<14:0 | _ | _ | | _ | _ | _ | _ | 0000 | | 12C0 | REFO3CON | 31:16<br>15:0 | ON | | SIDL | OE | RSLP | _ | DIVSWEN | ACTIVE | RODIV< 14:0 | _ | _ | | | DOS | EL<3:0> | | 0000 | | | | 31:16 | ON | _ | SIDL | | ROTRIM<8:0 | | DIVSWEIN | ACTIVE | _ | _ | | | _ | _ KUS | | _ | 0000 | | 12D0 | REFO3TRIM | 15:0 | _ | _ | _ | _ | TOTRINI O.C | _ | _ | _ | _ | | _ | | | | | | 0000 | | - | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | RODIV<14:0 | | _ | | _ | _ | | _ | 0000 | | 12E0 | REFO4CON | 15:0 | ON | _ | SIDL | OE | RSLP | _ | DIVSWEN | ACTIVE | TODIV 14.0 | _ | _ | _ | | ROS | EL<3:0> | | 0000 | | | | 31:16 | OIV | | OIDL | | ROTRIM<8:0 | | DIVOVILIV | AOTIVE | | | | | _ | | | _ | 0000 | | 12F0 | REFO4TRIM | 15:0 | _ | _ | _ | _ | | _ | _ | _ | _ | _ | | | _ | _ | | _ | 0000 | | | | 31:16 | | _ | _ | | _ | | _ | | | | _ | | | _ | | _ | 0000 | | 1300 | PB1DIV | 15:0 | | _ | _ | | PBDIVRDY | | _ | _ | | | | | PBDIV<6:0 | > | | | 8801 | | | | 31:16 | _ | _ | _ | | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1310 | PB2DIV | 15:0 | ON | _ | _ | _ | PBDIVRDY | _ | _ | _ | _ | | | | PBDIV<6:0 | | | | 8801 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1320 | PB3DIV | 15:0 | ON | _ | _ | _ | PBDIVRDY | _ | _ | _ | _ | | | | PBDIV<6:0 | > | | | 8801 | | | | 31:16 | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1330 | PB4DIV | 15:0 | ON | _ | _ | _ | PBDIVRDY | _ | _ | _ | _ | | | | PBDIV<6:0 | > | | | 8801 | | | (2) | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1350 | PB6DIV <sup>(2)</sup> | 15:0 | ON | _ | _ | _ | PBDIVRDY | _ | _ | _ | _ | | | | PBDIV<6:0 | > | | | 8803 | | | l | | | | | | 1 | | | | | | | | | | | | | <sup>1:</sup> Reset values are dependent on the DEVCFGx Configuration bits and the type of reset. Refer to Table 37-16 in 37.0 "Electrical Characteristics" for PBCLK6 frequency limitations. #### **TABLE 9-2**: **OSCILLATOR CONFIGURATION REGISTER MAP (CONTINUED)** | sse | | Bits | | | | | | | _ | | | | | | | | | | | |----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|------------|---------|---------|------|---------|---------|------|---------|----------|--------|--------------------------| | Virtual Addres<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets <sup>(1</sup> | | 1200 | SI EMCON | 31:16 | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | | SYSE | )IV<3:0> | | 0000 | | 1300 | SLEWCON | 15:0 | _ | _ | | _ | _ | 5 | SLWDIV<2:0 | > | _ | _ | _ | _ | _ | UPEN | DNEN | BUSY | 0000 | | 1200 | CLIVOTAT | 31:16 | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1390 | CLKSTAT | 15:0 | _ | _ | _ | _ | _ | _ | _ | UPLLRDY | SPLLRDY | - | LPRCRDY | SOSCRDY | _ | POSCRDY | _ | FRCRDY | 0000 | PIC32MK GPK/MCM with CAN FD Family x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Legend: 1: Reset values are dependent on the DEVCFGx Configuration bits and the type of reset. Refer to Table 37-16 in 37.0 "Electrical Characteristics" for PBCLK6 frequency limitations. ### REGISTER 9-1: OSCCON: OSCILLATOR CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|----------------------| | 04.04 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 31:24 | - | _ | - | _ | _ | F | RCDIV<2:0> | | | 00.40 | R/W-0 | U-0 | R/W-y | U-0 | U-0 | U-0 | U-0 | U-0 | | 23:16 | DRMEN | _ | SLP2SPD | _ | _ | _ | _ | _ | | 45.0 | U-0 | R-0 | R-0 | R-0 | U-0 | R/W-y | R/W-y | R/W-y | | 15:8 | _ | | COSC<2:0> | | _ | | NOSC<2:0> | | | 7:0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0, HS | R/W-0 | R/W-y | R/W-y | | | CLKLOCK | _ | _ | SLPEN | CF | UFRCEN | SOSCEN | OSWEN <sup>(1)</sup> | Legend:y = Value set from Configuration bits on PORHS = Hardware SetR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-27 Unimplemented: Read as '0' bit 26-24 FRCDIV<2:0>: Internal Fast RC (FRC) Oscillator Clock Divider bits 111 = FRC divided by 256 110 = FRC divided by 64 101 = FRC divided by 32 100 = FRC divided by 16 011 = FRC divided by 8 010 = FRC divided by 4 001 = FRC divided by 2 000 = FRC divided by 1 (default setting) bit 23 DRMEN: Dream Mode Enable bit 1 = Dream mode is enabled 0 = Dream mode is disabled bit 22 Unimplemented: Read as '0' bit 21 SLP2SPD: Sleep Two-speed Start-up Control bit 1 = Use FRC as SYSCLK until the selected clock is ready 0 = Use the selected clock directly bit 20-15 Unimplemented: Read as '0' bit 14-12 COSC<2:0>: Current Oscillator Selection bits 111 = Reserved 110 = Backup Fast RC (BFRC) Oscillator 101 = Internal Low-Power RC (LPRC) Oscillator 100 = Secondary Oscillator (Sosc) 011 = USB PLL (UPLL) input clock and divider are set by UPLLCON 010 = Primary Oscillator (Posc) (HS or EC) 001 = System PLL (SPLL) input clock and divider set by SPLLCON 000 = Internal Fast RC (FRC) Oscillator divided by FRCDIV<2:0> bits (FRCDIV) supports FRN / N, where 'N' is 1, 2, 4, 8, 16, 32, 64, and 256 bit 11 **Unimplemented:** Read as '0' Note 1: The reset value for this bit depends on the setting of the IESO bit (DEVCFG1<7>). When IESO = 1, the reset value is '1'. When IESO = 0, the reset value is '0'. Note: Writes to this register require an unlock sequence. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. ### REGISTER 9-1: OSCCON: OSCILLATOR CONTROL REGISTER - bit 10-8 NOSC<2:0>: New Oscillator Selection bits - 111 = Reserved - 110 = Backup Fast RC (BFRC) Oscillator - 101 = Internal Low-Power RC (LPRC) Oscillator - 100 = Secondary Oscillator (Sosc) - 011 = USB PLL (UPLL) input clock and divider are set by UPLLCON - 010 = Primary Oscillator (Posc) (HS or EC) - 001 = System PLL (SPLL) input clock and divider set by SPLLCON - 000 = Internal Fast RC (FRC) Oscillator divided by FRCDIV<2:0> bits (FRCDIV) supports FRN/N, where N is 1, 2, 4, 8, 16, 32, 64, and 256 On Reset, these bits are set to the value of the FNOSC<2:0> Configuration bits (DEVCFG1<2:0>). bit 7 CLKLOCK: Clock Selection Lock Enable bit If clock switching and monitoring is disabled (FCKSM<1:0> = 1x): - 1 = Clock and PLL selections are locked - 0 = Clock and PLL selections are not locked and may be modified If clock switching and monitoring is enabled (FCKSM<1:0> = 0x): Clock and PLL selections are never locked and may be modified. Note: Setting the OSCCON<CLKLOCK> = 1 locks the OSCCON[PLLODIV, FRCDIV, PLLMULT, NOSC, CLKLOCK, SLPEN, UFRCEN, SOSCEN and OSWEN], SPLLCON, OSCTUN, and PBxDIV registers if the DEVCFG1<FCKSM> = x1 (i.e., Clock switching disabled). This is a hard lock and cannot be undone in software after being set. Requires a system reset to undo. CLKLOCK is not a configuration word bit but is superseded if DEVCFG1<FCKSM> = 0x (i.e., Clock switching enabled). The OSCCON<CLKLOCK>=1 or DEVCFG1<FCKSM> = x1, (i.e., Clock switching disabled) although a barrier to user software clock switching or clock control in general has NO EFFECT on two speed hardware clock switch DEVCFG1<IESO> = 1: Internal External Switchover mode is enabled (Two-Speed Start-up is enabled, FRC hardware clock switch to clock source defined by DEVCFG1<FNOSC>. - bit 6-5 **Unimplemented:** Read as '0' - bit 4 SLPEN: Sleep Mode Enable bit - 1 = Device will enter Sleep mode when a WAIT instruction is executed - 0 = Device will enter Idle mode when a WAIT instruction is executed - - 1 = FSCM has detected a clock failure - 0 = No clock failure has been detected Note: On a clock fail event if enabled by the FCKSM<1:0> bits (DEVCFG1<15:14>) = '0b11, this bit and the RNMICON<CF> bit will be set. The user software must clear both the bits inside the CF NMI before attempting to exit the ISR. Software or hardware settings of the CF bit (OSCCON<3>) will cause a CF NMI event and an automatic clock switch to the FRC provided the FCKSM<1:0> = '0b11. Unlike the CF bit (OSCCON<3>), software or hardware settings of the CF bit (RNMICON<17>) will cause a CF NMI event but will not cause a clock switch to the FRC. After a Clock Fail event, a successful user software clock switch if implemented, hardware will automatically clear the CF bit (RNMICON<17>), but not the CF bit (OSCCON<3>). The CF bit (OSCCON<3>) must be cleared by software using the OSCCON register unlock procedure. - bit 2 UFRCEN: USB FRC Sleep Clock Enable bit - 1 = FRC is the USB input clock for wake from Sleep mode - 0 = USB input clock is determined by the UPOSCEN bit (UPLLCON<29>) - bit 1 SOSCEN: Secondary Oscillator (Sosc) Enable bit - 1 = Enable Secondary Oscillator - 0 = Disable Secondary Oscillator - Note 1: The reset value for this bit depends on the setting of the IESO bit (DEVCFG1<7>). When IESO = 1, the reset value is '1'. When IESO = 0, the reset value is '0'. Note: Writes to this register require an unlock sequence. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. ### REGISTER 9-1: OSCCON: OSCILLATOR CONTROL REGISTER - bit 0 **OSWEN:** Oscillator Switch Enable bit<sup>(1)</sup> - 1 = Initiate an oscillator switch to selection specified by NOSC<2:0> bits - 0 = Oscillator switch is complete - **Note 1:** The reset value for this bit depends on the setting of the IESO bit (DEVCFG1<7>). When IESO = 1, the reset value is '1'. When IESO = 0, the reset value is '0'. Note: Writes to this register require an unlock sequence. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. ### REGISTER 9-2: OSCTUN: FRC TUNING REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|---------------------|------------------|------------------| | 31:24 | U-0 | | _ | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | R-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 23:16 | _ | _ | _ | _ | _ | - | - | | | 45.0 | U-0 | R-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7:0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | _ | _ | | | TUN< | 5:0> <sup>(1)</sup> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-6 Unimplemented: Read as '0' bit 5-0 **TUN<5:0>:** FRC Oscillator Tuning bits<sup>(1)</sup> 111111 **= +1.453**% • • 100000 = 0.000% (Nominal Center Frequency, default) • • 000000 =-1.500% **Note 1:** OSCTUN functionality has been provided to help customers compensate for temperature effects on the FRC frequency over a wide range of temperatures. The tuning step size is an approximation, and is neither characterized nor tested. Note: Writes to this register require an unlock sequence. Refer to the Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. ### REGISTER 9-3: SPLLCON: SYSTEM PLL CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 24.24 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-y | R/W-y | R/W-y | | | | | 31:24 | _ | _ | _ | _ | _ | F | PLLODIV<2:0 | <b>^</b> | | | | | 22.46 | U-0 | R/W-y | | | | 23:16 | _ | PLLMULT<6:0> | | | | | | | | | | | 45.0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-y | R/W-y | R/W-y | | | | | 15:8 | _ | | | | | I | PLLIDIV<2:0> | • | | | | | 7:0 | R/W-y | U-0 | U-0 | U-0 | U-0 | R/W-y | R/W-y | R/W-y | | | | | | PLLICLK | _ | _ | _ | _ | PL | LRANGE<2: | 0> | | | | Legend:y = Value set from Configuration bits on PORR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown ``` bit 31-27 Unimplemented: Read as '0' ``` bit 26-24 PLLODIV<2:0>: System PLL Output Clock Divider bits 111 = Reserved 110 = Reserved 101 = PLL Divide by 32 100 = PLL Divide by 16 011 = PLL Divide by 8 010 = PLL Divide by 4 001 = PLL Divide by 2 000 = Reserved The default setting is specified by the FPLLODIV<2:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in **34.0** "Special Features" for information. bit 23 Unimplemented: Read as '0' bit 22-16 PLLMULT<6:0>: System PLL Multiplier bits 1111111 = Multiply by 128 1111110 = Multiply by 127 1111101 = Multiply by 126 1111100 = Multiply by 125 • • • 0000000 = Multiply by 1 The default setting is specified by the FPLLMULT<6:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in **34.0** "Special Features" for information. bit 15-11 Unimplemented: Read as '0' - Note 1: Writes to this register require an unlock sequence. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. - 2: Writes to this register are not allowed if the SPLL is selected as a clock source (COSC<2:0> = 001). - 3: While the PLL is active, and if updating the PLL bits in the OSCCON register at run-time, the user application must remain within the following limits at all times for all nodes in the PLL clock tree. Therefore, the order in which the PLL values may be modified, (i.e., PLLODIV, PLLMULT, PLLODIV) becomes important. Failure to maintain PLL nodes within min/max ranges may result in unstable PLL and system behavior. - Output and input to PLLIDIV block (i.e., FPLLI) 5 MHz to 64 MHz (min/max at all times) - VCO output, (i.e., FVCO) 350 MHz to 700 MHz (min/max at all times) - Output of PLLODIV, (i.e., FPLL) 10 MHz to 120 MHz (min/max at all times) ### REGISTER 9-3: SPLLCON: SYSTEM PLL CONTROL REGISTER bit 10-8 PLLIDIV<2:0>: System PLL Input Clock Divider bits ``` 111 = Divide by 8 110 = Divide by 7 101 = Divide by 6 100 = Divide by 5 011 = Divide by 4 010 = Divide by 3 001 = Divide by 2 000 = Divide by 1 ``` The default setting is specified by the FPLLIDIV<2:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in **34.0** "**Special Features**" for information. If the PLLICLK is set for FRC, this setting is ignored by the PLL and the divider is set to Divide-by-1. bit 7 PLLICLK: System PLL Input Clock Source bit - 1 = FRC is selected as the input to the System PLL - 0 = Posc is selected as the input to the System PLL The POR default is specified by the FPLLICLK Configuration bit in the DEVCFG2 register. Refer to Register 34-5 in **34.0** "Special Features" for information. bit 6-3 Unimplemented: Read as '0' bit 2-0 PLLRANGE<2:0>: System PLL Frequency Range Selection bits 111 = Reserved 110 = 54-64 MHz 101 = 34-64 MHz 100 = 21-42 MHz 011 = 13-26 MHz 010 = 8-16 MHz 001 = 5-10 MHz 000 = Bypass Use the highest filter range that covers the input freq to the VCO multiplier block that corresponds to the PLLIDIV output freq to minimize PLL system jitter (see Figure 9-1). For example, Crystal = 20 MHz, PLLIDIV<2:0> = 0b1; therefore, the filter input frequency is equal to 10 MHz, and therefore, PLLRANGE<2:0> = 0b010. The default setting is specified by the FPLLRNG<2:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in 34.0 "Special Features" for information. - Note 1: Writes to this register require an unlock sequence. Refer to **Section 42**. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. - 2: Writes to this register are not allowed if the SPLL is selected as a clock source (COSC<2:0> = 001). - 3: While the PLL is active, and if updating the PLL bits in the OSCCON register at run-time, the user application must remain within the following limits at all times for all nodes in the PLL clock tree. Therefore, the order in which the PLL values may be modified, (i.e., PLLODIV, PLLMULT, PLLODIV) becomes important. Failure to maintain PLL nodes within min/max ranges may result in unstable PLL and system behavior. - Output and input to PLLIDIV block (i.e., FPLLI) 5 MHz to 64 MHz (min/max at all times) - VCO output, (i.e., FVCO) 350 MHz to 700 MHz (min/max at all times) - Output of PLLODIV, (i.e., FPLL) 10 MHz to 120 MHz (min/max at all times) ### REGISTER 9-4: UPLLCON: USB PLL CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 31:24 | U-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 31.24 | _ | _ | UPOSCEN | _ | _ | F | PLLODIV<2:0 | > | | | | | 23:16 | U-0 | R/W-0 | | | | 23.10 | _ | PLLMULT<6:0> | | | | | | | | | | | 15:8 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 13.6 | _ | | | | | ı | PLLIDIV<2:0> | • | | | | | 7:0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | _ | _ | _ | _ | _ | PL | LRANGE<2: | 0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-30 Unimplemented: Read as '0' bit 29 **UPOSCEN:** Output Enable bit 1 = USB input clock is Posc 0 = USB input clock is UPLL bit 28-27 Unimplemented: Read as '0' bit 26-24 PLLODIV<2:0>: System PLL Output Clock Divider bits 111 = Reserved 110 = Reserved 101 = PLL Divide by 32 100 = PLL Divide by 16 011 = PLL Divide by 8 010 = PLL Divide by 4 001 = PLL Divide by 2 000 = Reserved The default setting is specified by the FPLLODIV<2:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in **34.0** "Special Features" for information. bit 23 Unimplemented: Read as '0' - Note 1: Writes to this register require an unlock sequence. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. - 2: Writes to this register are not allowed if the UPLL is selected as a clock source (COSC<2:0> = 001). - 3: While the PLL is active, and if updating the PLL bits in the OSCCON register at run-time, the user application must remain within the following limits at all times for all nodes in the PLL clock tree. Therefore, the order in which the PLL values may be modified, (i.e., PLLODIV, PLLMULT, PLLODIV) becomes important. Failure to maintain PLL nodes within min/max ranges may result in unstable PLL and system behavior. - Output and input to PLLIDIV block (i.e., FPLLI) 5 MHz to 64 MHz (min/max at all times) - VCO output, (i.e., FVCO) 350 MHz to 700 MHz (min/max at all times) - Output of PLLODIV, (i.e., FPLL) 10 MHz to 120 MHz (min/max at all times) ### REGISTER 9-4: UPLLCON: USB PLL CONTROL REGISTER bit 22-16 PLLMULT<6:0>: System PLL Multiplier Output Clock Divider bits ``` 1111111 = Multiply by 128 1111110 = Multiply by 127 1111101 = Multiply by 126 . . 0000010 = Multiply by 3 0000001 = Multiply by 2 0000000 = Multiply by 1 ``` The default setting is specified by the FPLLMULT<6:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in **34.0** "Special Features" for information. bit 15-11 Unimplemented: Read as '0' bit 10-8 PLLIDIV<2:0>: System PLL Input Clock Divider bits ``` 111 = Divide by 8 110 = Divide by 7 101 = Divide by 6 100 = Divide by 5 011 = Divide by 4 010 = Divide by 3 001 = Divide by 2 000 = Divide by 1 ``` The default setting is specified by the FPLLIDIV<2:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in 34.0 "Special Features" for information. If the PLLICLK is set for FRC, this setting is ignored by the PLL and the divider is set to Divide-by-1. bit 7-3 **Unimplemented:** Read as '0' bit 2-0 PLLRANGE<2:0>: System PLL Frequency Range Selection bits ``` 111 = Reserved 110 = 54-90 MHz 101 = 34-68 MHz 100 = 21-42 MHz 011 = 13-26 MHz 010 = 8-16 MHz 001 = 5-10 MHz 000 = Bypass ``` Use the highest filter range that covers the input freq to the VCO multiplier block that corresponds to the PLLIDIV output freq to minimize PLL system jitter (see Figure 9-1). For example, Crystal = 20 MHz, PLLIDIV<2:0> = 0b1; therefore, the filter input frequency is equal to 10 MHz, and therefore, PLLRANGE<2:0> = 0b010. The default setting is specified by the FPLLRNG<2:0> Configuration bits in the DEVCFG2 register. Refer to Register 34-5 in 34.0 "Special Features" for information. - Note 1: Writes to this register require an unlock sequence. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. - 2: Writes to this register are not allowed if the UPLL is selected as a clock source (COSC<2:0> = 001). - 3: While the PLL is active, and if updating the PLL bits in the OSCCON register at run-time, the user application must remain within the following limits at all times for all nodes in the PLL clock tree. Therefore, the order in which the PLL values may be modified, (i.e., PLLODIV, PLLMULT, PLLODIV) becomes important. Failure to maintain PLL nodes within min/max ranges may result in unstable PLL and system behavior. - Output and input to PLLIDIV block (i.e., FPLLI) 5 MHz to 64 MHz (min/max at all times) - VCO output, (i.e., FVCO) 350 MHz to 700 MHz (min/max at all times) - Output of PLLODIV, (i.e., FPLL) 10 MHz to 120 MHz (min/max at all times) ### REGISTER 9-5: REFOxCON: REFERENCE OSCILLATOR CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-----------------------|-------------------|-----------------------|-----------------------|--|--|--|--|--| | 24.24 | U-0 | R/W-0 | R/W-0 | N-0 R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | | | | | | | 31:24 | _ | | | | | | | | | | | | | | 22.46 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 R/W-0 R/W-0 | | R/W-0 | | | | | | | | 23:16 | | RODIV<7:0> | | | | | | | | | | | | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0, HC | R-0, HS, HC | | | | | | | 15:8 | ON <sup>(1)</sup> | _ | SIDL | OE | RSLP <sup>(2)</sup> — | | DIVSWEN | ACTIVE <sup>(1)</sup> | | | | | | | 7.0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | 7:0 | _ | _ | _ | _ | | ROSEL | .<3:0> <sup>(3)</sup> | | | | | | | **Legend:** HC = Hardware Cleared HS = Hardware Set R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 Unimplemented: Read as '0' bit 30-16 RODIV<14:0> Reference Clock Divider bits The value selects the reference clock divider bits (see Figure 9-1 for details). A value of '0' selects no divider. bit 15 **ON:** Output Enable bit<sup>(1)</sup> 1 = Reference Oscillator Module enabled0 = Reference Oscillator Module disabled bit 14 Unimplemented: Read as '0' bit 13 SIDL: Peripheral Stop in Idle Mode bit 1 = Discontinue module operation when the device enters Idle mode 0 = Continue module operation in Idle mode bit 12 **OE:** Reference Clock Output Enable bit 1 = Reference clock is driven out on REFCLKOx pin 0 = Reference clock is not driven out on REFCLKOx pin bit 11 RSLP: Reference Oscillator Module Run in Sleep bit<sup>(2)</sup> 1 = Reference Oscillator Module output continues to run in Sleep 0 = Reference Oscillator Module output is disabled in Sleep bit 10 Unimplemented: Read as '0' bit 9 **DIVSWEN:** Divider Switch Enable bit 1 = Divider switch is in progress 0 = Divider switch is complete bit 8 ACTIVE: Reference Clock Request Status bit (1) 1 = Reference clock request is active 0 = Reference clock request is not active bit 7-4 Unimplemented: Read as '0' **Note 1:** Do not write to this register when the ON bit is not equal to the ACTIVE bit. 2: This bit is ignored when the ROSEL<3:0> bits = 0000 or 0001. 3: The ROSEL<3:0> bits should not be written while the ACTIVE bit is '1', as undefined behavior may result. Note: REFOx pin output freq = (ROSEL, Reference Clock Source Freq / (2 \* (RODIV + (ROTRIM / 512)) For REFOx resulting frequencies that constitute a fractional result, the circuit will produce an average clock rate, meaning that the circuit will steal cycles from the input clock source such that the REFOx clock output over a period of cycles will average out to the desired frequency. For this reason, unless the resulting clock output is a whole integer value, it is not recommend for use as a clock source for ADC or asynchronous peripherals like CAN or UART do to the resulting jitter and clock rate uncertainty. ### REGISTER 9-5: REFOxCON: REFERENCE OSCILLATOR CONTROL REGISTER ('x' = 1-4) bit 3-0 **ROSEL<3:0>:** Reference Clock Source Select bits<sup>(3)</sup> 1111 = Reserved • . . 1001 = Reserved 1000 **= REFCLKI** 0111 = SPLL 0110 = UPLL 0101 = Sosc 0100 = LPRC 0011 = FRC 0010 = Posc 0001 = PBCLK1 0000 = SYSCLK Note 1: Do not write to this register when the ON bit is not equal to the ACTIVE bit. 2: This bit is ignored when the ROSEL<3:0> bits = 0000 or 0001. 3: The ROSEL<3:0> bits should not be written while the ACTIVE bit is '1', as undefined behavior may result. Note: REFOx pin output freq = (ROSEL, Reference Clock Source Freq / (2 \* (RODIV + (ROTRIM / 512)) For REFOx resulting frequencies that constitute a fractional result, the circuit will produce an average clock rate, meaning that the circuit will steal cycles from the input clock source such that the REFOx clock output over a period of cycles will average out to the desired frequency. For this reason, unless the resulting clock output is a whole integer value, it is not recommend for use as a clock source for ADC or asynchronous peripherals like CAN or UART do to the resulting jitter and clock rate uncertainty. ### REGISTER 9-6: REFOxTRIM: REFERENCE OSCILLATOR TRIM REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R/W-0 | 31:24 | | | • | ROTRIN | л<8:1> | • | | • | | 23:16 | R/W-0 | R-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 23.10 | ROTRIM<0> | _ | _ | - | _ | _ | _ | _ | | 45.0 | U-0 | R-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 | 7:0 | _ | _ | | | _ | | | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-23 ROTRIM<8:0>: Reference Oscillator Trim bits 111111111 = 511/512 divisor added to RODIV value 111111110 = 510/512 divisor added to RODIV value • • 100000000 = 256/512 divisor added to RODIV value • • 000000010 = 2/512 divisor added to RODIV value 000000001 = 1/512 divisor added to RODIV value 000000000 = 0 divisor added to RODIV value ### bit 22-0 Unimplemented: Read as '0' - **Note 1:** While the ON bit (REFOxCON<15>) is '1', writes to this register do not take effect until the DIVSWEN bit is also set to '1'. - 2: Do not write to this register when the ON bit (REFOxCON<15>) is not equal to the ACTIVE bit (REFOxCON<8>). - 3: Specified values in this register do not take effect if RODIV<14:0> (REFOxCON<30:16>) = 0. - 4: REFCLKOx Frequency = ((Selected Source Clock / 2) \* (N + (M / 512))) where, Selected source clock = ROSEL, N = RODIV<14:0>, and M = ROTRIM<8:0>. If the value of REFCLKOx Frequency is not a whole integer value, the output clock will have jitter as it will cause the REFCLKOx circuit to clock cycle steal to produce an average frequency equivalent to the user application's desired frequency. The amount of jitter, (i.e., clock cycle steals), become less as the fractional remainder value becomes closer to a whole number and is greatest at any value plus 0.5. Note: REFOx pin output freq = (ROSEL, Reference Clock Source Freq / (2 \* (RODIV + (ROTRIM / 512)) For REFOx resulting frequencies that constitute a fractional result, the circuit will produce an average clock rate, meaning that the circuit will steal cycles from the input clock source such that the REFOx clock output over a period of cycles will average out to the desired frequency. For this reason, unless the resulting clock output is a whole integer value, it is not recommend for use as a clock source for ADC or asynchronous peripherals like CAN or UART do to the resulting jitter and clock rate uncertainty. # REGISTER 9-7: PBxDIV: PERIPHERAL BUS 'x' CLOCK DIVISOR CONTROL REGISTER ('x' = 1-4. 6) | | | , ., | | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|----------------------| | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00:40 | U-0 U-0 | | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-1 | U-0 | U-0 | U-0 | R-1 | U-0 | U-0 | U-0 | | 15:8 | ON <sup>(1)</sup> | _ | _ | _ | PBDIVRDY | - | _ | _ | | 7.0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-1 <sup>(2)</sup> | | 7:0 | _ | | | | PBDIV<6:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 **ON:** Peripheral Bus 'x' Output Clock Enable bit (1) 1 = Output clock is enabled 0 = Output clock is disabled bit 14-12 **Unimplemented:** Read as '0' bit 11 **PBDIVRDY:** Peripheral Bus 'x' Clock Divisor Ready bit 1 = Clock divisor logic is not switching divisors and the PBxDIV<6:0> bits may be written 0 = Clock divisor logic is currently switching values and the PBxDIV<6:0> bits cannot be written bit 10-7 Unimplemented: Read as '0' bit 6-0 **PBDIV<6:0>:** Peripheral Bus 'x' Clock Divisor Control bits 11111111 = PBCLKx is SYSCLK divided by 128 11111110 = PBCLKx is SYSCLK divided by 127 • • 0000011 = PBCLKx is SYSCLK divided by 4 (default value for x = 6) 0000010 = PBCLKx is SYSCLK divided by 3 0000001 = PBCLKx is SYSCLK divided by 2 (default value for x < 6) 0000000 = PBCLKx is SYSCLK divided by 1 (default value for x = 7) **Note 1:** The clock for Peripheral Bus 1 cannot be turned off. Therefore, the ON bit in the PB1DIV register cannot be written as a '0'. Note: Writes to this register require an unlock sequence. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. #### REGISTER 9-8: SLEWCON: OSCILLATOR SLEW CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|----------------------------|------------------|------------------|--| | 31:24 | U-0 | | 31.24 | _ | | | _ | _ | _ | _ | _ | | | 00.46 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | _ | _ | _ | _ | | SYSDIV<3:0> <sup>(1)</sup> | | | | | 45.0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | | 15:8 | _ | _ | _ | _ | _ | ; | SLWDIV<2:0> | > | | | 7.0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R-0, HS, HC | | | 7:0 | _ | _ | | _ | - | UPEN | DNEN | BUSY | | Legend:HC = Hardware ClearedHS = Hardware SetR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-20 Unimplemented: Read as '0' bit 19-16 SYSDIV<3:0>: System Clock Divide Control bits<sup>(1)</sup> 1111 = SYSCLK is divided by 16 1110 = SYSCLK is divided by 15 : • 0010 = SYSCLK is divided by 3 0001 = SYSCLK is divided by 2 0000 = SYSCLK is not divided bit 15-11 Unimplemented: Read as '0' bit 10-8 **SLWDIV<2:0>:** Slew Divisor Steps Control bits These bits control the maximum division steps used when slewing during a frequency change. 111 = Steps are divide by 128, 64, 32, 16, 8, 4, 2, and then no divisor 110 = Steps are divide by 64, 32, 16, 8, 4, 2, and then no divisor 101 = Steps are divide by 32, 16, 8, 4, 2, and then no divisor 100 = Steps are divide by 16, 8, 4, 2, and then no divisor 011 = Steps are divide by 8, 4, 2, and then no divisor 010 = Steps are divide by 4, 2, and then no divisor 001 = Steps are divide by 2, and then no divisor 000 = No divisor is used during slewing The steps apply in reverse order (i.e., 2, 4, 8, etc.) during a downward frequency change. bit 7-3 Unimplemented: Read as '0' bit 2 **UPEN:** Upward Slew Enable bit 1 = Slewing enabled for switching to a higher frequency 0 = Slewing disabled for switching to a higher frequency bit 1 **DNEN:** Downward Slew Enable bit 1 = Slewing enabled for switching to a lower frequency 0 = Slewing disabled for switching to a lower frequency bit 0 BUSY: Clock Switching Slewing Active Status bit 1 = Clock frequency is being actively slewed to the new frequency 0 = Clock switch has reached its final value Note 1: The SYSDIV<3:0> bit settings are ignored if both UPEN and DNEN = 0, and SYSCLK will be divided by 1. #### REGISTER 9-9: CLKSTAT: OSCILLATOR CLOCK STATUS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 U-0 U-0 | | U-0 | U-0 | U-0 | | 31.24 | _ | _ | | | _ | - | | _ | | 22.46 | U-0 | 23:16 | _ | _ | - | - | _ | - | | <b>24/16/8/0</b> U-0 — | | 45.0 | U-0 R-0 | | 15:8 | _ | _ | _ | | | _ | | UPLLRDY | | 7.0 | R-0 | U-0 | R-0 | R-0 U-0 R-0 | | R-0 | U-0 | R-0 | | 7:0 | SPLLRDY | _ | LPRCRDY | SOSCRDY | _ | POSCRDY | _ | FRCRDY | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-9 Unimplemented: Read as '0' bit 8 UPLLRDY: USB PLL (UPLL) Ready Status bit 1 = UPLL is ready0 = UPLL is not ready bit 7 SPLLRDY: System PLL (SPLL) Ready Status bit 1 = SPLL is ready0 = SPLL is not ready bit 5 LPRCRDY: Low-Power RC (LPRC) Oscillator Ready Status bit 1 = LPRC is stable and ready 0 = LPRC is disabled or not operating bit 4 SOSCRDY: Secondary Oscillator (Sosc) Ready Status bit 1 = Sosc is stable and ready 0 = Sosc is disabled or not operating bit 3 Unimplemented: Read as '0' bit 2 POSCRDY: Primary Oscillator (Posc) Ready Status bit 1 = Posc is stable and ready 0 = Posc is disabled or not operating bit 1 Unimplemented: Read as '0' bit 0 FRCRDY: Fast RC (FRC) Oscillator Ready Status bit 1 = FRC is stable and ready 0 = FRC is disabled for not operating | NOTES: | | | |--------|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 10.0 PREFETCH MODULE Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 4.** "**Prefetch Cache Module**" (DS60001119), which is available from the *Documentation > Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). The Prefetch module is a performance enhancing module that is included in the PIC32MK GPK/MCM with CAN FD Family of devices. When running at high-clock rates, Wait states must be inserted into Program Flash Memory (PFM) read transactions to meet the access time of the PFM. Wait states can be hidden to the core by prefetching and storing instructions in a temporary holding area that the CPU can access quickly. Although the data path to the CPU is 32 bits wide, the data path to the PFM is 128 bits wide. This wide data path provides the same bandwidth to the CPU as a 32-bit path running at four times the frequency. The Prefetch module holds a subset of PFM in temporary holding spaces known as lines. Each line contains a tag and data field. Normally, the lines hold a copy of what is currently in memory to make instructions or data available to the CPU without Flash Wait states. ### 10.1 Prefetch Cache Features - · 36x16 byte fully-associative lines - · 16 lines for CPU instructions - · Four lines for CPU data - · Four lines for peripheral data - · 16-byte parallel memory fetch - · Configurable predictive prefetch A simplified block diagram of the Prefetch module is shown in Figure 10-1. FIGURE 10-1: PREFETCH MODULE BLOCK DIAGRAM ### 10.2 Prefetch Control Registers ### TABLE 10-1: PREFETCH REGISTER MAP | ess | | 0 | | | | | | | | В | its | | | | | | | | 8 | |-----------------------------|---------------------------------|-----------|--------------------------------------------------|--------------------|-------|-------|--------|----------|--------|--------|---------|---------------|---------|---------|------|---------------|---------|---------|-----------| | Virtual Address<br>(BF80_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | 0000 | | 31:16 | _ | _ | _ | _ | _ | PERCHEEN | DCHEEN | ICHEEN | _ | PER<br>CHEINV | DCHEINV | ICHEINV | _ | PER<br>CHECOH | DCHECOH | ICHECOH | 0700 | | 0800 | CHECON | 15:0 | 5:0 — — CHE — — PFM — — PREFEN<1:0> — PFMWS<3:0> | | | | | | | | • | 0107 | | | | | | | | | 0040 | CUECTAT | 31:16 | - | _ | _ | _ | PFMDED | PFMSEC | _ | | _ | _ | _ | 1 | _ | _ | _ | _ | 0000 | | 0810 | CHESTAT | 15:0 | | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | 1 | _ | _ | _ | _ | 0000 | | 0000 | CHEHIT | 31:16 | | | | • | • | | • | CHEHIT | <31:16> | | • | • | | • | • | • | 0000 | | 0020 | CHEHII | 15:0 | | CHEHIT<15:0> 0000 | | | | | | | | | | | | | | | | | 0000 | CHEMIC | 31:16 | • | CHEMIS<31:16> 0000 | | | | | | | | | | | | | | | | | 0830 | CHEMIS | 15:0 | • | CHEMIS<15:0> 0000 | | | | | | | | | | | | | | | | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. #### REGISTER 10-1: CHECON: CACHE MODULE CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|------------------------------|------------------------|------------------------|-------------------|------------------------------|------------------------|--------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 R/W-1 | | R/W-1 | | 31.24 | _ | | | _ | _ | PERCHEEN | DCHEEN | ICHEEN | | | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | _ | PER<br>CHEINV <sup>(1)</sup> | DCHEINV <sup>(1)</sup> | ICHEINV <sup>(1)</sup> | _ | PER<br>CHECOH <sup>(2)</sup> | DCHECOH <sup>(2)</sup> | 17/9/1 24/16/8/0 | | | U-0 | U-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | R/W-1 | | 15:8 | _ | _ | _ | CHE<br>PERFEN | _ | _ | _ | | | 7:0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-1 | R/W-1 | R/W-1 | | 7.0 | _ | _ | PREFE | N<1:0> | | PFM | WS<3:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-27 Unimplemented: Read as '0' bit 26 PERCHEEN: Peripheral Cache Enable bit 1 = Peripheral cache is enabled0 = Peripheral cache is disabled bit 25 DCHEEN: Data Cache Enable bit 1 = Data cache is enabled 0 = Data cache is disabled bit 24 ICHEEN: Instruction Cache Enable bit 1 = Instruction cache is enabled0 = Instruction cache is disabled bit 23 Unimplemented: Read as '0' bit 22 **PERCHEINV:** Peripheral Cache Invalidate bit<sup>(1)</sup> 1 = Force invalidate cache/invalidate busy 0 = Cache Invalidation follows CHECOH/invalid complete bit 21 **DCHEINV:** Data Cache Invalidate bit<sup>(1)</sup> 1 = Force invalidate cache/invalidate busy 0 = Cache Invalidation follows CHECOH/invalid complete bit 20 **ICHEINV:** Instruction Cache Invalidate bit<sup>(1)</sup> 1 = Force invalidate cache/invalidate busy 0 = Cache Invalidation follows CHECOH/invalid complete bit 19 Unimplemented: Read as '0' bit 18 **PERCHECOH:** Peripheral Auto-cache Coherency Control bit<sup>(2)</sup> 1 = Automatically invalidate cache on a programming event 0 = Do not automatically invalidate cache on a programming event bit 17 **DCHECOH:** Data Auto-cache Coherency Control bit<sup>(2)</sup> 1 = Automatically invalidate cache on a programming event 0 = Do not automatically invalidate cache on a programming event Note 1: Hardware automatically clears this bit when cache invalidate completes. Bits may clear at different times. 2: The PERCHECOH, DCHECOH, and ICHECOH bits must be stable before initiation of programming. ### REGISTER 10-1: CHECON: CACHE MODULE CONTROL REGISTER (CONTINUED) bit 16 ICHECOH: Instruction Auto-cache Coherency Control bit (2) 1 = Automatically invalidate cache on a programming event 0 = Do not automatically invalidate cache on a programming event bit 15-13 Unimplemented: Read as '0' bit 12 CHEPERFEN: Cache Performance Counters Enable bit 1 = Performance counters are enabled 0 = Performance counters are disabled bit 11-9 Unimplemented: Read as '0' bit 8 **PFMAWSEN:** PFM Address Wait State Enable bit 1 = Add one more Wait State to Flash address setup (suggested for higher system clock frequencies) 0 = Add no Wait States to the Flash address setup (suggested for lower system clock frequencies to achieve higher performance) When this bit is set to '1', total Flash wait states are PFMWS plus PFMAWSEN. bit 7-6 **Unimplemented:** Read as '0' bit 5-4 **PREFEN<1:0>:** Predictive Prefetch Enable bits 11 = Disable predictive prefetch 10 = Disable predictive prefetch 01 = Enable predictive prefetch for CPU instructions only 00 = Disable predictive prefetch bit 3-0 PFMWS<3:0>: PFM Access Time Defined in Terms of SYSCLK Wait States bits 0111 = Seven Wait states • • 0010 = Two Wait states 0001 = One Wait state 0000 = Zero Wait states | DEVCFG0<9:8> | Required Flash Wait States<br>PFMWS<3:0> bits | SYSCLK (MHz) | |--------------------------------------------|-----------------------------------------------|-------------------------------| | FECCCON<1:0> bits | 1 - Wait State | 0 < SYSCLK ≤ 110 MHz | | (DEVCFG0<9:8>) = 0x1x<br>with ECC disabled | 2 - Wait State | 110 MHz < SYSCLK ≤ 120<br>MHz | | FECCCON<1:0> bits | 1 - Wait State | 0 < SYSCLK ≤ 96 MHz | | (DEVCFG0<9:8>) = 0x0x<br>with ECC enabled | 2 - Wait State | 96 MHz < SYSCLK ≤ 120 MHz | - Note 1: Hardware automatically clears this bit when cache invalidate completes. Bits may clear at different times. - 2: The PERCHECOH, DCHECOH, and ICHECOH bits must be stable before initiation of programming. ### REGISTER 10-2: CHEHIT: CACHE HIT STATUS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | | |------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--|--| | 21:24 | R/W-0 | | | | | | | | 31.24 | | | | CHEHIT | <31:24> | | | | | | | | | | | | 22:16 | R/W-0 | | | | | | | | 31:24 —<br>23:16 —<br>15:8 — | | CHEHIT<23:16> | | | | | | | | | | | | | | | 15.0 | R/W-0 | | | | | | | | 15.6 | | | | CHEHI | Γ<15:8> | | | | | | | | | | | | 7:0 | R/W-0 | | | | | | | | 7.0 | CHEHIT<7:0> | | | | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-0 CHEHIT<31:0>: Instruction Cache Hit Count bits When the CHEPERFEN bit (CHECON<12>) = 1, the CHEHIT<31:0> bits increment each time the processor issues an instruction fetch or load that hits the prefetch cache from a cacheable region. Non-cacheable accesses do not modify this value. The CHEHIT<31:0> bits are reset on a '0' to '1' transition of the CHEPERFEN bit. ### REGISTER 10-3: CHEMIS: CACHE MISS STATUS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|--------------------------------------------------------| | 31:24 | R/W-0 | R/W-0 | R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31.24 | | • | • | CHEMIS | | | • | | | 23:16 | R/W-0 | 23.10 | | | | CHEMIS | <23:16> | | | 7/9/1 24/16/8/0<br>V-0 R/W-0<br>V-0 R/W-0<br>V-0 R/W-0 | | 15:8 | R/W-0 | 15.6 | | | | CHEMIS | S<15:8> | | | | | 7:0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 R/W-0 R/W-0 | | R/W-0 | R/W-0 | | 7.0 | | | | CHEMI | S<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-0 CHEMIS<31:0>: Instruction Cache Miss Count bits When the CHEPERFEN bit (CHECON<12>) = 1, the CHEMIS<31:0> bits increment each time the processor issues an instruction fetch or load that hits the prefetch cache from a cacheable region. Non-cacheable accesses do not modify this value. The CHEMIS<31:0> bits are reset on a '0' to '1' transition of the CHEPERFEN bit. # 11.0 DIRECT MEMORY ACCESS (DMA) CONTROLLER Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 31. "Direct Memory Access (DMA) Controller" (DS60001117), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The Direct Memory Access (DMA) Controller is a bus initiator module useful for data transfers between different devices without CPU intervention. The source and destination of a DMA transfer can be any of the memory mapped modules existent in the device, such as SPI, UART, PMP, etc., or memory itself. The following are some of the key features of the DMA Controller module: - · Eight identical channels, each featuring: - Auto-increment source and destination address registers - Source and destination pointers - Memory-to-memory and memory-toperipheral transfers - · Automatic word-size detection: - Transfer granularity, down to byte level - Bytes need not be word-aligned at source and destination - · Fixed priority channel arbitration - · Flexible DMA channel operating modes: - Manual (software) or automatic (interrupt) DMA requests - One-Shot or Auto-Repeat Block Transfer modes - Channel-to-channel chaining - · Flexible DMA requests: - A DMA request can be selected from any of the peripheral interrupt sources - Each channel can select any (appropriate) observable interrupt as its DMA request source - A DMA transfer abort can be selected from any of the peripheral interrupt sources - Up to 2-byte Pattern (data) match transfer termination - · Multiple DMA channel status interrupts: - DMA channel block transfer complete - Source empty or half empty - Destination full or half full - DMA transfer aborted due to an external event - Invalid DMA address generated - · DMA debug support features: - Most recent error address accessed by a DMA channel - Most recent DMA channel to transfer data - · CRC Generation module: - CRC module can be assigned to any of the available channels - CRC module is highly configurable ### FIGURE 11-1: DMA BLOCK DIAGRAM ### 11.1 DMA Control Registers ### TABLE 11-1: DMA GLOBAL REGISTER MAP | ess | | 0 | | | | | | | | Bi | ts | | | | | | | | <b>"</b> | |-----------------------------|---------------------------------|-----------|-------|-------|-------|---------|---------|-------|------|----------|---------|------|------|------|------|------|----------|------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1000 | DMACON | 31:16 | | | _ | _ | | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | DIVIACON | 15:0 | ON | - | _ | SUSPEND | DMABUSY | I | | | _ | | 1 | _ | 1 | 1 | _ | _ | 0000 | | 1010 | DMASTAT | 31:16 | RDWR | - | _ | _ | _ | I | | | _ | | 1 | _ | 1 | 1 | _ | _ | 0000 | | 1010 | DIVIASTAT | 15:0 | | - | _ | _ | _ | I | | | _ | | 1 | _ | 1 | | MACH<2:0 | > | 0000 | | 1020 | DMAADDR | 31:16 | | | • | | • | | | DMAADD | D-21:0> | • | | | | | • | • | 0000 | | 1020 | DIVIAADDR | 15:0 | | | | | | | | DIVIAADL | K<31.02 | | | | | | | | 0000 | **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information PIC32MK GPK/MCM with CAN FD Family ### TABLE 11-2: DMA CRC REGISTER MAP | ess | | | | | | | | | | Ві | ts | | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-----------|------|--------|----------|--------|--------|------|------|------|----------|------|-----------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | 1020 | DCRCCON | 31:16 | _ | _ | BYTO | <1:0> | WBO | _ | _ | BITO | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1030 | DCRCCON | 15:0 | _ | _ | _ | | | PLEN<4:0> | | | CRCEN | CRCAPP | CRCTYP | _ | _ | C | RCCH<2:0 | > | 0000 | | 1040 | DCRCDATA | 31:16 | | | | | | | | DCBCDA | TA<31:0> | | | | | | | | 0000 | | 1040 | DCRCDAIA | 15:0 | | | | | | | | DONODA | IA\51.02 | | | | | | | | 0000 | | 1050 | DCRCXOR | 31:16 | | | | | | | | DCRCXC | D-21:05 | | | | | | | | 0000 | | 1000 | DUNUXUK | 15:0 | | | | | | | | DONONO | 71.07 | | | | | | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 11-3: DMA CHANNEL 0 THROUGH CHANNEL 7 REGISTER MAP | ess | | | | | | | | | | Bit | s | | | | | | | | | |-----------------------------|---------------------------------|---------------|--------|-------------|----------|--------|---------------|-------|------|--------|--------|--------|--------|--------|--------|--------|-----------|------------------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | DCHOCON | 31:16 | | | | CHPIG | SN<7:0> | | | | _ | _ | _ | _ | _ | _ | 1 | _ | 0000 | | 1060 | DCH0CON | 15:0 | CHBUSY | _ | CHPIGNEN | _ | CHPATLEN | _ | _ | CHCHNS | CHEN | CHAED | CHCHN | CHAEN | _ | CHEDET | CHPR | I<1:0> | 0000 | | 1070 | DCH0ECON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | Q<7:0> | | | 1 | OOFF | | 1070 | | 15:0 | | | | CHSIF | RQ<7:0> | | ı | | CFORCE | CABORT | PATEN | SIRQEN | AIRQEN | _ | | _ | FF00 | | 1080 | DCH0INT | 31:16 | _ | | _ | | _ | | _ | _ | CHSDIE | CHSHIE | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE | CHERIE | | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | CHSDIF | CHSHIF | CHDDIF | CHDHIF | CHBCIF | CHCCIF | CHTAIF | CHERIF | | | 1090 | DCH0SSA | 31:16 | | | | | | | | CHSSA | <31:0> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | | | | | | | | | | 0000 | | 10A0 | DCH0DSA | 31:16<br>15:0 | | | | | | | | CHDSA- | <31:0> | | | | | | | | 0000 | | | | 31:16 | _ | | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 10B0 | DCH0SSIZ | 15:0 | | | | | | | | CHSSIZ | <15·0> | | | | | | | | 0000 | | | | 31:16 | _ | | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 10C0 | DCH0DSIZ | 15:0 | | | | | | | | CHDSIZ | <15:0> | | | | | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 10D0 | DCH0SPTR | 15:0 | | | 1 | | 1 | | | CHSPTR | <15:0> | | | | | | | | 0000 | | 4050 | DOLLODDID | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 10E0 | DCH0DPTR | 15:0 | | | | | | | | CHDPTR | <15:0> | | | | | | | | 0000 | | 1050 | DCH0CSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | DCHUCSIZ | 15:0 | | | | | | | | CHCSIZ | <15:0> | | | | | | | | 0000 | | 1100 | DCH0CPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1100 | B011001 111 | 15:0 | | | | | | | ı | CHCPTR | <15:0> | 1 | | 1 | 1 | | | 1 | 0000 | | 1110 | DCH0DAT | 31:16 | _ | _ | _ | | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CHPDAT | <15:0> | | | | | | | | 0000 | | 1120 | DCH1CON | 31:16 | | | | CHPIC | SN<7:0> | | 1 | | | | | | _ | _ | _ | | 0000 | | | | 15:0 | CHBUSY | | CHPIGNEN | | CHPATLEN | | _ | CHCHNS | CHEN | CHAED | CHCHN | CHAEN | | CHEDET | CHPR | l<1:0> | 0000 | | 1130 | DCH1ECON | 31:16 | | | _ | —<br>— | — <u> </u> | | _ | _ | 050505 | CARORT | DATEN | | Q<7:0> | | | | 00FF | | | | 15:0 | | | | CHSIF | RQ<7:0> | | | | CHERT | CABORT | PATEN | SIRQEN | AIRQEN | | - CLITAIE | - CHEDIE | FF00 | | 1140 | DCH1INT | 31:16 | _ | | | | | | _ | | CHSDIE | CHSHIE | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE | CHERIE<br>CHERIF | | | - | | 15:0 | _ | _ | | | | _ | _ | _ | | CHSHIF | CHDDIF | CHDHIF | CHBCIF | CHCCIF | CHTAIF | CHEKIF | 0000 | | 1150 | DCH1SSA | 31:16<br>15:0 | | CHSSA<31:0> | | | | | | | | | | | | | | | | | | | 31:16 | | | | | | | | | | | | | | | | | 0000 | | 1160 | DCH1DSA | 15:0 | | | | | | | | CHDSA- | <31:0> | | | | | | | | 0000 | | <u> </u> | | | · | | | | s 'n' Reset v | | | | | | | | | | | | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 11-3: DMA CHANNEL 0 THROUGH CHANNEL 7 REGISTER MAP (CONTINUED) | SSS | | | | | | | | | | Bits | 5 | | | | | | | | | |-----------------------------|---------------------------------|---------------|--------|----------|----------|-------|----------|----------|------|-----------|-------------|--------|--------|--------|--------|--------|--------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1170 | DCH1SSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | BOITTOOLE | 15:0 | | | | | | | 1 | CHSSIZ | <15:0> | | | | | ı | | ı | 0000 | | 1180 | DCH1DSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | 1 | | | | | CHDSIZ | <15:0> | | | | | | | | 0000 | | 1190 | DCH1SPTR | 31:16 | _ | | _ | | _ | | _ | | | | _ | _ | | _ | | _ | 0000 | | | | 15:0 | | | | | | | | CHSPTR | <15:0> | | | | | | | | 0000 | | 11A0 | DCH1DPTR | 31:16 | _ | | _ | _ | _ | _ | _ | - CUIDITI | -45.0: | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CHDPTR | | | | | | | | | 0000 | | 11B0 | DCH1CSIZ | 31:16<br>15:0 | _ | | _ | _ | _ | | _ | CHCSIZ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 31:16 | _ | | | _ | _ | | _ | CHCSIZ | | | _ | _ | | | | _ | 0000 | | 11C0 | DCH1CPTR | 15:0 | _ | <u>—</u> | | | _ | <u> </u> | | CHCPTR | <br><15:0> | | | | | | | _ | 0000 | | | | 31:16 | _ | | _ | _ | _ | | _ | | — | _ | _ | _ | _ | _ | _ | _ | 0000 | | 11D0 | DCH1DAT | 15:0 | | | | | | | | CHPDAT | | | | | | | | | 0000 | | | | 31:16 | | | | CHPIG | N<7·0> | | | 0 2 | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 11E0 | DCH2CON | | CHBUSY | | CHPIGNEN | | CHPATLEN | | _ | CHCHNS | CHEN | CHAED | CHCHN | CHAEN | _ | CHEDET | CHPF | !<1:0> | 0000 | | | | 31:16 | _ | | _ | _ | _ | | _ | _ | | | | CHAIR | | | | | OOFF | | 11F0 | DCH2ECON | 15:0 | | | | CHSIR | Q<7:0> | | | | CFORCE | CABORT | PATEN | SIRQEN | AIRQEN | _ | _ | _ | FF00 | | 1000 | DOLLOW IT | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | CHSDIE | CHSHIE | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE | CHERIE | 0000 | | 1200 | DCH2INT | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | CHSDIF | CHSHIF | CHDDIF | CHDHIF | CHBCIF | CHCCIF | CHTAIF | CHERIF | 0000 | | 1210 | DCH2SSA | 31:16 | | | | | | | | CHSSA< | :31:0> | | | | | • | | • | 0000 | | | | 15:0 | | | | | | | | | | | | | | | | | 0000 | | 1220 | DCH2DSA | 31:16 | | | | | | | | CHDSA< | :31:0> | | | | | | | | 0000 | | | | 15:0 | | | 1 | | | | | | | | | | | | | l | 0000 | | 1230 | DCH2SSIZ | 31:16<br>15:0 | _ | | _ | | _ | | _ | CHSSIZ | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | | | | | | | | | CHOOK | 15:0> | | | | | | | | 0000 | | 1240 | DCH2DSIZ | 31:16<br>15:0 | _ | | _ | | _ | | _ | CHDSIZ | —<br><15:0> | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 31:16 | _ | | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1250 | DCH2SPTR | 15:0 | | | | | | | | CHSPTR | <15:0> | | | | | | | | 0000 | | 4000 | DOLIODD== | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1260 | DCH2DPTR | 15:0 | | | | | | | | CHDPTR | <15:0> | | | | | | | | 0000 | | 4070 | DOLL00017 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1270 | DCH2CSIZ | 15:0 | | | | | | | | CHCSIZ | <15:0> | | | | | | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. | sse | | | | | | | | | | Bits | s | | | | | | | | | |-----------------------------|---------------------------------|---------------|--------|----------|----------|----------|----------|-------|------|--------|--------------|------------|----------|---------|--------|--------|------------------|------------------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | DCUIOCDED | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | 0000 | | 1200 | DCH2CPTR | 15:0 | | | | | | | | CHCPTR | <15:0> | | | | | | | | 0000 | | 1290 | DCH2DAT | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | | 1 | _ | _ | 0000 | | 1290 | DCHZDAI | 15:0 | | | | | | | | CHPDAT | <15:0> | | | | | | | | 0000 | | 12A0 | DCH3CON | 31:16 | | | | CHPIG | N<7:0> | | | | | _ | | _ | _ | _ | _ | _ | 0000 | | 12/40 | DCH3CON | 15:0 | CHBUSY | | CHPIGNEN | | CHPATLEN | | _ | CHCHNS | CHEN | CHAED | CHCHN | CHAEN | _ | CHEDET | CHPR | tl<1:0> | 0000 | | 12B0 | DCH3ECON | 31:16 | _ | _ | _ | | _ | | _ | _ | | | | CHAIR | | | | 1 | OOFF | | | | 15:0 | | | | CHSIR | Q<7:0> | | | | CFORCE | CABORT | PATEN | SIRQEN | AIRQEN | | —<br>OUTA15 | | FF00 | | 12C0 | DCH3INT | 31:16<br>15:0 | _ | _ | _ | | _ | | _ | _ | CHSDIE | CHSHIE | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE<br>CHTAIF | CHERIE<br>CHERIF | 0000 | | | | 31:16 | | <u> </u> | _ | <u> </u> | _ | | _ | | | CHOIM | CHIDDII | CHDHIII | CHECH | CHCCII | CITIAII | CHERT | 0000 | | 12D0 | DCH3SSA | 15:0 | | | | | | | | CHSSA< | 31:0> | | | | | | | | 0000 | | 4050 | DOLLODOA | 31:16 | | | | | | | | OUDOA | .0.1.0. | | | | | | | | 0000 | | 12E0 | DCH3DSA | 15:0 | | | | | | | | CHDSA< | 31:0> | | | | | | | | 0000 | | 12F0 | DCH3SSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | | - | _ | _ | 0000 | | 121 0 | BOITOGGIZ | 15:0 | | | | | | | ı | CHSSIZ | <15:0> | | | | | | ı | 1 | 0000 | | 1300 | DCH3DSIZ | 31:16 | _ | _ | _ | _ | _ | | _ | | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CHDSIZ | <15:0> | | | | | | | | 0000 | | 1310 | DCH3SPTR | 31:16<br>15:0 | _ | | _ | | _ | | _ | CHSPTR | <15:0> | _ | | _ | | _ | _ | _ | 0000 | | | | 31:16 | _ | _ | | | _ | _ | _ | | <del> </del> | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1320 | DCH3DPTR | 15:0 | | | | | | | | CHDPTR | <15:0> | | | | | | | | 0000 | | 4000 | DOL120017 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1330 | DCH3CSIZ | 15:0 | | | | | | | | CHCSIZ | <15:0> | | | | | | | | 0000 | | 1340 | DCH3CPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CHCPTR | <15:0> | | | | | | | | 0000 | | 1350 | DCH3DAT | 31:16<br>15:0 | _ | _ | _ | | _ | _ | _ | CHPDAT | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 31:16 | | | | CHPIG | N-7:0> | | | CHPDAI | <15:0> | | | | | | | | - | | 1360 | DCH4CON | 15:0 | CHBUSY | | CHPIGNEN | | CHPATLEN | | _ | CHCHNS | CHEN | —<br>CHAED | CHCHN | CHAEN | | CHEDET | —<br>CHPR | 2 <1:0> | 0000 | | | | 31:16 | _ | | | _ | _ | | _ | _ | J. 12.11 | 3111112 | 31101111 | CHAIR | | SHEDET | | 1.0 | 0000 | | 1370 | DCH4ECON | 15:0 | | | | CHSIR | Q<7:0> | | | | CFORCE | CABORT | PATEN | SIRQEN | AIRQEN | _ | _ | _ | FF00 | | 1200 | DCHAINT | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | CHSDIE | CHSHIE | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE | CHERIE | 0000 | | 1380 | DCH4INT | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | CHSDIF | CHSHIF | CHDDIF | CHDHIF | CHBCIF | CHCCIF | CHTAIF | CHERIF | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Legend: Note 1: All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 11-3: DMA CHANNEL 0 THROUGH CHANNEL 7 REGISTER MAP (CONTINUED) | ess | | | | | | | | | | Bit | S | | | | | | | | ۱., | |-----------------------------|---------------------------------|---------------|----------|-------|---------------|-------|---------------|-------|------|-------------|------------------|---------------|-----------------|----------------|------------------|-------------|-------------|-------------|--------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | DCH4SSA | 31:16<br>15:0 | | | | | | | | CHSSA | :31:0> | | | | | | | | 0000 | | 13A0 | DCH4DSA | 31:16<br>15:0 | | | | | | | | CHDSA | <31:0> | | | | | | | | 0000 | | 13B0 | DCH4SSIZ | 31:16<br>15:0 | _ | _ | _ | _ | _ | _ | _ | CHSSIZ- | <u> </u> | _ | _ | _ | _ | _ | _ | _ | 0000 | | 13C0 | DCH4DSIZ | 31:16<br>15:0 | _ | _ | _ | _ | _ | _ | _ | CHDSIZ- | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 13D0 | DCH4SPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 13E0 | DCH4DPTR | 15:0<br>31:16 | _ | _ | _ | _ | _ | _ | _ | CHSPTR | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 13F0 | DCH4CSIZ | 15:0<br>31:16 | _ | _ | _ | _ | _ | _ | _ | CHDPTR | _ | _ | _ | _ | _ | _ | _ | _ | 000 | | 1400 | DCH4CPTR | 15:0<br>31:16 | _ | _ | _ | _ | _ | _ | _ | CHCSIZ- | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1410 | DCH4DAT | 15:0<br>31:16 | _ | _ | _ | _ | _ | _ | _ | CHCPTR | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0<br>31:16 | | | | CHPIG | SN<7:0> | | | CHPDAT | <15:0><br>— | _ | _ | _ | _ | _ | _ | _ | 0000 | | | DCH5CON | 15:0<br>31:16 | CHBUSY — | _ | CHPIGNEN<br>— | _ | CHPATLEN<br>— | _ | _ | CHCHNS | CHEN | CHAED | CHCHN | CHAEN<br>CHAIR | —<br>Q<7:0> | CHEDET | CHPR | l<1:0> | 0000<br>00FE | | 1430 | DCH5ECON | 15:0 | _ | | | CHSIR | Q<7:0> | | | _ | CFORCE<br>CHSDIE | CABORT CHSHIE | PATEN<br>CHDDIE | SIRQEN | AIRQEN<br>CHBCIE | —<br>CHCCIE | —<br>CHTAIE | —<br>CHERIE | FF00 | | 1440 | DCH5IN1 | 31:16<br>15:0 | _ | | _ | | _ | _ | _ | _ | CHSDIF | CHSHIF | CHDDIE | CHDHIF | CHBCIE | CHCCIE | CHTAIF | CHERIF | 0000 | | 1450 | DCH5SSA | 31:16<br>15:0 | | | | | | | | CHSSA | 31:0> | | | | | | | | 0000 | | 1460 | DCH5DSA | 31:16<br>15:0 | | | | | | | | CHDSA | 31:0> | | | | | | | | 0000 | | 1470 | DCH5SSIZ | 31:16<br>15:0 | 1 | _ | _ | _ | _ | _ | _ | - CHSSIZ | —<br><15:0> | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1480 | DCH5DSIZ | 31:16<br>15:0 | _ | _ | _ | _ | _ | _ | _ | CHDSIZ- | —<br><15:0> | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1490 | DCH5SPTR | 31:16<br>15:0 | _ | _ | _ | _ | _ | _ | _ | —<br>CHSPTR | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | PIC32MK GPK/MCM with CAN FD Family x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more | DS60 | |--------| | Ō | | õ | | 0 | | ŏ | | 8 | | ュ | | S | | | | 9 | | 9E | | Υ. | | ਰ | | page | | Ō | | ē | | | | $\sim$ | | 200 | | 0 | | | | | | TABLE 11-3: DMA CH | IANNEL 0 THROUGH CH | IANNEL 7 REGISTER MAP | (CONTINUED) | |--------------------|---------------------|-----------------------|-------------| |--------------------|---------------------|-----------------------|-------------| | ess | | • | | | | | | | | Bit | s | | | | | | | | | |-----------------------------|---------------------------------|---------------|-----------|-------|--------------|-------|----------|-------|------|-------------|---------|--------|---------|---------|------------------|----------|---------|----------------------------------------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1440 | DCH5DPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1-7/10 | | 15:0 | | | | | | | | CHDPTR | <15:0> | | 1 | | 1 | | | | 0000 | | 14B0 | DCH5CSIZ | 31:16 | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | ı | CHCSIZ | <15:0> | | | | | | | 1 | 0000 | | 14C0 | DCH5CPTR | 31:16 | — | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | 1 | | | | | CHCPTR | <15:0> | 1 | | | | ı | | | 0000 | | 14D0 | DCH5DAT | 31:16 | _ | | _ | | _ | | _ | OLIDDAT | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CHPDAT | | | | | | | | | 0000 | | 14E0 | DCH6CON | 31:16 | 011011011 | | lou proviewi | CHPIG | N<7:0> | | | l au au mua | | | | | | | _ | <u> </u> | 0000 | | | | 15:0 | CHBUSY | | CHPIGNEN | | CHPATLEN | | _ | CHCHNS | CHEN | CHAED | CHCHN | CHAEN | —<br>0 :7.0: | CHEDET | СНРБ | l<1:0> | 0000 | | 14F0 | DCH6ECON | 31:16 | _ | _ | _ | | - 1 | | _ | _ | CFORCE | CABORT | PATEN | CHAIR | | | | | 00FF | | | | 15:0 | | | | Спык | Q<7:0> | | | | CHSDIE | CHSHIE | CHDDIE | CHDHIE | AIRQEN<br>CHBCIE | - CHCCIE | CHTAIE | CHERIE | FF00 | | 1500 | DCH6INT | 31:16<br>15:0 | _ | | _ | | _ | | _ | _ | CHSDIF | CHSHIF | CHDDIE | CHDHIF | CHBCIE | CHCCIE | CHTAIF | CHERIF | 0000 | | | | 31:16 | | | _ | | | | _ | _ | | CHOIM | CHIDDII | CHDIIII | Cribon | Criccii | CITIAII | CHERN | 0000 | | 1510 | DCH6SSA | 15:0 | | | | | | | | CHSSA | <31:0> | | | | | | | | 0000 | | | | 31:16 | | | | | | | | | | | | | | | | | 0000 | | 1520 | DCH6DSA | 15:0 | | | | | | | | CHDSA | <31:0> | | | | | | | | 0000 | | 4500 | DOLL00017 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1530 | DCH6SSIZ | 15:0 | | | • | | | | • | CHSSIZ | <15:0> | • | | | | | • | • | 0000 | | 15.40 | DCH6DSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1540 | DCH0D3IZ | 15:0 | | | | | | | | CHDSIZ | <15:0> | | | | | | | | 0000 | | 1550 | DCH6SPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | DOI 1001 110 | 15:0 | | | | | | | | CHSPTR | <15:0> | | 1 | | 1 | | | | 0000 | | 1560 | DCH6DPTR | 31:16 | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | | 15:0 | | | | | | | 1 | CHDPTR | <15:0> | 1 | | | | 1 | ı | 1 | 0000 | | 1570 | DCH6CSIZ | 31:16 | _ | | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CHCSIZ | <15:0> | | | | | | | 1 | 0000 | | 1580 | DCH6CPTR | 31:16 | _ | _ | _ | | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CHCPTR | <15:0> | | | | | | | | 0000 | | 1590 | DCH6DAT | 31:16 | _ | | _ | _ | _ | _ | _ | CUIDD AT | -415:05 | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | OUE | N -7 0: | | | CHPDAT | <15:0> | | | | | | | | 0000 | | 15A0 | DCH7CON | 31:16 | CLIBLICY | | CUDIONEN | CHPIG | N<7:0> | | | CHCHNO | - CHEN | CHAFE | | CHAEN | | CHEDET | —<br>— | —————————————————————————————————————— | 0000 | | Legen | | | CHBUSY | | CHPIGNEN | | CHPATLEN | | | CHCHNS | CHEN | CHAED | CHCHN | CHAEN | _ | CHEDET | CHPF | l<1:0> | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Legend: All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 11-3: DMA CHANNEL 0 THROUGH CHANNEL 7 REGISTER MAP (CONTINUED) | SSS | | | | | | | | | | Bit | | | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|--------|-------|------|--------|--------|--------|--------|--------|--------|--------|--------|--------|------------| | Virtual Address<br>(BF81_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 15B0 | DCH7ECON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | | CHAIR | Q<7:0> | | | | 00FF | | 1000 | DOITIEGOIN | 15:0 | | | | CHSIR | Q<7:0> | | | | CFORCE | | PATEN | SIRQEN | | _ | _ | _ | FF00 | | 15C0 | DCH7INT | 31:16 | | _ | _ | _ | _ | _ | | _ | CHSDIE | | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE | CHERIE | | | 1000 | DOMINIT | 15:0 | | _ | _ | _ | _ | _ | _ | _ | CHSDIF | CHSHIF | CHDDIF | CHDHIF | CHBCIF | CHCCIF | CHTAIF | CHERIF | | | 1500 | DCH7SSA | 31:16 | | | | | | | | CHSSA- | :31.0> | | | | | | | | 0000 | | 1300 | DOITIOUA | 15:0 | | | | | | | | CHOOK | 31.02 | | | | | | | | 0000 | | 15E0 | DCH7DSA | 31:16 | | | | | | | | CHDSA- | <31·0> | | | | | | | | 0000 | | 1020 | | 15:0 | | | | | | | | ONDON | -01.0- | | | | | | | | 0000 | | 15F0 | DCH7SSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 101 0 | BOITTOOLE | 15:0 | | | | | | | | CHSSIZ | <15:0> | | | | | | | | 0000 | | 1600 | DCH7DSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | | 15:0 | | | | | | | | CHDSIZ | <15:0> | | | | | | | | 0000 | | 1610 | DCH7SPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1010 | | 15:0 | | | | | | | | CHSPTR | <15:0> | | | | | | | | 0000 | | 1620 | DCH7DPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1020 | BOINBI III | 15:0 | | | | | | | | CHDPTR | <15:0> | | | | | | | | 0000 | | 1630 | DCH7CSIZ | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | | 15:0 | | | | | | | | CHCSIZ | <15:0> | | | | | | | | 0000 | | 1640 | DCH7CPTR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1340 | | 15:0 | | | | | | | | | | | | | 0000 | | | | | | 1650 | DCH7DAT | 31:16 | _ | _ | _ | _ | _ | _ | | _ | | _ | | _ | _ | _ | _ | _ | 0000 | | 1000 | 201112711 | 15:0 | | | | | | | | CHPDAT | <15:0> | | | | | | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more REGISTER 11-1: DMACON: DMA CONTROLLER CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|------------------------|-------------------|-------------------|------------------|------------------| | 21.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | | 15:8 | ON | _ | _ | SUSPEND <sup>(1)</sup> | DMABUSY | - | _ | _ | | 7.0 | U-0 | 7:0 | _ | _ | _ | _ | _ | _ | _ | _ | Legend: bit 12 R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 ON: DMA On bit 1 = DMA module is enabled0 = DMA module is disabledbit 14-13 Unimplemented: Read as '0' SUSPEND: DMA Suspend bit(1) 1 = DMA transfers are suspended to allow CPU uninterrupted access to data bus 0 = DMA operates normally bit 11 DMABUSY: DMA Module Busy bit 1 = DMA module is active and is transferring data 0 = DMA module is disabled and not actively transferring data bit 10-0 Unimplemented: Read as '0' **Note 1:** If the user application clears this bit, it may take a number of cycles before the DMA module completes the current transaction and responds to this request. The user application should poll the BUSY bit to verify that the request has been honored. ### REGISTER 11-2: DMASTAT: DMA STATUS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R-0 | U-0 | 31:24 | RDWR | _ | - | _ | _ | - | _ | _ | | 23:16 | U-0 | 23.10 | | _ | | - | _ | | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | U-0 | U-0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | | 7:0 | | _ | 1 | | _ | | DMACH<2:0> | • | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 RDWR: Read/Write Status bit 1 = Last DMA bus access when an error was detected was a read 0 = Last DMA bus access when an error was detected was a write bit 30-3 **Unimplemented:** Read as '0' bit 2-0 **DMACH<2:0>:** DMA Channel bits These bits contain the value of the most recent active DMA channel when an error was detected. **Note:** The DMASTAT register will be cleared when its contents are read. If more than one errors at the same time, the read transaction will be recorded. Additional transfers that occur later with an error will not update this register until it has been read or cleared. ### REGISTER 11-3: DMAADDR: DMA ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.04 | R-0 | | | 31:24 | DMAADDR<31:24> | | | | | | | | | | | 00.40 | R-0 | | | 23:16 | DMAADDR<23:16> | | | | | | | | | | | 45.0 | R-0 | | | 15:8 | DMAADDR<15:8> | | | | | | | | | | | 7.0 | R-0 | | | 7:0 | DMAADDR<7:0> | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-0 DMAADDR<31:0>: DMA Module Address bits These bits contain the address of the most recent DMA access when an error was detected. **Note:** The DMAADDR register will be cleared when its contents are read. If more than one errors at the same time, the read transaction will be recorded. Additional transfers that occur later with an error will not update this register until it has been read or cleared. #### REGISTER 11-4: DCRCCON: DMA CRC CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-----------------------|-------------------|-------------------|--------------------|-------------------|------------------|------------------| | 04:04 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | | 31:24 | _ | _ | BYTO | <1:0> | WBO <sup>(1)</sup> | _ | _ | BITO | | 23:16 | U-0 | 23.10 | | _ | _ | _ | _ | _ | - | _ | | 45.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15:8 | _ | _ | _ | PLEN<4:0>(1,2,3) | | | | | | 7.0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | CRCEN | CRCAPP <sup>(1)</sup> | CRCTYP | _ | _ | ( | CRCCH<2:0> | • | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-30 Unimplemented: Read as '0' bit 29-28 BYTO<1:0>: CRC Byte Order Selection bits - 11 = Endian byte swap on half-word boundaries (i.e., source half-word order with reverse source byte order per half-word) - 10 = Swap half-words on word boundaries (i.e., reverse source half-word order with source byte order per half-word) - 01 = Endian byte swap on word boundaries (i.e., reverse source byte order) - 00 = No swapping (i.e., source byte order) - bit 27 WBO: CRC Write Byte Order Selection bit (1) - 1 = Source data is written to the destination re-ordered as defined by BYTO<1:0> - 0 = Source data is written to the destination unaltered - bit 26-25 Unimplemented: Read as '0' - bit 24 BITO: CRC Bit Order Selection bit When CRCTYP (DCRCCON<15>) = 1 (CRC module is in IP Header mode): - 1 = The IP header checksum is calculated Least Significant bit (LSb) first (i.e., reflected) - 0 = The IP header checksum is calculated Most Significant bit (MSb) first (i.e., not reflected) When CRCTYP (DCRCCON<15>) = 0 (CRC module is in LFSR mode): - 1 = The LFSR CRC is calculated Least Significant bit first (i.e., reflected) - 0 = The LFSR CRC is calculated Most Significant bit first (i.e., not reflected) - bit 23-13 Unimplemented: Read as '0' - bit 12-8 PLEN<4:0>: Polynomial Length bits<sup>(1,2,3)</sup> When CRCTYP (DCRCCON<15>) = $\underline{1}$ (CRC module is in IP Header mode): These bits are unused. When CRCTYP (DCRCCON<15>) = 0 (CRC module is in LFSR mode): Denotes the length of the polynomial – 1. bit 7 CRCEN: CRC Enable bit - 1 = CRC module is enabled and channel transfers are routed through the CRC module - 0 = CRC module is disabled and channel transfers proceed normally - **Note 1:** When WBO = 1, unaligned transfers are not supported and the CRCAPP bit cannot be set. - 2: The maximum CRC length supported by the DMA module is 32. - 3: This bit is unused when CRCTYP is equal to '1'. ### REGISTER 11-4: DCRCCON: DMA CRC CONTROL REGISTER (CONTINUED) - bit 6 CRCAPP: CRC Append Mode bit<sup>(1)</sup> - 1 = The DMA transfers data from the source into the CRC but NOT to the destination. When a block transfer completes the DMA writes the calculated CRC value to the location given by CHxDSA - 0 = The DMA transfers data from the source through the CRC obeying WBO as it writes the data to the destination - bit 5 CRCTYP: CRC Type Selection bit - 1 = The CRC module will calculate an IP header checksum - 0 = The CRC module will calculate a LFSR CRC - bit 4-3 Unimplemented: Read as '0' - bit 2-0 CRCCH<2:0>: CRC Channel Select bits - 111 = CRC is assigned to Channel 7 - 110 = CRC is assigned to Channel 6 - 101 = CRC is assigned to Channel 5 - 100 = CRC is assigned to Channel 4 - 011 = CRC is assigned to Channel 3 - 010 = CRC is assigned to Channel 2 - 001 = CRC is assigned to Channel 1 - 000 = CRC is assigned to Channel 0 - Note 1: When WBO = 1, unaligned transfers are not supported and the CRCAPP bit cannot be set. - 2: The maximum CRC length supported by the DMA module is 32. - 3: This bit is unused when CRCTYP is equal to '1'. #### REGISTER 11-5: DCRCDATA: DMA CRC DATA REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.04 | R/W-0 | | | 31:24 | DCRCDATA<31:24> | | | | | | | | | | | 00.40 | R/W-0 | | | 23:16 | DCRCDATA<23:16> | | | | | | | | | | | 45.0 | R/W-0 | | | 15:8 | DCRCDATA<15:8> | | | | | | | | | | | 7.0 | R/W-0 | | | 7:0 | | | | DCRCDA | ΓA<7:0> | | | | | | | Legend: | | | | |-------------------|------------------|---------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, re | ead as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | ### bit 31-0 DCRCDATA<31:0>: CRC Data Register bits Writing to this register will seed the CRC generator. Reading from this register will return the current value of the CRC. Bits greater than PLEN will return '0' on any read. When CRCTYP (DCRCCON<15>) = 1 (CRC module is in IP Header mode): Only the lower 16 bits contain IP header checksum information. The upper 16 bits are always '0'. Data written to this register is converted and read back in 1's complement form (i.e., current IP header checksum value). When CRCTYP (DCRCCON<15>) = 0 (CRC module is in LFSR mode): Bits greater than PLEN will return '0' on any read. #### REGISTER 11-6: DCRCXOR: DMA CRCXOR ENABLE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R/W-0 | | | 31:24 | DCRCXOR<31:24> | | | | | | | | | | | 22.40 | R/W-0 | | | 23:16 | DCRCXOR<23:16> | | | | | | | | | | | 45.0 | R/W-0 | | | 15:8 | | | | DCRCXO | R<15:8> | | | | | | | 7.0 | R/W-0 | | | 7:0 | | | | DCRCXO | R<7:0> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-0 DCRCXOR<31:0>: CRC XOR Register bits When CRCTYP (DCRCCON<15>) = 1 (CRC module is in IP Header mode): This register is unused. When CRCTYP (DCRCCON<15>) = 0 (CRC module is in LFSR mode): - 1 = Enable the XOR input to the Shift register - 0 = Disable the XOR input to the Shift register; data is shifted in directly from the previous stage in the register REGISTER 11-7: DCHxCON: DMA CHANNEL 'x' CONTROL REGISTER ('x' = 0-7) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|---------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|-----------------------| | 24.24 | R/W-0 | 31:24 | | | • | CHPIG | N<7:0> | • | | | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | | _ | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | | 15:8 | CHBUSY | _ | CHIPGNEN | _ | CHPATLEN | | _ | CHCHNS <sup>(1)</sup> | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R-0 | R/W-0 | R/W-0 | | 7:0 | CHEN <sup>(2)</sup> | CHAED | CHCHN | CHAEN | _ | CHEDET | CHPF | RI<1:0> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' #### bit 31-24 CHPIGN<7:0>: Channel Register Data bits Pattern Terminate mode: Any byte matching these bits during a pattern match may be ignored during the pattern match determination when the CHPIGNEN bit is set. If a byte is read that is identical to this data byte, the pattern match logic will treat it as a "don't care" when the pattern matching logic is enabled and the CHPIGEN bit is set. bit 23-16 Unimplemented: Read as '0' bit 15 CHBUSY: Channel Busy bit 1 = Channel is active or has been enabled 0 = Channel is inactive or has been disabled bit 14 Unimplemented: Read as '0' bit 13 CHPIGNEN: Enable Pattern Ignore Byte bit 1 = Treat any byte that matches the CHPIGN<7:0> bits as a "don't care" when pattern matching is enabled 0 = Disable this feature bit 12 Unimplemented: Read as '0' bit 11 CHPATLEN: Pattern Length bit 1 = 2 byte length 0 = 1 byte length bit 10-9 **Unimplemented:** Read as '0' bit 8 CHCHNS: Chain Channel Selection bit (1) 1 = Chain to channel lower in natural priority (CH1 will be enabled by CH2 transfer complete) 0 = Chain to channel higher in natural priority (CH1 will be enabled by CH0 transfer complete) bit 7 CHEN: Channel Enable bit<sup>(2)</sup> 1 = Channel is enabled 0 = Channel is disabled bit 6 CHAED: Channel Allow Events If Disabled bit 1 = Channel start/abort events will be registered, even if the channel is disabled 0 = Channel start/abort events will be ignored if the channel is disabled bit 5 **CHCHN:** Channel Chain Enable bit 1 = Allow channel to be chained 0 = Do not allow channel to be chained Note 1: The chain selection bit takes effect when chaining is enabled (i.e., CHCHN = 1). When the channel is suspended by clearing this bit, the user application should poll the CHBUSY bit (if available on the device variant) to see when the channel is suspended, as it may take some clock cycles to complete a current transaction before the channel is suspended. ### REGISTER 11-7: DCHxCON: DMA CHANNEL 'x' CONTROL REGISTER ('x' = 0-7) (CONTINUED) - bit 4 CHAEN: Channel Automatic Enable bit - 1 = Channel is continuously enabled, and not automatically disabled after a block transfer is complete - 0 = Channel is disabled on block transfer complete - bit 3 Unimplemented: Read as '0' - bit 2 CHEDET: Channel Event Detected bit - 1 = An event has been detected - 0 = No events have been detected - bit 1-0 CHPRI<1:0>: Channel Priority bits - 11 = Channel has priority 3 (highest) - 10 = Channel has priority 2 - 01 = Channel has priority 1 - 00 = Channel has priority 0 - Note 1: The chain selection bit takes effect when chaining is enabled (i.e., CHCHN = 1). - 2: When the channel is suspended by clearing this bit, the user application should poll the CHBUSY bit (if available on the device variant) to see when the channel is suspended, as it may take some clock cycles to complete a current transaction before the channel is suspended. #### REGISTER 11-8: DCHxECON: DMA CHANNEL x EVENT CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|----------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | U-0 | | | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | 00.40 | R/W-1 | | | 23:16 | CHAIRQ<7:0> <sup>(1)</sup> | | | | | | | | | | | 45.0 | R/W-1 | | | 15:8 | CHSIRQ<7:0> <sup>(1)</sup> | | | | | | | | | | | 7.0 | S-0 | S-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | | | | 7:0 | CFORCE | CABORT | PATEN | SIRQEN | AIRQEN | 1 | 1 | _ | | | Legend:S = Settable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23-16 CHAIRQ<7:0>: Channel Transfer Abort IRQ bits(1) 11111111 = Interrupt 255 will abort any transfers in progress and set CHAIF flag • • . 00000001 = Interrupt 1 will abort any transfers in progress and set CHAIF flag 00000000 = Interrupt 0 will abort any transfers in progress and set CHAIF flag bit 15-8 CHSIRQ<7:0>: Channel Transfer Start IRQ bits<sup>(1)</sup> 11111111 = Interrupt 255 will initiate a DMA transfer . Ĭ bit 7 00000001 = Interrupt 1 will initiate a DMA transfer 00000000 = Interrupt 0 will initiate a DMA transfer Note: The DMA does not support I<sup>2</sup>C, Change Notification, Input Capture, CTMU, QEI, and Motor Control PWMs. Use of any of these DMA trigger transfer events could lead to unexpected behavior. CFORCE: DMA Forced Transfer bit 1 = A DMA transfer is forced to begin when this bit is written to a '1' 0 = This bit always reads '0' bit 6 CABORT: DMA Abort Transfer bit 1 = A DMA transfer is aborted when this bit is written to a '1' 0 = This bit always reads '0' bit 5 PATEN: Channel Pattern Match Abort Enable bit 1 = Abort transfer and clear CHEN on pattern match 0 = Pattern match is disabled bit 4 SIRQEN: Channel Start IRQ Enable bit 1 = Start channel cell transfer if an interrupt matching CHSIRQ occurs 0 = Interrupt number CHSIRQ is ignored and does not start a transfer bit 3 AIRQEN: Channel Abort IRQ Enable bit 1 = Channel transfer is aborted if an interrupt matching CHAIRQ occurs 0 = Interrupt number CHAIRQ is ignored and does not terminate a transfer bit 2-0 Unimplemented: Read as '0' Note 1: See Table 8-3: "Interrupt IRQ, Vector and Bit Location" for the list of available interrupt IRQ sources. #### REGISTER 11-9: DCHxINT: DMA CHANNEL x INTERRUPT CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | | _ | _ | - | _ | _ | _ | _ | | 00.40 | R/W-0 | 23:16 | CHSDIE | CHSHIE | CHDDIE | CHDHIE | CHBCIE | CHCCIE | CHTAIE | CHERIE | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R/W-0 | 7:0 | CHSDIF | CHSHIF | CHDDIF | CHDHIF | CHBCIF | CHCCIF | CHTAIF | CHERIF | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23 CHSDIE: Channel Source Done Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 22 CHSHIE: Channel Source Half Empty Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 21 CHDDIE: Channel Destination Done Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 20 CHDHIE: Channel Destination Half Full Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 19 CHBCIE: Channel Block Transfer Complete Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 18 CHCCIE: Channel Cell Transfer Complete Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 17 CHTAIE: Channel Transfer Abort Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 16 CHERIE: Channel Address Error Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabledUnimplemented: Read as '0' bit 7 CHSDIF: Channel Source Done Interrupt Flag bit 1 = Channel Source Pointer has reached end of source (CHSPTR = CHSSIZ) 0 = No interrupt is pending bit 6 CHSHIF: Channel Source Half Empty Interrupt Flag bit 1 = Channel Source Pointer has reached midpoint of source (CHSPTR = CHSSIZ/2) 0 = No interrupt is pending bit 15-8 ### REGISTER 11-9: DCHxINT: DMA CHANNEL x INTERRUPT CONTROL REGISTER (CONTINUED) - bit 5 CHDDIF: Channel Destination Done Interrupt Flag bit - 1 = Channel Destination Pointer has reached end of destination (CHDPTR = CHDSIZ) - 0 = No interrupt is pending - bit 4 **CHDHIF:** Channel Destination Half Full Interrupt Flag bit - 1 = Channel Destination Pointer has reached midpoint of destination (CHDPTR = CHDSIZ/2) - 0 = No interrupt is pending - bit 3 CHBCIF: Channel Block Transfer Complete Interrupt Flag bit - 1 = A block transfer has been completed (the larger of CHSSIZ/CHDSIZ bytes has been transferred), or a pattern match event occurs - 0 = No interrupt is pending - bit 2 CHCCIF: Channel Cell Transfer Complete Interrupt Flag bit - 1 = A cell transfer has been completed (CHCSIZ bytes have been transferred) - 0 = No interrupt is pending - bit 1 CHTAIF: Channel Transfer Abort Interrupt Flag bit - 1 = An interrupt matching CHAIRQ has been detected and the DMA transfer has been aborted - 0 = No interrupt is pending - bit 0 CHERIF: Channel Address Error Interrupt Flag bit - 1 = A channel address error has been detected Either the source or the destination address is invalid. - 0 = No interrupt is pending ### REGISTER 11-10: DCHxSSA: DMA CHANNEL x SOURCE START ADDRESS REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R/W-0 | | | 31:24 | | | | CHSSA< | 31:24> | | | | | | | 22.46 | R/W-0 | | | 23:16 | CHSSA<23:16> | | | | | | | | | | | 45.0 | R/W-0 | | | 15:8 | CHSSA<15:8> | | | | | | | | | | | 7.0 | R/W-0 | | | 7:0 | CHSSA<7:0> | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 CHSSA<31:0> Channel Source Start Address bits Channel source start address. **Note:** This must be the physical address of the source. ### REGISTER 11-11: DCHxDSA: DMA CHANNEL x DESTINATION START ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--| | 24.24 | R/W-0 | | | | | 31:24 | | CHDSA<31:24> | | | | | | | | | | | | 22.46 | R/W-0 | | | | | 23:16 | CHDSA<23:16> | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | 15:8 | CHDSA<15:8> | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | 7:0 | | | _ | CHDSA | <7:0> | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 CHDSA<31:0>: Channel Destination Start Address bits Channel destination start address. Note: This must be the physical address of the destination. ### REGISTER 11-12: DCHxSSIZ: DMA CHANNEL x SOURCE SIZE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | 15:8 | CHSSIZ<15:8> | | | | | | | | | 7.0 | R/W-0 | 7:0 | | | | CHSSIZ | :<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CHSSIZ<15:0>: Channel Source Size bits 1111111111111111 = 65,535 byte source size : 00000000000000010 **= 2** byte source size 0000000000000001 = 1 byte source size 0000000000000000 = 65,536 byte source size #### REGISTER 11-13: DCHxDSIZ: DMA CHANNEL x DESTINATION SIZE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | 15:8 | CHDSIZ<15:8> | | | | | | | | | 7.0 | R/W-0 | 7:0 | | | | CHDSIZ | <7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CHDSIZ<15:0>: Channel Destination Size bits 111111111111111 = 65,535 byte destination size : 0000000000000001 = 1 byte destination size 0000000000000000 = 65,536 byte destination size #### REGISTER 11-14: DCHxSPTR: DMA CHANNEL x SOURCE POINTER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | - | _ | _ | _ | _ | | 15:8 | R-0 | 15.6 | | | | CHSPTR | <15:8> | | | | | 7:0 | R-0 | 7.0 | | | | CHSPTF | R<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CHSPTR<15:0>: Channel Source Pointer bits 111111111111111 = Points to byte 65,535 of the source • 00000000000000000 = Points to byte 1 of the source 0000000000000000 = Points to byte 0 of the source **Note:** When in Pattern Detect mode, this register is reset on a pattern detect. #### REGISTER 11-15: DCHxDPTR: DMA CHANNEL x DESTINATION POINTER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22,46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | R-0 | 13.6 | | | | CHDPTR | <15:8> | | | | | 7:0 | R-0 | 7:0 | | | | CHDPTF | R<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CHDPTR<15:0>: Channel Destination Pointer bits 1111111111111111 = Points to byte 65,535 of the destination • 0000000000000000 = Points to byte 1 of the destination 000000000000000 = Points to byte 0 of the destination #### REGISTER 11-16: DCHxCSIZ: DMA CHANNEL x CELL-SIZE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | - | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | 15:8 | | | | CHCSIZ | <15:8> | | | | | 7.0 | R/W-0 | 7:0 | | | | CHCSIZ | <7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CHCSIZ<15:0>: Channel Cell-Size bits 1111111111111111 = 65,535 bytes transferred on an event : 0000000000000001= 1 byte transferred on an event 000000000000000 = 65,536 bytes transferred on an event #### REGISTER 11-17: DCHxCPTR: DMA CHANNEL x CELL POINTER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R-0 | 15:8 | | | | CHCPTR | <15:8> | | | | | 7:0 | R-0 | 7:0 | | | | CHCPTF | R<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CHCPTR<15:0>: Channel Cell Progress Pointer bits 111111111111111 = 65,535 bytes have been transferred since the last event • 000000000000000 = 1 byte has been transferred since the last event 000000000000000 = 0 bytes have been transferred since the last event **Note:** When in Pattern Detect mode, this register is reset on a pattern detect. #### REGISTER 11-18: DCHxDAT: DMA CHANNEL x PATTERN DATA REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 24.24 | U-0 | | | | | | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | | 22,16 | U-0 | | | | | | 23:16 | _ | _ | _ | _ | _ | _ | | _ | | | | | | | 45.0 | R/W-0 | | | | | | 15:8 | | | | CHPDAT | <15:8> | | | | | | | | | | 7.0 | R/W-0 | | | | | | 7:0 | CHPDAT<7:0> | | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CHPDAT<15:0>: Channel Data Register bits Pattern Terminate mode: Data to be matched must be stored in this register to allow terminate on match. All other modes: Unused. #### 12.0 USB ON-THE-GO (OTG) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 27. "USB On-The-Go (OTG)" (DS60001126), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The Universal Serial Bus (USB) module contains analog and digital components to provide a USB 2.0 full-speed and low-speed embedded host, full-speed device or OTG implementation with a minimum of external components. This module in Host mode is intended for use as an embedded host and therefore does not implement a UHCI or OHCI controller. The USB module consists of the clock generator, the USB voltage comparators, the transceiver, the Serial Interface Engine (SIE), a dedicated USB DMA controller, pull-up and pull-down resistors, and the register interface. A block diagram of the PIC32MK USB OTG module is presented in Figure 12-1. The clock generator provides the 48 MHz clock required for USB full-speed and low-speed communication. The voltage comparators monitor the voltage on the VBUS pin to determine the state of the bus. The transceiver provides the analog translation between the USB bus and the digital logic. The SIE is a state machine that transfers data to and from the endpoint buffers and generates the hardware protocol for data transfers. The USB DMA controller transfers data between the data buffers in RAM and the SIE. The integrated pull-up and pull-down resistors eliminate the need for external signaling components. The register interface allows the CPU to configure and communicate with the module. The PIC32MK GPK.MCM USB OTG module includes the following features: - · USB full-speed support for host and device - · Low-speed host support - USB OTG support - · Integrated signaling resistors - Integrated analog comparators for VBUS monitoring - · Integrated USB transceiver - · Transaction handshaking performed by hardware - · Endpoint buffering anywhere in system RAM - Integrated DMA to access system RAM and Flash Note: The implementation and use of the USB specifications, and other third party specifications or technologies, may require licensing; including, but not limited to, USB Implementers Forum, Inc. (also referred to as USB-IF). The user is fully responsible for investigating and satisfying any applicable licensing obligations. FIGURE 12-1: USB INTERFACE DIAGRAM #### 12.1 Control Registers #### TABLE 12-1: USB1 AND USB2 REGISTER MAP | SSS | | | | | | | | | | | Bit | s | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------------------------|----------|----------|------------|----------|----------|----------|----------|------------| | Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 9040 | U1OTGIR <sup>(2)</sup> | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 9040 | 0101GIK | 15:0 | _ | | | _ | _ | _ | _ | _ | IDIF | T1MSECIF | LSTATEIF | ACTVIF | SESVDIF | SESENDIF | _ | VBUSVDIF | 0000 | | 9050 | U1OTGIE | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | 0101012 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | IDIE | T1MSECIE | LSTATEIE | ACTVIE | SESVDIE | SESENDIE | | VBUSVDIE | 0000 | | 9060 | U1OTGSTAT <sup>(3)</sup> | 31:16 | | | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | _ | 0000 | | | 0.0.00 | 15:0 | _ | | | | | | _ | _ | ID | | LSTATE | _ | SESVD | SESEND | | VBUSVD | 0000 | | 9070 | U10TGCON | 31:16 | _ | | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | DPPULUP | DMPULUP | DPPULDWN | DMPULDWN | VBUSON | OTGEN | VBUSCHG | VBUSDIS | 0000 | | 9080 | U1PWRC | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | — | _ | | | | _ | | | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | UACTPND <sup>(4)</sup> | _ | | USLPGRD | USBBUSY | _ | USUSPEND | USBPWR | 0000 | | | =(2) | 31:16 | _ | | | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | | 0000 | | 9200 | U1IR <sup>(2)</sup> | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | STALLIF | ATTACHIF | RESUMEIF | IDLEIF | TRNIF | SOFIF | UERRIF | URSTIF | 0000 | | | | 31:16 | | | | | | | | | | | | | | _ | _ | DETACHIF | 0000 | | 9210 | U1IE | 31.10 | _ | | | | | | _ | | _ | _ | _ | _ | _ | _ | | URSTIE | 0000 | | 92 10 | OTIL | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | STALLIE | ATTACHIE | RESUMEIE | IDLEIE | TRNIE | SOFIE | UERRIE | DETACHIE | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 9220 | U1EIR <sup>(2)</sup> | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | BTSEF | BMXEF | DMAEF | BTOEF | DFN8EF | CRC16EF | CRC5EF | PIDEF | 0000 | | | | | | | | | | | | | | | | | | | EOFEF | | 0000 | | | | 31:16 | | | | | | | _ | _ | _ | | _ | _ | _ | _ | _ | | 0000 | | 9230 | U1EIE | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | BTSEE | BMXEE | DMAEE | BTOEE | DFN8EE | CRC16EE | CRC5EE | PIDEE | 0000 | | | | 31:16 | | | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EOFEE — | _ | 0000 | | 9240 | U1STAT <sup>(3)</sup> | 15:0 | | | | | | | | | _ | | PT<3:0> | _ | DIR | PPBI | | | 0000 | | | | 31:16 | | | | | | | | | _ | _ | — | _ | DIIX | _ | | | 0000 | | 9250 | U1CON | 31.10 | | | | | | | | | | | PKTDIS | | | _ | | USBEN | 0000 | | 3230 | O TOON | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | JSTATE | SE0 | TOKBUSY | USBRST | HOSTEN | RESUME | PPBRST | SOFEN | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 9260 | U1ADDR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | LSPDEN | | | | VADDR<6: | 0> | | | 0000 | | 0077 | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 9270 | U1BDTP1 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | | BD | TPTRL<15:9 | > | | | _ | 0000 | | | | | | | | | | | | | | | | | | | | | | PIC32MK GPK/MCM with CAN FD Family **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: With the exception of those noted, all registers in this table (except as noted) have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC respectively. See 13.2 "CLR, SET, and INV Registers" for more information. **<sup>2:</sup>** This register does not have associated SET and INV registers. <sup>3:</sup> This register does not have associated CLR, SET, and INV registers. <sup>4:</sup> Reset value for this bit is undefined. TABLE 12-1: USB1 AND USB2 REGISTER MAP (CONTINUED) | ess | | • | | | | | | | | | Bit | s | | | | | | | <b>"</b> | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|-------|----------|-------|----------|---------|--------|-----------|----------|------------| | Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 9280 | U1FRML <sup>(3)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3200 | OTITAME | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | FRML< | 7:0> | | | | 0000 | | 9290 | U1FRMH <sup>(3)</sup> | 31:16 | _ | | _ | _ | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | 0000 | | 0200 | | 15:0 | _ | _ | _ | _ | | _ | _ | _ | | _ | | _ | _ | | FRMH<2:0> | | 0000 | | 92A0 | U1TOK | 31:16 | _ | | | | | _ | | | _ | _ | | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | | | | | _ | | | | PID | <3:0> | | | EP | <3:0> | ı | 0000 | | 92B0 | U1SOF | 31:16 | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | OLBO | 01001 | 15:0 | _ | _ | | | | _ | _ | _ | | 1 | | CNT<7 | 7:0> | | 1 | 1 | 0000 | | 92C0 | U1BDTP2 | 31:16 | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | 0.552 | 15:0 | _ | | | | | _ | | | | | | BDTPTRH | <23:16> | 1 | | ı | 0000 | | 92D0 | U1BDTP3 | 31:16 | _ | | | | | _ | | | _ | _ | | _ | _ | _ | _ | _ | 0000 | | 0220 | 0.220 | 15:0 | _ | | | | | _ | | | | | | BDTPTRU | <31:24> | 1 | | ı | 0000 | | 92E0 | U1CNFG1 | 31:16 | _ | | | | | _ | | | _ | _ | | _ | _ | | _ | _ | 0000 | | | | 15:0 | _ | | | | | _ | | | UTEYE | UOEMON | | USBSIDL | LSDEV | _ | _ | UASUSPNE | | | 9300 | U1EP0 | 31:16 | _ | _ | | | | _ | | | _ | | | | | | | | 0000 | | | | 15:0 | _ | _ | | | | _ | _ | _ | LSPD | RETRYDIS | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9310 | U1EP1 | 31:16 | _ | _ | | | | _ | | | | _ | | | | | | | 0000 | | | | 15:0 | _ | _ | | | | _ | | | | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9320 | U1EP2 | 31:16 | _ | _ | | | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | _ | _ | _ | _ | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9330 | U1EP3 | 31:16 | _ | _ | | | | _ | _ | | | _ | | | | | | | 0000 | | | | 15:0 | _ | _ | | | | _ | _ | | | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9340 | U1EP4 | 31:16 | _ | _ | | | | _ | | | | _ | | | | | | | 0000 | | | | 15:0 | _ | | | | | _ | | | | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9350 | U1EP5 | 31:16 | | | | | | _ | | | | _ | | | | | | | 0000 | | | | 15:0 | _ | | | | | _ | | | | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9360 | U1EP6 | 31:16 | | | | | | | | | | _ | | - | | | - | — | 0000 | | | | 15:0 | | | | | | _ | | | | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9370 | U1EP7 | 31:16 | | | | | | | | | | _ | | - | | | - | — | 0000 | | | | 15:0 | | | | | | _ | | | | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 9380 | U1EP8 | 31:16 | | | | | | _ | | | | _ | | | | | | | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. With the exception of those noted, all registers in this table (except as noted) have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC respectively. See 13.2 "CLR, SET, and INV Registers" for more information. This register does not have associated SET and INV registers. 2: This register does not have associated CLR, SET, and INV registers. Reset value for this bit is undefined. | 001519E-page 226 | DS600 | |------------------|----------| | 519E-page 2: | $\simeq$ | | 519E-page 2: | $\circ$ | | 519E-page 2: | | | 19E-page 226 | S | | 9E-page 226 | _ | | E-page 226 | 9 | | page 226 | Ψ | | age 226 | 0 | | ge 226 | മ | | e 226 | g | | 226 | Φ | | | 226 | **USB1 AND USB2 REGISTER MAP (CONTINUED) TABLE 12-1:** | ess | | • | | | | | | | | | Bit | s | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------------|----------|----------|----------|---------|----------|----------|--------------------|------------| | Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 9390 | U1EP9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | 0000 | | 3330 | O ILI 9 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 93A0 | U1EP10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 30/10 | 012110 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 93B0 | U1EP11 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3300 | O ILI II | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 93C0 | U1EP12 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 9300 | OTEF 12 | 15:0 | | | | _ | _ | _ | _ | _ | _ | - | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 93D0 | U1EP13 | 31:16 | | | | _ | _ | _ | _ | _ | _ | - | _ | _ | | _ | - | _ | 0000 | | 9300 | OTEF 13 | 15:0 | | | | _ | _ | _ | _ | _ | _ | - | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 0050 | LIAEDAA | 31:16 | | | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | - | _ | 0000 | | 93E0 | U1EP14 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | 0050 | U1EP15 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 93F0 | UTEPTS | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A040 | U2OTGIR <sup>(2)</sup> | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | IDIF | T1MSECIF | LSTATEIF | ACTVIF | SESVDIF | SESENDIF | _ | VBUSVDIF | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A050 | U2OTGIE | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | IDIE | T1MSECIE | LSTATEIE | ACTVIE | SESVDIE | SESENDIE | _ | VBUSVDIE | 0000 | | 4000 | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A060 | U2OTGSTAT <sup>(3)</sup> | 15:0 | | _ | _ | _ | _ | _ | _ | _ | ID | - | LSTATE | _ | SESVD | SESEND | | VBUSVD | 0000 | | 4070 | LICOTOCONI | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | | _ | 0000 | | A070 | U2OTGCON | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | DPPULUP | DMPULUP | DPPULDWN | DMPULDWN | VBUSON | OTGEN | VBUSCHG | VBUSDIS | 0000 | | 4000 | LIODIMEDO | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | 0000 | | A080 | U2PWRC | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | UACTPND(4) | _ | _ | USLPGRD | USBBUSY | _ | USUSPEND | USBPWR | 0000 | | | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | - | _ | 0000 | | A200 | U2IR <sup>(2)</sup> | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | STALLIF | ATTACHIF | RESUMEIF | IDLEIF | TRNIF | SOFIF | UERRIF | URSTIF<br>DETACHIF | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A210 | U2IE | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | STALLIE | ATTACHIE | RESUMEIE | IDLEIE | TRNIE | SOFIE | UERRIE | URSTIE<br>DETACHIE | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Legend: Note 1: With the exception of those noted, all registers in this table (except as noted) have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC respectively. See 13.2 "CLR, SET, and INV Registers" for more information. This register does not have associated SET and INV registers. 2: This register does not have associated CLR, SET, and INV registers. Reset value for this bit is undefined. | TABLE 12-1: USB1 AND USB2 REGISTER MAP (CONTINUED) | |----------------------------------------------------| |----------------------------------------------------| | sse | | | | | | | | | | | Bit | ts | | | | | | | | |-----------------------------|---------------------------------|---------------|-------|-------|-------|-------|-------|-------|------|------|--------|--------------|-------------------|---------------|----------------------------------------|---------|-----------------|----------------|------------| | Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | | 31:16 | | _ | | _ | I | _ | _ | _ | _ | _ | _ | _ | _ | _ | I | _ | 0000 | | A220 | U2EIR <sup>(2)</sup> | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | BTSEF | BMXEF | DMAEF | BTOEF | DFN8EF | CRC16EF | CRC5EF<br>EOFEF | PIDEF | 0000 | | | | 31:16 | _ | _ | _ | _ | I | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | 0000 | | A230 | U2EIE | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | BTSEE | BMXEE | DMAEE | BTOEE | DFN8EE | CRC16EE | CRC5EE<br>EOFEE | PIDEE | 0000 | | A 2 4 0 | U2STAT <sup>(3)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A240 | U251A1(9) | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | ENDF | PT<3:0> | | DIR | PPBI | - | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | 0000 | | A250 | U2CON | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | JSTATE | SE0 | PKTDIS<br>TOKBUSY | USBRST | HOSTEN | RESUME | PPBRST | USBEN<br>SOFEN | 0000 | | 4.000 | 1104000 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A260 | U2ADDR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | LSPDEN | | | DE | VADDR<6: | 0> | | | 0000 | | A270 | U2BDTP1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A210 | UZBDTFT | 15:0 | _ | _ | _ | _ | 1 | _ | _ | _ | | | BD | TPTRL<15:9> | > | | | _ | 0000 | | A280 | U2FRML <sup>(3)</sup> | 31:16 | - | _ | - | _ | I | _ | _ | _ | - | _ | _ | _ | _ | _ | I | _ | 0000 | | A200 | OZI KWE. | 15:0 | | _ | | _ | | _ | _ | _ | | | | FRML< | 7:0> | | | | 0000 | | A290 | U2FRMH <sup>(3)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 7 1200 | 021 TWIIT | 15:0 | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | FRMH<2:0> | | 0000 | | A2A0 | U2TOK | 31:16 | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | _ | | _ | _ | | | PID | <3:0> | | | EP | <3:0> | | 0000 | | A2B0 | U2SOF | 31:16 | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | _ | _ | _ | _ | | | | | CNT<7 | 7:0> | | | | 0000 | | A2C0 | U2BDTP2 | 31:16 | | | | _ | _ | _ | | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | _ | _ | _ | | | | | | BDTPTRH | <23:16> | | | | 0000 | | A2D0 | U2BDTP3 | 31:16 | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | 0000 | | $\vdash$ | | 15:0 | | | | | | _ | _ | | | | | BDTPTRU | <31:24> | | | | 0000 | | A2E0 | U2CNFG1 | 31:16 | | | | | | _ | _ | | —<br>— | - | _ | — | —————————————————————————————————————— | _ | | — | 0000 | | | | 15:0 | | _ | | _ | | _ | _ | _ | UTEYE | UOEMON | | USBSIDL | LSDEV | | | UASUSPND | | | A300 | U2EP0 | 31:16<br>15:0 | _ | _ | | _ | | | _ | _ | LSPD | RETRYDIS | _ | —<br>EPCONDIS | EPRXEN | EPTXEN | —<br>EPSTALL | EPHSHK | 0000 | | Legen | | | | _ | | | | | | | LSPD | VE I K I DIS | _ | ELCONDI2 | EPRAEN | EPIAEN | EPSTALL | EPHONK | 0000 | $\textbf{Legend:} \qquad \textbf{x = unknown value on Reset; } \textbf{— = unimplemented, read as `0'. Reset values are shown in hexadecimal.}$ Note 1: With the exception of those noted, all registers in this table (except as noted) have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC respectively. See 13.2 "CLR, SET, and INV Registers" for more information. <sup>2:</sup> This register does not have associated SET and INV registers. <sup>3:</sup> This register does not have associated CLR, SET, and INV registers. <sup>4:</sup> Reset value for this bit is undefined. | ▢ | |---------------| | DS60001519E- | | Õ | | 0 | | 0 | | 0 | | <del></del> | | O1 | | $\overline{}$ | | 9 | | ÜП | | Ċ | | page | | ۵ | | æ | | | | 22 | | 8 | | $\sim$ | | | | TABLE 12-1: USB1 AND USB2 REGISTER MAP (CONTINUED) | |----------------------------------------------------| |----------------------------------------------------| | ess | | е | Bits | | | | | | | | | | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|----------|--------|--------|---------|--------|------------| | Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | A310 | U2EP1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | A310 | UZLF I | 15:0 | _ | _ | _ | _ | - | - | _ | - | 1 | _ | - | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A320 | U2EP2 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 71020 | OZLI Z | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A330 | U2EP3 | 31:16 | | _ | _ | _ | | | _ | | _ | _ | | _ | _ | | _ | _ | 0000 | | 7000 | OZLI 3 | 15:0 | | _ | _ | _ | | | _ | | _ | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A340 | U2EP4 | 31:16 | | _ | _ | _ | | | _ | | _ | _ | | _ | _ | | _ | _ | 0000 | | 7040 | OZLI 4 | 15:0 | | _ | _ | _ | | | _ | | _ | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A350 | U2EP5 | 31:16 | | _ | _ | _ | | | _ | | _ | _ | | _ | _ | | _ | _ | 0000 | | 71000 | OZLI O | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A360 | U2EP6 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 71000 | OZLI O | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A370 | U2EP7 | 31:16 | | _ | _ | _ | | | _ | | _ | _ | | _ | _ | | _ | _ | 0000 | | 71070 | OZLI 7 | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A380 | U2EP8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 7300 | OZLI O | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A390 | U2EP9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 71000 | OZEI 3 | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A3A0 | U2EP10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | AJAU | OZLI 10 | 15:0 | | _ | _ | _ | | | _ | | _ | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A3B0 | U2EP11 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | AJDO | OZLI II | 15:0 | | _ | _ | _ | | | _ | | _ | _ | | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A3C0 | U2EP12 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A300 | OZLI IZ | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A3D0 | U2EP13 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | NODO | OZEI 10 | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A3E0 | U2EP14 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | 0000 | | ASEU | UZEF 14 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | | A3F0 | U2EP15 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | 0000 | | ASFU | UZEF 13 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Legend: With the exception of those noted, all registers in this table (except as noted) have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC respectively. See Note 1: 13.2 "CLR, SET, and INV Registers" for more information. This register does not have associated SET and INV registers. This register does not have associated CLR, SET, and INV registers. Reset value for this bit is undefined. #### REGISTER 12-1: UXOTGIR: USB OTG INTERRUPT STATUS REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | - | _ | _ | - | - | _ | _ | _ | | 45.0 | U-0 | 15:8 | - | _ | _ | _ | - | _ | _ | _ | | 7.0 | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | U-0 | R/WC-0, HS | | 7:0 | IDIF | T1MSECIF | LSTATEIF | ACTVIF | SESVDIF | SESENDIF | _ | VBUSVDIF | **Legend:** WC = Write '1' to clear HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 IDIF: ID State Change Indicator bit 1 = Change in ID state is detected0 = No change in ID state is detected bit 6 T1MSECIF: 1 Millisecond Timer bit 1 = 1 millisecond timer has expired0 = 1 millisecond timer has not expired bit 5 LSTATEIF: Line State Stable Indicator bit 1 = USB line state has been stable for 1millisecond, but different from last time 0 = USB line state has not been stable for 1 millisecond bit 4 ACTVIF: Bus Activity Indicator bit 1 = Activity on the D+, D-, ID or VBUS pins has caused the device to wake-up 0 = Activity has not been detected bit 3 SESVDIF: Session Valid Change Indicator bit 1 = VBUS voltage has dropped below the session end level 0 = VBUS voltage has not dropped below the session end level bit 2 SESENDIF: B-Device VBUS Change Indicator bit 1 = A change on the session end input was detected 0 = No change on the session end input was detected bit 1 Unimplemented: Read as '0' bit 0 VBUSVDIF: A-Device VBUS Change Indicator bit 1 = Change on the session valid input is detected 0 = No change on the session valid input is detected #### REGISTER 12-2: UxOTGIE: USB OTG INTERRUPT ENABLE REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | _ | | _ | ı | 1 | | 1 | _ | | 45.0 | U-0 | 15:8 | | - | | 1 | 1 | - | 1 | _ | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | | 7:0 | IDIE | T1MSECIE | LSTATEIE | ACTVIE | SESVDIE | SESENDIE | | VBUSVDIE | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 IDIE: ID Interrupt Enable bit 1 = ID interrupt is enabled0 = ID interrupt is disabled bit 6 T1MSECIE: 1 Millisecond Timer Interrupt Enable bit 1 = 1 millisecond timer interrupt is enabled0 = 1 millisecond timer interrupt is disabled bit 5 LSTATEIE: Line State Interrupt Enable bit 1 = Line state interrupt is enabled0 = Line state interrupt is disabled bit 4 ACTVIE: Bus Activity Interrupt Enable bit 1 = ACTIVITY interrupt is enabled 0 = ACTIVITY interrupt is disabledbit 3 SESVDIE: Session Valid Interrupt Enable **SESVDIE:** Session Valid Interrupt Enable bit 1 = Session valid interrupt is enabled 0 = Session valid interrupt is disabled bit 2 SESENDIE: B-Session End Interrupt Enable bit 1 = B-session end interrupt is enabled 0 = B-session end interrupt is disabled bit 1 Unimplemented: Read as '0' bit 0 VBUSVDIE: A-VBUS Valid Interrupt Enable bit 1 = A-V<sub>BUS</sub> valid interrupt is enabled 0 = A-VBUS valid interrupt is disabled #### REGISTER 12-3: UXOTGSTAT: USB OTG STATUS REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | - | _ | _ | - | - | - | _ | | 23:16 | U-0 | 23.10 | - | - | - | _ | - | - | - | _ | | 45.0 | U-0 | 15:8 | _ | - | _ | _ | - | - | - | _ | | 7.0 | R-0 | U-0 | R-0 | U-0 | R-0 | R-0 | U-0 | R-0 | | 7:0 | ID | | LSTATE | _ | SESVD | SESEND | _ | VBUSVD | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 ID: ID Pin State Indicator bit 1 = No cable is attached or a Type-B cable has been plugged into the USB receptacle 0 = A Type-A cable has been plugged into the USB receptacle bit 6 Unimplemented: Read as '0' bit 5 LSTATE: Line State Stable Indicator bit 1 = USB line state (SE0 (UxCON<6>) and JSTATE (UxCON<7>)) has been stable for the previous 1 ms 0 = USB line state (SE0 and JSTATE) has not been stable for the previous 1 ms bit 4 Unimplemented: Read as '0' bit 3 SESVD: Session Valid Indicator bit 1 = VBUS voltage is above Session Valid on the A or B device 0 = VBUS voltage is below Session Valid on the A or B device bit 2 SESEND: B-Device Session End Indicator bit 1 = VBUS voltage is below Session Valid on the B device 0 = VBUS voltage is above Session Valid on the B device bit 1 Unimplemented: Read as '0' bit 0 VBUSVD: A-Device VBUS Valid Indicator bit 1 = VBUS voltage is above Session Valid on the A device 0 = VBUS voltage is below Session Valid on the A device #### REGISTER 12-4: UxOTGCON: USB OTG CONTROL REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | - | | - | _ | - | - | _ | | 22.46 | U-0 | 23:16 | - | - | | - | _ | - | | - | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R/W-0 | 7:0 | DPPULUP | DMPULUP | DPPULDWN | DMPULDWN | VBUSON | OTGEN | VBUSCHG | VBUSDIS | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 DPPULUP: D+ Pull-Up Enable bit 1 = D+ data line pull-up resistor is enabled0 = D+ data line pull-up resistor is disabled bit 6 DMPULUP: D- Pull-Up Enable bit 1 = D- data line pull-up resistor is enabled 0 = D- data line pull-up resistor is disabled bit 5 DPPULDWN: D+ Pull-Down Enable bit 1 = D+ data line pull-down resistor is enabled0 = D+ data line pull-down resistor is disabled bit 4 DMPULDWN: D- Pull-Down Enable bit 1 = D- data line pull-down resistor is enabled 0 = D- data line pull-down resistor is disabled bit 3 VBUSON: VBUS Power-on bit 1 = VBUS line is powered 0 = VBUS line is not powered bit 2 OTGEN: OTG Functionality Enable bit 1 = DPPULUP, DMPULUP, DPPULDWN and DMPULDWN bits are under software control 0 = DPPULUP, DMPULUP, DPPULDWN and DMPULDWN bits are under USB hardware control bit 1 VBUSCHG: VBUS Charge Enable bit 1 = VBUS line is charged through a pull-up resistor 0 = VBUS line is not charged through a resistor bit 0 VBUSDIS: VBUS Discharge Enable bit 1 = VBUS line is discharged through a pull-down resistor 0 = VBUS line is not discharged through a resistor #### REGISTER 12-5: UxPWRC: USB POWER CONTROL REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|------------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | - | _ | | | _ | _ | | 22,16 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | | 7:0 | UACTPND | _ | _ | USLPGRD | USBBUSY <sup>(1)</sup> | _ | USUSPEND | USBPWR | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 **UACTPND:** USB Activity Pending bit - 1 = USB hardware has detected a change in link status; however, an interrupt is pending and has not yet been generated. Software should not put the device into Sleep mode. - 0 = An interrupt is not pending - bit 6-5 Unimplemented: Read as '0' - bit 4 USLPGRD: USB Sleep Entry Guard bit - 1 = Sleep entry is blocked if USB bus activity is detected or if a notification is pending - 0 = USB module does not block Sleep entry - bit 3 USBBUSY: USB Module Busy bit<sup>(1)</sup> - 1 = USB module is active or disabled, but not ready to be enabled - 0 = USB module is not active and is ready to be enabled **Note:** When USBPWR = 0 and USBBUSY = 1, status from all other registers is invalid and writes to all USB module registers produce undefined results. - bit 2 Unimplemented: Read as '0' - bit 1 USUSPEND: USB Suspend Mode bit - 1 = USB module is placed in Suspend mode (The 48 MHz USB clock will be gated off. The transceiver is placed in a low-power state.) - 0 = USB module operates normally - bit 0 USBPWR: USB Operation Enable bit - 1 = USB module is turned on - 0 = USB module is disabled (Outputs held inactive, device pins not used by USB, analog features are shut down to reduce power consumption.) #### REGISTER 12-6: UxIR: USB INTERRUPT REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|---------------------|-------------------------|-------------------|----------------------|-------------------|-----------------------|-------------------------| | 31:24 | U-0 | 31.24 | | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | 15.6 | | _ | _ | _ | _ | _ | _ | _ | | | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | R/WC-0, HS | R-0 | R/WC-0, HS | | 7:0 | STALLIF | STALLIE ATTACLUE(1) | RESUMEIF <sup>(2)</sup> | IDLEIF | TRNIF <sup>(3)</sup> | SOFIF | UERRIF <sup>(4)</sup> | URSTIF <sup>(5)</sup> | | | STALLIF | AT IACHIE | NEOUNIEIL, | IDLEIF | I INNIE (*) | JOFIF | OENKIE'' | DETACHIF <sup>(6)</sup> | Legend:WC = Write '1' to clearHS = Hardware Settable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown - bit 31-8 Unimplemented: Read as '0' - bit 7 **STALLIF:** STALL Handshake Interrupt bit - 1 = In Host mode, a STALL handshake was received during the handshake phase of the transaction In Device mode, a STALL handshake was transmitted during the handshake phase of the transaction - 0 = STALL handshake has not been sent - bit 6 **ATTACHIF:** Peripheral Attach Interrupt bit<sup>(1)</sup> - 1 = Peripheral attachment was detected by the USB module - 0 = Peripheral attachment was not detected - bit 5 **RESUMEIF:** Resume Interrupt bit<sup>(2)</sup> - 1 = K-State is observed on the D+ or D- pin for 2.5 $\mu$ s - 0 = K-State is not observed - bit 4 IDLEIF: Idle Detect Interrupt bit - 1 = Idle condition detected (constant Idle state of 3 ms or more) - 0 = No Idle condition is detected - bit 3 **TRNIF:** Token Processing Complete Interrupt bit<sup>(3)</sup> - 1 = Processing of current token is complete; a read of the UxSTAT register will provide endpoint information - 0 = Processing of current token not complete - bit 2 **SOFIF:** SOF Token Interrupt bit - 1 = SOF token received by the peripheral or the SOF threshold reached by the host - 0 = SOF token was not received nor threshold reached - bit 1 **UERRIF:** USB Error Condition Interrupt bit<sup>(4)</sup> - 1 = Unmasked error condition has occurred - 0 = Unmasked error condition has not occurred - bit 0 **URSTIF:** USB Reset Interrupt bit (Device mode)<sup>(5)</sup> - 1 = Valid USB Reset has occurred - 0 = No USB Reset has occurred - **Note 1:** This bit is valid only if the HOSTEN bit is set (see Register 12-11), there is no activity on the USB for $2.5 \mu s$ , and the current bus state is not SE0. - 2: When not in Suspend mode, this interrupt should be disabled. - 3: Clearing this bit will cause the STAT FIFO to advance. - 4: Only error conditions enabled through the UxEIE register will set this bit. - 5: Device mode. - Host mode. #### REGISTER 12-6: UxIR: USB INTERRUPT REGISTER ('x' = 1 AND 2) (CONTINUED) - bit 0 **DETACHIF:** USB Detach Interrupt bit (Host mode)<sup>(6)</sup> - 1 = Peripheral detachment was detected by the USB module - 0 = Peripheral detachment was not detected - **Note 1:** This bit is valid only if the HOSTEN bit is set (see Register 12-11), there is no activity on the USB for 2.5 µs, and the current bus state is not SE0. - 2: When not in Suspend mode, this interrupt should be disabled. - 3: Clearing this bit will cause the STAT FIFO to advance. - 4: Only error conditions enabled through the UxEIE register will set this bit. - 5: Device mode. - 6: Host mode. REGISTER 12-7: UxIE: USB INTERRUPT ENABLE REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-----------------------|-------------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | | | _ | | 15:8 | U-0 | 13.0 | _ | _ | _ | _ | _ | | | _ | | | R/W-0 | 7:0 | STALLIE | ATTACHIE | RESUMEIE | IDLEIE | TRNIE | SOFIE | UERRIE <sup>(1)</sup> | URSTIE <sup>(5)</sup> | | | OTALLIL | OTALLIL ATTACHIL I | | | | | OERRIE' | DETACHIE <sup>(6)</sup> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 STALLIE: STALL Handshake Interrupt Enable bit 1 = STALL interrupt is enabled0 = STALL interrupt is disabled bit 6 ATTACHIE: ATTACH Interrupt Enable bit 1 = ATTACH interrupt is enabled0 = ATTACH interrupt is disabled bit 5 **RESUMEIE:** RESUME Interrupt Enable bit 1 = RESUME interrupt is enabled0 = RESUME interrupt is disabled bit 4 IDLEIE: Idle Detect Interrupt Enable bit 1 = Idle interrupt is enabled0 = Idle interrupt is disabled bit 3 TRNIE: Token Processing Complete Interrupt Enable bit 1 = TRNIF interrupt is enabled0 = TRNIF interrupt is disabled bit 2 SOFIE: SOF Token Interrupt Enable bit 1 = SOFIF interrupt is enabled0 = SOFIF interrupt is disabled bit 1 **UERRIE:** USB Error Interrupt Enable bit<sup>(1)</sup> 1 = USB Error interrupt is enabled0 = USB Error interrupt is disabled bit 0 **URSTIE:** USB Reset Interrupt Enable bit<sup>(2)</sup> 1 = URSTIF interrupt is enabled0 = URSTIF interrupt is disabled **DETACHIE:** USB Detach Interrupt Enable bit<sup>(3)</sup> 1 = DATTCHIF interrupt is enabled0 = DATTCHIF interrupt is disabled Note 1: For an interrupt to propagate USBIF, the UERRIE bit (UxIE<1>) must be set. 2: Device mode. 3: Host mode. #### REGISTER 12-8: UXEIR: USB ERROR INTERRUPT STATUS REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|----------------------|----------------------|-------------------|-------------------|------------------------|------------------|--| | 24.04 | U-0 | | 31:24 | | _ | _ | _ | | _ | _ | _ | | | 22.46 | U-0 | | 23:16 | | _ | _ | _ | | _ | _ | _ | | | 45.0 | U-0 | | 15:8 | - | - | - | - | - | - | _ | _ | | | | R/WC-0, HS | | 7:0 | חדפרר | DMVEE | DMAEF <sup>(1)</sup> | BTOEF <sup>(2)</sup> | DENOEE | 0004655 | CRC5EF <sup>(4)</sup> | DIDEE | | | | BTSEF | SEF BMXEF DMAEF | | BIOEL- | DFN8EF | CRC16EF | EOFEF <sup>(3,5)</sup> | PIDEF | | Legend:WC = Write '1' to clearHS = Hardware Settable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 **BTSEF:** Bit Stuff Error Flag bit 1 = Packet rejected due to bit stuff error 0 = Packet accepted bit 6 BMXEF: Bus Matrix Error Flag bit 1 = The base address, of the BDT, or the address of an individual buffer pointed to by a BDT entry, is invalid. 0 = No address error bit 5 **DMAEF:** DMA Error Flag bit<sup>(1)</sup> 1 = USB DMA error condition detected 0 = No DMA error bit 4 **BTOEF:** Bus Turnaround Time-Out Error Flag bit<sup>(2)</sup> 1 = Bus turnaround time-out has occurred 0 = No bus turnaround time-out bit 3 **DFN8EF:** Data Field Size Error Flag bit 1 = Data field received is not an integral number of bytes 0 = Data field received is an integral number of bytes bit 2 CRC16EF: CRC16 Failure Flag bit 1 = Data packet is rejected due to CRC16 error 0 = Data packet is accepted - **Note 1:** This type of error occurs when the module's request for the DMA bus is not granted in time to service the module's demand for memory, resulting in an overflow or underflow condition, and/or the allocated buffer size is not sufficient to store the received data packet causing it to be truncated. - 2: This type of error occurs when more than 16-bit-times of Idle from the previous End-of-Packet (EOP) has elapsed. - **3:** This type of error occurs when the module is transmitting or receiving data and the SOF counter has reached zero. - 4: Device mode. - 5: Host mode. #### REGISTER 12-8: UXEIR: USB ERROR INTERRUPT STATUS REGISTER ('x' = 1 AND 2) bit 1 CRC5EF: CRC5 Host Error Flag bit<sup>(4)</sup> 1 = Token packet rejected due to CRC5 error 0 = Token packet is accepted **EOFEF:** EOF Error Flag bit<sup>(3,5)</sup> 1 = EOF error condition is detected 0 = No EOF error condition bit 0 PIDEF: PID Check Failure Flag bit 1 = PID check is failed 0 = PID check is passed - Note 1: This type of error occurs when the module's request for the DMA bus is not granted in time to service the module's demand for memory, resulting in an overflow or underflow condition, and/or the allocated buffer size is not sufficient to store the received data packet causing it to be truncated. - 2: This type of error occurs when more than 16-bit-times of Idle from the previous End-of-Packet (EOP) has elapsed. - **3:** This type of error occurs when the module is transmitting or receiving data and the SOF counter has reached zero. - 4: Device mode. - Host mode. #### REGISTER 12-9: UXEIE: USB ERROR INTERRUPT ENABLE REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-----------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | | _ | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | _ | | _ | | | R/W-0 | 7:0 | BTSEE | BTSEE BMXEE | חאאבב | BTOEE | DFN8EE | CRC16EE | CRC5EE <sup>(1)</sup> | PIDEE | | | DISEE | ISEE DIVIXEE L | | DMAEE BTOEE | | CKCTOEE | EOFEE <sup>(2)</sup> | FIDEE | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 BTSEE: Bit Stuff Error Interrupt Enable bit 1 = BTSEF interrupt is enabled 0 = BTSEF interrupt is disabled bit 6 BMXEE: Bus Matrix Error Interrupt Enable bit 1 = BMXEF interrupt is enabled0 = BMXEF interrupt is disabled bit 5 **DMAEE:** DMA Error Interrupt Enable bit 1 = DMAEF interrupt is enabled0 = DMAEF interrupt is disabled bit 4 BTOEE: Bus Turnaround Time-out Error Interrupt Enable bit 1 = BTOEF interrupt is enabled0 = BTOEF interrupt is disabled bit 3 **DFN8EE:** Data Field Size Error Interrupt Enable bit 1 = DFN8EF interrupt is enabled0 = DFN8EF interrupt is disabled bit 2 CRC16EE: CRC16 Failure Interrupt Enable bit 1 = CRC16EF interrupt is enabled0 = CRC16EF interrupt is disabled bit 1 CRC5EE: CRC5 Host Error Interrupt Enable bit<sup>(1)</sup> 1 = CRC5EF interrupt is enabled0 = CRC5EF interrupt is disabled **EOFEE:** EOF Error Interrupt Enable bit<sup>(2)</sup> 1 = EOF interrupt is enabled0 = EOF interrupt is disabled bit 0 PIDEE: PID Check Failure Interrupt Enable bit 1 = PIDEF interrupt is enabled0 = PIDEF interrupt is disabled Note 1: Device mode. 2: Host mode. Note: For an interrupt to propagate USBIF, the UERRIE bit (UxIE<1>) must be set. #### REGISTER 12-10: UxSTAT: USB STATUS REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | | _ | | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | - | - | - | - | - | - | - | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R-x | R-x | R-x | R-x | R-x | R-x | U-0 | U-0 | | 7:0 | | ENDP. | T<3:0> | | DIR | PPBI | _ | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-4 ENDPT<3:0>: Encoded Number of Last Endpoint Activity bits (Represents the number of the BDT, updated by the last USB transfer.) 1111 = Endpoint 15 1110 = Endpoint 14 : 0001 = Endpoint 1 0000 = Endpoint 0 bit 3 DIR: Last BD Direction Indicator bit 1 = Last transaction was a transmit transfer (TX) 0 = Last transaction was a receive transfer (RX) bit 2 PPBI: Ping-Pong BD Pointer Indicator bit 1 = The last transaction was to the ODD BD bank 0 = The last transaction was to the EVEN BD bank bit 1-0 **Unimplemented:** Read as '0' **Note:** The UxSTAT register is a window into a 4-byte FIFO maintained by the USB module. UxSTAT value is only valid when the TRNIF bit (UxIR<3>) is active. Clearing the TRNIF bit advances the FIFO. Data in register is invalid when the TRNIF bit = 0. #### REGISTER 12-11: UxCON: USB CONTROL REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|--------------------------|-----------------------|-----------------------|-----------------------|------------------|----------------------| | 24.04 | U-0 | 31:24 | 1 | _ | _ | _ | _ | _ | _ | - | | 22,46 | U-0 | 23:16 | 1 | _ | _ | _ | _ | _ | _ | - | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | - | | | R-x | R-x | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | ICTATE | SE0 | PKTDIS <sup>(4)</sup> | USBRST <sup>(5)</sup> | HOSTEN <sup>(2)</sup> | RESUME <sup>(3)</sup> | DDDDCT | USBEN <sup>(4)</sup> | | | JSTATE | SE0 | TOKBUSY <sup>(1,5)</sup> | USBRSIN | HOSTEN- | KESUME | PPBRST | SOFEN <sup>(5)</sup> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' 1 = JSTATE is detected on the USB 0 = No JSTATE is detected bit 6 SE0: Live Single-Ended Zero flag bit 1 = Single Ended Zero is detected on the USB 0 = No Single Ended Zero is detected bit 5 **PKTDIS:** Packet Transfer Disable bit<sup>(4)</sup> 1 = Token and packet processing are disabled (set upon SETUP token received) 0 = Token and packet processing are enabled **TOKBUSY:** Token Busy Indicator bit<sup>(1,5)</sup> 1 = Token being executed by the USB module 0 = No token being executed bit 4 USBRST: Module Reset bit<sup>(5)</sup> 1 = USB reset is generated 0 = USB reset is terminated bit 3 **HOSTEN:** Host Mode Enable bit<sup>(2)</sup> 1 = USB host capability is enabled 0 = USB host capability is disabled bit 2 **RESUME:** RESUME Signaling Enable bit<sup>(3)</sup> 1 = RESUME signaling is activated 0 = RESUME signaling is disabled #### bit 1 **PPBRST:** Ping-Pong Buffers Reset bit - 1 = Reset all Even/Odd buffer pointers to the EVEN BD banks - 0 = Even/Odd buffer pointers not being Reset - Note 1: Software is required to check this bit before issuing another token command to the UxTOK register (see Register 12-15). - 2: All host control logic is reset any time that the value of this bit is toggled. - 3: Software must set the RESUME bit for 10 ms if the part is a function, or for 25 ms if the part is a host, and then clear it to enable remote wake-up. In Host mode, the USB module will append a low-speed EOP to the RESUME signaling when this bit is cleared. - 4: Device mode. - 5: Host mode. #### REGISTER 12-11: UxCON: USB CONTROL REGISTER ('x' = 1 AND 2) (CONTINUED) bit 0 USBEN: USB Module Enable bit(4) 1 = USB module and supporting circuitry is enabled0 = USB module and supporting circuitry is disabled **SOFEN:** SOF Enable bit<sup>(5)</sup> 1 = SOF token sent every 1 ms 0 = SOF token disabled - **Note 1:** Software is required to check this bit before issuing another token command to the UxTOK register (see Register 12-15). - 2: All host control logic is reset any time that the value of this bit is toggled. - 3: Software must set the RESUME bit for 10 ms if the part is a function, or for 25 ms if the part is a host, and then clear it to enable remote wake-up. In Host mode, the USB module will append a low-speed EOP to the RESUME signaling when this bit is cleared. - 4: Device mode. - 5: Host mode. #### REGISTER 12-12: UxADDR: USB ADDRESS REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | - | - | _ | - | - | - | _ | | 7:0 | R/W-0 | 7:0 | LSPDEN | | | D | EVADDR<6:0 | )> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 LSPDEN: Low Speed Enable Indicator bit 1 = Next token command to be executed at Low Speed 0 = Next token command to be executed at Full Speed bit 6-0 **DEVADDR<6:0>:** 7-bit USB Device Address bits #### REGISTER 12-13: UxFRML: USB FRAME NUMBER LOW REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 24.04 | U-0 | | | | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 22.46 | U-0 | | | | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 15:8 | U-0 | | | | 15.6 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | 7.0 | R-0 | | | | 7:0 | | · | | FRML | <7:0> | | · | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-0 FRML<7:0>: The 11-bit Frame Number Lower bits The register bits are updated with the current frame number whenever a SOF TOKEN is received. #### REGISTER 12-14: UxFRMH: USB FRAME NUMBER HIGH REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | - | | _ | - | _ | - | _ | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | - | - | _ | - | - | - | _ | | 7.0 | U-0 | U-0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | | 7:0 | | | | | | | FRMH<2:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-3 Unimplemented: Read as '0' bit 2-0 FRMH<2:0>: The Upper 3 bits of the Frame Numbers bits The register bits are updated with the current frame number whenever a SOF TOKEN is received. #### REGISTER 12-15: UxTOK: USB TOKEN REGISTER ('x' = 1 AND 2) | | , | | | | | | | | |--------------|-------------------|-------------------|---------------------|-------------------|-------------------|-------------------|------------------|------------------| | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | 24.04 | U-0 | 31:24 | | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R/W-0 | 7:0 | | PID<3 | 3:0> <sup>(1)</sup> | | | EP< | 3:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-4 PID<3:0>: Token Type Indicator bits<sup>(1)</sup> 0001 = OUT (TX) token type transaction 1001 = IN (RX) token type transaction 1101 = SETUP (TX) token type transaction Note: All other values are reserved and must not be used. bit 3-0 **EP<3:0>:** Token Command Endpoint Address bits The four bit value must specify a valid endpoint. Note 1: All other values are reserved and must not be used. #### REGISTER 12-16: UxSOF: USB SOF THRESHOLD REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | - | _ | _ | _ | _ | - | _ | _ | | 22,16 | U-0 | 23:16 | - | _ | _ | _ | _ | - | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R/W-0 | 7:0 | | | | CNT | <7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-0 CNT<7:0>: SOF Threshold Value bits Typical values of the threshold are: 01001010 **= 64-byte packet** 00101010 = **32-byte packet** 00011010 = **16-byte packet** 00010010 = 8-byte packet #### REGISTER 12-17: UxBDTP1: USB BDT PAGE 1 REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | - | _ | - | _ | - | - | - | _ | | 00.46 | U-0 | 23:16 | - | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | - | _ | - | _ | - | - | - | _ | | 7.0 | R/W-0 U-0 | | 7:0 | | | ВІ | DTPTRL<15:9 | )> | | | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-1 BDTPTRL<15:9>: BDT Base Address bits This 7-bit value provides address bits 15 through 9 of the BDT base address, which defines the starting location of the BDT in system memory. The 32-bit BDT base address is 512-byte aligned. bit 0 Unimplemented: Read as '0' #### REGISTER 12-18: UxBDTP2: USB BDT PAGE 2 REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | | _ | | _ | _ | _ | _ | _ | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | - | _ | - | - | _ | - | _ | | 7.0 | R/W-0 | 7:0 | | | | BDTPTRI | H<23:16> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-0 BDTPTRH<23:16>: BDT Base Address bits This 8-bit value provides address bits 23 through 16 of the BDT base address, which defines the starting location of the BDT in system memory. The 32-bit BDT base address is 512-byte aligned. #### REGISTER 12-19: UxBDTP3: USB BDT PAGE 3 REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.40 | U-0 | 23:16 | - | _ | | _ | - | | - | | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | _ | - | | | 7.0 | R/W-0 | 7:0 | | | | BDTPTR | U<31:24> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-0 BDTPTRU<31:24>: BDT Base Address bits This 8-bit value provides address bits 31 through 24 of the BDT base address, defines the starting location of the BDT in system memory. The 32-bit BDT base address is 512-byte aligned. #### REGISTER 12-20: UxCNFG1: USB CONFIGURATION 1 REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | - | _ | - | - | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | - | _ | | 7.0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | | 7:0 | UTEYE | UOEMON | _ | USBSIDL | LSDEV | _ | _ | UASUSPND | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' '1' = Bit is set -n = Value at POR '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 UTEYE: USB Eye-Pattern Test Enable bit > 1 = Eye-Pattern Test is enabled 0 = Eye-Pattern Test is disabled **UOEMON:** USB OE Monitor Enable bit bit 6 1 = OE signal is active; it indicates intervals during which the D+/D- lines are driving 0 = OE signal is inactive bit 5 Unimplemented: Read as '0' bit 4 USBSIDL: Stop in Idle Mode bit 1 = Discontinue module operation when device enters Idle mode 0 = Continue module operation is in Idle mode bit 3 LSDEV: Low-Speed Device Enable bit 1 = USB module to operate in Low-Speed Device mode 0 = USB module to operate in OTG, Host, or Full-Speed Device mode bit 2-1 Unimplemented: Read as '0' bit 0 **UASUSPND:** Automatic Suspend Enable bit - 1 = USB module automatically suspends upon entry to Sleep mode. See the USUSPEND bit (UxPWRC<1>) in Register 12-5. - 0 = USB module does not automatically suspend upon entry to Sleep mode. Software must use the USUSPEND bit (UxPWRC<1>) to suspend the module, including the USB 48 MHz clock #### REGISTER 12-21: UxEP0-UxEP15: USB ENDPOINT CONTROL REGISTER ('x' = 1 AND 2) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | - | _ | - | _ | _ | | | _ | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | LSPD | RETRYDIS | _ | EPCONDIS | EPRXEN | EPTXEN | EPSTALL | EPHSHK | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 LSPD: Low-Speed Direct Connection Enable bit (Host mode and UxEP0 only) 1 = Direct connection to a low-speed device is enabled 0 = Direct connection to a low-speed device is disabled; hub required with PRE\_PID bit 6 **RETRYDIS:** Retry Disable bit (Host mode and UxEP0 only) 1 = Retry NAKed transactions is disabled 0 = Retry NAKed transactions is enabled; retry done in hardware bit 5 Unimplemented: Read as '0' bit 4 EPCONDIS: Bidirectional Endpoint Control bit If EPTXEN = 1 and EPRXEN = 1: - 1 = Disable Endpoint n from Control transfers; only TX and RX transfers allowed - 0 = Enable Endpoint n for Control (SETUP) transfers; TX and RX transfers also allowed Otherwise, this bit is ignored. - bit 3 EPRXEN: Endpoint Receive Enable bit - 1 = Endpoint n receive is enabled - 0 = Endpoint n receive is disabled - bit 2 **EPTXEN:** Endpoint Transmit Enable bit - 1 = Endpoint n transmit is enabled - 0 = Endpoint n transmit is disabled - bit 1 **EPSTALL:** Endpoint Stall Status bit - 1 = Endpoint n was stalled - 0 = Endpoint n was not stalled - bit 0 EPHSHK: Endpoint Handshake Enable bit - 1 = Endpoint Handshake is enabled - 0 = Endpoint Handshake is disabled (typically used for isochronous endpoints) #### 13.0 I/O PORTS Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 12.** "I/O Ports" (DS60001120), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). General purpose I/O pins are the simplest of peripherals. They allow the PIC32MK GPK/MCM with CAN FD Family of devices to monitor and control other devices. To add flexibility and functionality, some pins are multiplexed with alternate function(s). These functions depend on which peripheral features are on the device. In general, when a peripheral is functioning, that pin may not be used as a general purpose I/O pin. The following are key features of the I/O ports: - · Individual output pin open-drain enable/disable - · Individual input pin weak pull-up and pull-down - Monitor selective inputs and generate interrupt when change in pin state is detected - · Operation during Sleep and Idle modes - Fast bit manipulation using CLR, SET, and INV registers Figure 13-1 illustrates a block diagram of a typical multiplexed I/O port. FIGURE 13-1: BLOCK DIAGRAM OF A TYPICAL MULTIPLEXED PORT STRUCTURE #### 13.1 Parallel I/O (PIO) Ports All port pins have ten registers directly associated with their operation as digital I/O. The data direction register (TRISx) determines whether the pin is an input or an output. If the data direction bit is a '1', then the pin is an input. All port pins are defined as inputs after a Reset. Reads from the latch (LATx) read the latch. Writes to the latch write the latch. Reads from the port (PORTx) read the port pins, while writes to the port pins write the latch. #### 13.1.1 OPEN-DRAIN CONFIGURATION In addition to the PORTx, LATx, and TRISx registers for data control, some port pins can also be individually configured for either digital or open-drain output. This is controlled by the Open-Drain Control register, ODCx, associated with each port. Setting any of the bits configures the corresponding pin to act as an open-drain output. The open-drain feature allows the generation of outputs higher than VDD (e.g., 5V) on any desired 5V-tolerant pins by using external pull-up resistors. The maximum open-drain voltage allowed is the same as the maximum VIH specification. Refer to the pin name tables (Table 3 and Table 5) for the available pins and their functionality. # 13.1.2 CONFIGURING ANALOG AND DIGITAL PORT PINS The ANSELx register controls the operation of the analog port pins. The port pins that are to function as analog inputs must have their corresponding ANSEL and TRIS bits set. In order to use port pins for I/O functionality with digital modules, such as Timers, UARTs, etc., the corresponding ANSELx bit must be cleared. The ANSELx register has a default value of 0xFFFF; therefore, all pins that share analog functions are analog (not digital) by default. If the TRIS bit is cleared (output) while the ANSELx bit is set, the digital output level (VOH or VOL) is converted by an analog peripheral, such as the ADC module or Comparator module. When the PORT register is read, all pins configured as analog input channels are read as cleared (a low level). Pins configured as digital inputs do not convert an analog input. Analog levels on any pin defined as a digital input (including the ANx pins) can cause the input buffer to consume current that exceeds the device specifications. #### 13.1.3 I/O PORT WRITE/READ TIMING One instruction cycle is required between a port direction change or port write operation and a read operation of the same port. Typically this instruction would be an NOP. #### 13.1.4 INPUT CHANGE NOTIFICATION The input change notification function of the I/O ports allows the PIC32MK GPK/MCM with CAN FD Family devices to generate interrupt requests to the processor in response to a change-of-state on selected input pins. This feature can detect input change-of-states even in Sleep mode, when the clocks are disabled. Every I/O port pin can be selected (enabled) for generating an interrupt request on a change-of-state. Five control registers are associated with the CN functionality of each I/O port. The CNENx and CNNEx registers contain the CN interrupt enable control bits for each of the input pins. Setting these bits enables a CN interrupt for the corresponding pins. The CNENx register enables a mismatch CN interrupt condition when the EDGEDETECT bit (CNCONx<11>) is not set. When the EDGEDETECT bit is set, the CNNEx register controls the negative edge while the CNENx register controls the positive edge. The CNSTATx and CNFx registers indicate the status of change notice based on the setting of the EDGEDETECT bit. If the EDGEDETECT bit is set to '0', the CNSTATx register indicates whether a change occurred on the corresponding pin since the last read of the PORTx bit. If the EDGEDETECT bit is set to '1', the CNFx register indicates whether a change has occurred and through the CNNEx and CNENx registers the edge type of the change that occurred is also indicated. Each I/O pin also has a weak pull-up and a weak pull-down connected to it. The pull-ups act as a current source or sink source connected to the pin, and eliminate the need for external resistors when push-button or keypad devices are connected. The pull-ups and pull-downs are enabled separately using the CNPUx and the CNPDx registers, which contain the control bits for each of the pins. Setting any of the control bits enables the weak pull-ups and/or pull-downs for the corresponding pins. **Note:** Pull-ups and pull-downs on change notification pins should always be disabled when the port pin is configured as a digital output. An additional control register (CNCONx) is shown in Register 13-3. #### 13.2 CLR, SET, and INV Registers Every I/O module register has a corresponding CLR (clear), SET (set) and INV (invert) register designed to provide fast atomic bit manipulations. As the name of the register implies, a value written to a SET, CLR or INV register effectively performs the implied operation, but only on the corresponding base register and only bits specified as '1' are modified. Bits specified as '0' are not modified. Reading SET, CLR and INV registers returns undefined values. To see the affects of a write operation to a SET, CLR or INV register, the base register must be read. #### 13.3 Peripheral Pin Select (PPS) A major challenge in general purpose devices is providing the largest possible set of peripheral features while minimizing the conflict of features on I/O pins. The challenge is even greater on low pin-count devices. In an application where more than one peripheral needs to be assigned to a single pin, inconvenient workarounds in application code or a complete redesign may be the only option. PPS configuration provides an alternative to these choices by enabling peripheral set selection and their placement on a wide range of I/O pins. By increasing the pinout options available on a particular device, users can better tailor the device to their entire application, rather than trimming the application to fit the device. The PPS configuration feature operates over a fixed subset of digital I/O pins. Users may independently map the input and/or output of most digital peripherals to these I/O pins. PPS is performed in software and generally does not require the device to be reprogrammed. Hardware safeguards are included that prevent accidental or spurious changes to the peripheral mapping once it has been established. #### 13.3.1 AVAILABLE PINS The number of available pins is dependent on the particular device and its pin count. Pins that support the PPS feature include the designation "RPn" in their full pin designation, where "RP" designates a remappable peripheral and "n" is the remappable port number. #### 13.3.2 AVAILABLE PERIPHERALS The peripherals managed by the PPS are all digitalonly peripherals. These include general serial communications (UART, SPI, and CAN), general purpose timer clock inputs, timer-related peripherals (input capture and output compare), interrupt-on-change inputs, and reference clocks (input and output). In comparison, some digital-only peripheral modules are never included in the PPS feature. This is because the peripheral's function requires special I/O circuitry on a specific port and cannot be easily connected to multiple pins. A similar requirement excludes all modules with analog inputs, such as the Analog-to-Digital Converter (ADC). A key difference between remappable and non-remappable peripherals is that remappable peripherals are not associated with a default I/O pin. The peripheral must always be assigned to a specific I/O pin before it can be used. In contrast, non-remappable peripherals are always available on a default pin, assuming that the peripheral is active and not conflicting with another peripheral. When a remappable peripheral is active on a given I/O pin, it takes priority over all other digital I/O and digital communication peripherals associated with the pin. Priority is given regardless of the type of peripheral that is mapped. Remappable peripherals never take priority over any analog functions associated with the pin. #### 13.3.3 CONTROLLING PPS PPS features are controlled through two sets of SFRs: one to map peripheral inputs, and one to map outputs. Because they are separately controlled, a particular peripheral's input and output (if the peripheral has both) can be placed on any selectable function pin without constraint. The association of a peripheral to a peripheral-selectable pin is handled in two different ways, depending on whether an input or output is being mapped. #### 13.3.4 INPUT MAPPING The inputs of the PPS options are mapped on the basis of the peripheral. That is, a control register associated with a peripheral dictates the pin it will be mapped to. The [pin name]R registers, where [pin name] refers to the peripheral pins listed in Table 13-1, are used to configure peripheral input mapping (see Register 13-1). Each register contains sets of 4 bit fields. Programming these bit fields with an appropriate value maps the RPn pin with the corresponding value to that peripheral. For any given device, the valid range of values for any bit field is shown in Table 13-1. Figure 13-2 illustrates the remappable pin selection for the U1RX input. # FIGURE 13-2: REMAPPABLE INPUT EXAMPLE FOR U1RX **TABLE 13-1: INPUT PIN SELECTION** | Peripheral Pin | [pin name]R SFR | [pin name]R bits | [pin name]R Value to<br>RPn Pin Selection | |----------------------|-----------------|------------------|-------------------------------------------| | INT4 | INT4R<3:0> | INT4R | 0000 = RPA0 | | T2CK | T2CKR<3:0> | T2CKR | DDD0 | | T6CK | T6CKR<3:0> | T6CKR | 0001 = RPB3 | | IC4 | IC4R<3:0> | IC4R | 0010 = <b>RPB4</b> | | IC7 | IC7R<3:0> | IC7R | | | IC12 | IC12R<3:0> | IC12R | 0011 = RPB15 | | IC15 | IC15R<3:0> | IC15R | 0100 = RPB7 | | U3RX | U3RXR<3:0> | U3RXR | | | U4CTS | U4CTSR<3:0> | U4CTSR | 0101 = RPC7 | | U6RX | U6RXR<3:0> | U6RXR | 0110 = RPC0 | | SDI1 | SDI1R<3:0> | SDI1R | | | SDI3 | SDI3R<3:0> | SDI3R | 0111 = Reserved | | SCK4 | SCK4R<3:0> | SCK4R | 1000 <b>= RPA11</b> | | SDI5 | SDI5R<3:0> | SDI5R | 1000 | | SS6 | SS6R<3:0> | SS6R | 1001 <b>= RPD5</b> | | QEA1 <sup>(2)</sup> | QEA1R<3:0> | QEA1R | 1010 = <b>RPG6</b> | | HOME2 <sup>(2)</sup> | HOME2R<3:0> | HOME2R | 1010 14 00 | | QAEA3 <sup>(2)</sup> | QAEA3R<3:0> | QEA3R | 1011 = RPF1 | | HOME4 <sup>(2)</sup> | HOME4R<3:0> | HOME4R | 1100 = RPE0 <sup>(1)</sup> | | QEA5 <sup>(2)</sup> | QEA5R<3:0> | QEA5R | 1100 - 101 20 | | HOME6 <sup>(2)</sup> | HOME6R<3:0> | HOME6R | 1101 = RPA15 <sup>(1)</sup> | | FLT1 <sup>(2)</sup> | FLT1R<3:0> | FLT1R | 1110 - <b>Pagaryad</b> | | C3RX <sup>(3)</sup> | C3RXR<3:0> | C3RXR | 1110 = Reserved | | REFCLKI | REFIR <3:0> | REFIR | 1111 = Reserved | - 2: Only available on "MCM" variant. - 3: Not available on "GPK" variant. - 4: Not available on "GPK" variant. TABLE 13-1: INPUT PIN SELECTION (CONTINUED) | Peripheral Pin | [pin name]R SFR | [pin name]R bits | [pin name]R Value to<br>RPn Pin Selection | |----------------------|-----------------|------------------|-------------------------------------------| | INT3 | INT3R<3:0> | INT3R | 0000 = RPA1 | | T3CK | T3CKR<3:0> | T3CKR | 0001 <b>= RPB5</b> | | T7CK | T7CKR<3:0> | T7CKR | 0010 = RPB1 | | IC3 | IC3R<3:0> | IC3R | | | IC8 | IC8R<3:0> | IC8R | 0011 <b>= RPB11</b> | | IC11 | IC11R<3:0> | IC11R | 0100 <b>= RPB8</b> | | IC16 | IC16R<3:0> | IC16R | 0101 <b>= RPA8</b> | | U1CTS | U1CTSR<3:0> | U1CTSR | 0110 = <b>RPC8</b> | | U2RX | U2RXR<3:0> | U2RXR | | | U5CTS | U5CTSR<3:0> | U5CTSR | 0111 <b>= RPB12</b> | | SDI2 | SDI2R<3:0> | SDI2R | 1000 <b>= RPA12</b> | | SDI4 | SDI4R<3:0> | SDI4R | 1001 <b>= RPD6</b> | | SCK6 | SCK6R<3:0> | SCK6R | 1010 = <b>RPG7</b> | | QEB1 <sup>(2)</sup> | QEB1R<3:0> | QEB1R | | | INDX2 <sup>(2)</sup> | INDX2R<3:0> | INDX2R | 1011 = RPG0 <sup>(1)</sup> | | QEB3 <sup>(2)</sup> | QEB3R<3:0> | QEB3R | 1100 = RPE1 <sup>(1)</sup> | | INDX4 <sup>(2)</sup> | INDX4R<3:0> | INDX4R | 1101 = RPA14 <sup>(1)</sup> | | QEB5 <sup>(2)</sup> | QEB5R<3:0> | QEB5R | 1110 = Reserved | | INDX6 <sup>(2)</sup> | INDX6R<3:0> | INDX6R | | | C2RX <sup>(3)</sup> | C2RXR<3:0> | C2RXR | 1111 = Reserved | | FLT2 <sup>(2)</sup> | FLT2R <3:0> | FLT2R | | - 2: Only available on "MCM" variant. - 3: Not available on "GPK" variant. - 4: Not available on "GPK" variant. TABLE 13-1: INPUT PIN SELECTION (CONTINUED) | Peripheral Pin | [pin name]R SFR | [pin name]R bits | [pin name]R Value to<br>RPn Pin Selection | |----------------------|-----------------|------------------|-------------------------------------------| | INT2 | INT2R<3:0> | INT2R | 0000 = RPB6 | | T4CK | T4CKR<3:0> | T4CKR | 0001 <b>= RPC15</b> | | T8CK | T8CKR<3:0> | T8CKR | 0001 - 14 010 | | IC1 | IC1R<3:0> | IC1R | 0010 <b>= RPA4</b> | | IC5 | IC5R<3:0> | IC5R | 0011 <b>= RPB13</b> | | IC9 | IC9R<3:0> | IC9R | 0100 DDD0 | | IC13 | IC13R<3:0> | IC13R | 0100 = RPB2 | | U1RX | U1RXR<3:0> | U1RXR | 0101 = RPC6 | | U2CTS | U2CTSR<3:0> | U2CTSR | 0110 = <b>RPC1</b> | | U5RX | U5RXR<3:0> | U5RXR | | | SS1 | SS1R<3:0> | SS1R | 0111 <b>= RPA7</b> | | SS3 | SS3R<3:0> | SS3R | 1000 = RPE14 | | SS4 | SS4R<3:0> | SS4R | 1001 = RPC13 | | SS5 | SS5R<3:0> | SS5R | 1001 - RPC13 | | INDX1 <sup>(2)</sup> | INDX1R<3:0> | INDX1R | 1010 <b>= RPG8</b> | | QEB2 <sup>(2)</sup> | QEB2R<3:0> | QEB2R | 1011 = Reserved | | INDX3 <sup>(2)</sup> | INDX3R<3:0> | INDX3R | | | QEB4 <sup>(2)</sup> | QEB4R<3:0> | QEB4R | 1100 = RPF0 | | INDX5 <sup>(2)</sup> | INDX5R<3:0> | INDXR5 | 1101 = RPD4 <sup>(1)</sup> | | QEB6 <sup>(2)</sup> | QEB6R<3:0> | QEB6R | 1110 = Reserved | | C1RX <sup>(3)</sup> | C1RXR<3:0> | C1RXR | TITU - Reserved | | OCFB | OCFBR<3:0> | OCFBR | 1111 = Reserved | - 2: Only available on "MCM" variant. - 3: Not available on "GPK" variant. - 4: Not available on "GPK" variant. TABLE 13-1: INPUT PIN SELECTION (CONTINUED) | Peripheral Pin | [pin name]R SFR | [pin name]R bits | [pin name]R Value to<br>RPn Pin Selection | |----------------------|--------------------------|------------------|-------------------------------------------| | INT1 | INT1R<3:0> | INT1R | 0000 = RPB14 | | T5CK | T5CKR<3:0> | T5CKR | 0001 <b>= RPC12</b> | | T9CK | T9CKR<3:0> | T9CKR | 0001 - 14 012 | | IC2 | IC2R<3:0> | IC2R | 0010 <b>= RPB0</b> | | IC6 | IC6R<3:0> | IC6R | 0011 = RPB10 | | IC10 | IC10R<3:0> | IC10R | 0100 DDD0 | | IC14 | IC14R<3:0> | IC14R | 0100 = RPB9 | | U3CTS | U3CTSR<3:0> | U3CTSR | 0101 = RPC9 | | U4RX | U4RXR<3:0> | U4RXR | 0110 = RPC2 | | U6CTS | U6CTSR<3:0> | U6CTSR | | | SS2 | SS2R<3:0> <sup>(2)</sup> | SS2R | 0111 = Reserved | | SCK3 | SCK3R<3:0> | SCK3R | 1000 = RPE15 | | SCK5 | SCK5R<3:0> | SCK5R | 1001 - PPC40 | | SDI6 | SDI6R<3:0> | SDI6R | 1001 = RPC10 | | HOME1 <sup>(3)</sup> | HOME1R<3:0> | HOME1R | 1010 <b>= RPG9</b> | | QEA2 <sup>(3)</sup> | QEA2R<3:0> | QEA2R | 1011 = RPG12 <sup>(1)</sup> | | HOME3 <sup>(3)</sup> | HOME3R<3:0> | HOME3R | | | QEA4 <sup>(3)</sup> | QEA4R<3:0> | QEA4R | 1100 = RPG1 <sup>(1)</sup> | | HOME5 <sup>(3)</sup> | HOME5R<3:0> | HOME5R | 1101 = RPD3 <sup>(1)</sup> | | QEA6 <sup>(3)</sup> | QEA6R<3:0> | QEA6R | | | C4RX <sup>(4)</sup> | C4RXR<3:0> | C4RXR | TIIU - Reserved | | OCFA | OCFAR<3:0> | OCFAR | 1111 = Reserved | Note 1: This selection is not available on 64-pin devices. - 2: Only available on "MCM" variant. - 3: Not available on "GPK" variant. - 4: Not available on "GPK" variant. #### 13.3.5 OUTPUT MAPPING In contrast to inputs, the outputs of the PPS options are mapped on the basis of the pin. In this case, a control register associated with a particular pin dictates the peripheral output to be mapped. The RPnR registers (Register 13-2) are used to control output mapping. Like the [pin name]R registers, each register contains sets of 4 bit fields. The value of the bit field corresponds to one of the peripherals, and that peripheral's output is mapped to the pin (see Table 13-2 and Figure 13-3). A null output is associated with the output register reset value of '0'. This is done to ensure that remappable outputs remain disconnected from all output pins by default. FIGURE 13-3: EXAMPLE OF MULTIPLEXING OF REMAPPABLE OUTPUT # 13.3.6 CONTROLLING CONFIGURATION CHANGES Because peripheral remapping can be changed during run time, some restrictions on peripheral remapping are needed to prevent accidental configuration changes. The PIC32MK GPK/MCM with CAN FD Family devices include two features to prevent alterations to the peripheral map: - · Control register lock sequence - · Configuration bit select lock #### 13.3.6.1 Control Register Lock Under normal operation, writes to the RPnR and [pin name]R registers are not allowed. Attempted writes appear to execute normally, but the contents of the registers remain unchanged. To change these registers, they must be unlocked in hardware. The register lock is controlled by the IOLOCK Configuration bit (CFGCON<13>). Setting the IOLOCK bit prevents writes to the control registers and clearing the IOLOCK bit allows writes. To set or clear the IOLOCK bit, an unlock sequence must be executed. Refer to the **Section 42. "Oscillators with Enhanced PLL"** (DS60001250) in the "PIC32 Family Reference Manual" for details. ### 13.3.6.2 Configuration Bit Select Lock As an additional level of safety, the device can be configured to prevent more than one write session to the RPnR and [pin name]R registers. The IOL1WAY Configuration bit (DEVCFG3<29>) blocks the IOLOCK bit from being cleared after it has been set once. If the IOLOCK bit remains set, the register unlock procedure does not execute, and the PPS control registers cannot be written to. The only way to clear the bit and reenable peripheral remapping is to perform a device Reset. In the default (unprogrammed) state, IOL1WAY is set, restricting users to one write session. **TABLE 13-2: OUTPUT PIN SELECTION** | RPn Port Pin | RPnR SFR | RPnR bits | RPnR Value to Peripheral<br>Selection | |----------------------|-----------------------|----------------------------|----------------------------------------------------------------------------------------| | RPA0 | RPA0R | RPA0R<4:0> | 00000 = Off<br>00001 = U1TX | | RPB3 | RPB3R | RPB3R<4:0> | 00010 = U2RTS<br>00011 = SDO1 | | RPB4 | RPB4R | RPB4R<4:0> | 00100 = SDO2<br>00101 = OCI | | RPB15 | RPB15R | RPB15R<4:0> | 00110 = OC7<br>00111 = C2OUT | | RPB7 | RPB7R | RPB7R<4:0> | 01000 = C4OUT<br>01001 = OC13 | | RPC7 | RPC7R | RPC7R<4:0> | 01010 = <u>Reserved</u><br>- 01011 = <u>U5RTS</u> | | RPC0 | RPC0R | RPC0R<4:0> | 01100 = C1TX <sup>(3)</sup><br>- 01101 = Reserved | | RPA11 | RPA11R | RPA11R<4:0> | 01110 = SDO3<br>-01111 = SCK4 | | RPD5 | RPD5R | RPD5R<4:0> | 10000 = <u>SDO</u> 5<br>-10001 = <u>SS6</u> | | RPG6 | RPG6R | RPG6R<4:0> | 10001 - 330<br>10010 = REFCLKO4<br>- 10011 = Reserved | | RPF1 | RPF1R | RPF1R<4:0> | 10101 = Reserved<br>10100 = QEICMP1 <sup>(2)</sup><br>- 10101 = QEICMP5 <sup>(2)</sup> | | RPE0 <sup>(1)</sup> | RPE0R <sup>(1)</sup> | RPE0R<4:0> <sup>(1)</sup> | 101101 = QEICMP5(-) | | RPA15 <sup>(1)</sup> | RPA15R <sup>(1)</sup> | RPA15R<4:0> <sup>(1)</sup> | 11111 = Reserved | Note 1: This selection is not available on 64-pin devices. 2: Only available on "MCM" variant. 3: Not available on "GPK" variant. TABLE 13-2: OUTPUT PIN SELECTION (CONTINUED) | RPn Port Pin | RPnR SFR | RPnR bits | RPnR Value to Peripheral<br>Selection | |----------------------|-----------------------|----------------------------|--------------------------------------------------------------------------| | RPA1 | RPA1R | RPA1R<4:0> | 00000 = Off<br>00001 = U3RTS | | RPB5 | RPB5R | RPB5R<4:0> | 00010 = U4TX<br>00011 = SDO1 | | RPB1 | RPB1R | RPB1R<4:0> | 00100 = SDO2<br>00101 = OC2 | | RPB11 | RPB11R | RPB11R<4:0> | 00110 = OC8<br>00111 = C3OUT | | RPA8 | RPA8R | RPA8R<4:0> | 01000 = OC9<br>01001 = OC12 | | RPC8 | RPC8R | RPC8R<4:0> | 101010 = <u>OC16</u><br> 01011 = U6RTS<br> 01100 = C4TX <sup>(3)</sup> | | RPB12 | RPB12R | RPB12R<4:0> | 01100 = <b>C41X</b> 01101 = <b>Reserved</b> 01110 = <b>SDO3</b> | | RPA12 | RPA12R | RPA12R<4:0> | 01111 = SDO4<br>10000 = SDO5 | | RPD6 | RPD6R | RPD6R<4:0> | 10001 = SCK6<br>10010 = REFCLKO3 | | RPG7 | RPG7R | RPG7R<4:0> | 10011 = Reserved<br>10100 = QEICMP2 <sup>(2)</sup> | | RPG0 <sup>(1)</sup> | RPG0R <sup>(1)</sup> | RPG0R<4:0> <sup>(1)</sup> | 10101 = QEICMP6 <sup>(2)</sup><br>10110 = Reserved | | RPE1 <sup>(1)</sup> | RPE1R <sup>(1)</sup> | RPE1R<4:0> <sup>(1)</sup> | | | RPA14 <sup>(1)</sup> | RPA14R <sup>(1)</sup> | RPA14R<4:0> <sup>(1)</sup> | 11111 = Reserved | - 2: Only available on "MCM" variant. - **3:** Not available on "GPK" variant. TABLE 13-2: OUTPUT PIN SELECTION (CONTINUED) | RPn Port Pin | RPnR SFR | RPnR bits | RPnR Value to Peripheral<br>Selection | |---------------------|----------------------|---------------------------|---------------------------------------------------------| | RPB6 | RPB6R | RPB6R<4:0> | 00000 = Off<br>00001 = U3TX | | RPC15 | RPC15R | RPC15R<4:0> | 00010 = <u>U4RTS</u><br>00011 = <u>SS1</u> | | RPA4 | RPA4R | RPA4R<4:0> | 00100 = Reserved<br>00101 = OC4 | | RPB13 | RPB13R | RPB13R<4:0> | 00110 = OC5<br>00111 = REFCLKO1 | | RPB2 | RPB2R | RPB2R<4:0> | 01000 = C5OUT<br>01001 = OC10 | | RPC6 | RPC6R | RPC6R<4:0> | 01010 = OC14<br>01011 = U6TX | | RPC1 | RPC1R | RPC1R<4:0> | 01100 = C3TX <sup>(3)</sup><br>01101 = <u>Res</u> erved | | RPA7 | RPA7R | RPA7R<4:0> | 01110 = <u>SS3</u><br>01111 = <u>SS4</u> | | RPE14 | RPE14R | RPE14R<4:0> | 10000 = SS5<br>10001 = SDO6 | | RPG8 | RPG8R | RPG8R<4:0> | 10010 = REFCLKO2<br>10011 = Reserved | | RPF0 | RPF0R | RPF0R<4:0> | 10100 = QEICMP3 <sup>(2)</sup><br>10101 = Reserved | | RPD4 <sup>(1)</sup> | RPD4R <sup>(1)</sup> | RPD4R<4:0> <sup>(1)</sup> | 11111 = Reserved | Note 1: This selection is not available on 64-pin devices. 2: Only available on "MCM" variant. 3: Not available on "GPK" variant. TABLE 13-2: OUTPUT PIN SELECTION (CONTINUED) | RPn Port Pin | RPnR SFR | RPnR bits | RPnR Value to Peripheral<br>Selection | |----------------------|-----------------------|---------------------------|-----------------------------------------------------| | RPB14 | RPB14R | RPB14R<4:0> | 00000 = Off<br>00001 = U1RTS | | RPC12 | RPC12R | RPC12R<4:0> | 00010 = U2TX<br>00011 = Reserved | | RPB0 | RPB0R | RPB0R<4:0> | 00100 = SS2<br>00101 = OC3 | | RPB10 | RPB10R | RPB10R<4:0> | 00110 = OC6<br>00111 = C1OUT | | RPB9 | RPB9R | RPB9R<4:0> | 01000 = Reserved<br>01001 = OC11 | | RPC9 | RPC9R | RPC9R<4:0> | 01010 = OC15<br> | | RPC2 | RPC2R | RPC2R<4:0> | 01100 = C2TX <sup>(3)</sup><br>- 01101 = Reserved | | RPE15 | RPE15R | RPE15R<4:0> | 01110 = SCK3<br>01111 = SDO4 | | RPC10 | RPC10R | RPC10R<4:0> | 10000 = SCK5<br>-10001 = SDO6 | | RPG9 | RPG9R | RPG9R<4:0> | 10010 = CTPLS<br>- 10011 = Reserved | | RPG12 <sup>(1)</sup> | RPG12R <sup>(1)</sup> | RPG12R<4:0> | 10100 = QEICMP4 <sup>(2)</sup><br>-10101 = Reserved | | RPG1 <sup>(1)</sup> | RPG1R <sup>(1)</sup> | RPG1R<4:0> <sup>(1)</sup> | • | | RPD3 <sup>(1)</sup> | RPD3R <sup>(1)</sup> | RPD3R<4:0> <sup>(1)</sup> | 11111 = Reserved | Note 1: This selection is not available on 64-pin devices. 2: Only available on "MCM" variant. 3: Not available on "GPK" variant. ### 13.4 I/O Ports Control Registers TABLE 13-3: PORTA REGISTER MAP FOR 100-PIN DEVICES ONLY | ess | | 0 | | | | | | | | Bi | ts | | | | | | | | | |-----------------------------|---------------------------------|-----------|------------------|-------------------|-------|----------------|------------------|----------------|------|----------------|---------------|------|------|--------------|------|------|--------------|--------------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0000 | ANSELA | 31:16 | _ | _ | | | _ | | | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | ANSA15 | ANSA14 | | ANSA12 | ANSA11 | _ | | ANSA8 | _ | | | ANSA4 | | _ | ANSA1 | ANSA0 | D813 | | 0010 | TRISA | 31:16 | _ | _ | _ | _ | _ | _ | | _ | _ | | | _ | | _ | _ | _ | 0000 | | | | 15:0 | TRISA15 | TRISA14 | _ | TRISA12 | TRISA11 | TRISA10 | | TRISA8 | TRISA7 | | | TRISA4 | | _ | TRISA1 | TRISA0 | DD93 | | 0020 | PORTA | 31:16 | _ | _ | _ | _ | _ | _ | | _ | _ | | | _ | | _ | _ | _ | 0000 | | | | 15:0 | RA15 | RA14 | _ | RA12 | RA11 | RA10 | _ | RA8 | RA7 | | | RA4 | | _ | RA1 | RA0 | XXXX | | 0030 | LATA | 31:16 | _ | _ | _ | | | | _ | | _ | | | | | _ | | | 0000 | | | | 15:0 | LATA15 | LATA14 | _ | LATA12 | LATA11 | LATA10 | _ | LATA8 | LATA7 | | | LATA4 | | _ | LATA1 | LATA0 | XXXX | | 0040 | ODCA | 31:16 | _ | | | _ | | _ | | _ | _ | | _ | _ | | _ | | | 0000 | | | | 15:0 | ODCA15 | ODCA14 | | ODCA12 | ODCA11 | ODCA10 | | ODCA8 | ODCA7 | | _ | ODCA4 | | _ | ODCA1 | ODCA0 | 0000 | | 0050 | CNPUA | 31:16 | —<br>ONIDI IA 45 | —<br>ONIDI 14.4.4 | | —<br>ONIDHA40 | —<br>ONIDI 14.44 | —<br>ONDUA40 | | — | —<br>ONDUAT | | | — — — | | _ | - CNIBULA | | 0000 | | | | | CNPUA15 | CNPUA14 | | CNPUA12 | CNPUA11 | CNPUA10 | | CNPUA8 | CNPUA7 | | | CNPUA4 | | _ | CNPUA1 | CNPUA0 | 0000 | | 0060 | CNPDA | 31:16 | —<br>ONIDD 445 | —<br>ONIDD 4.4.4 | | —<br>ONIDD 440 | —<br>ONIDD 444 | —<br>ONIDD 440 | | —<br>ONIDD 4.0 | —<br>ONDD 4.7 | | | — ONDD 4.4 | | _ | | | 0000 | | | | | CNPDA15 | | | | CNPDA11 | CNPDA10 | | CNPDA8 | CNPDA7 | | | CNPDA4 | | _ | CNPDA1 | CNPDA0 | 0000 | | 0070 | CNCONA | 31:16 | _ | | | | - | _ | | _ | | | | _ | | _ | _ | | 0000 | | 0070 | CINCONA | 15:0 | ON | _ | SIDL | _ | EDGE<br>DETECT | _ | - | _ | _ | | _ | _ | | _ | _ | _ | 0000 | | 0080 | CNENA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | _ | 0000 | | 0000 | ONLIVE | 15:0 | CNIEA15 | CNIEA14 | _ | CNIEA12 | CNIEA11 | CNIEA10 | | CNIEA8 | CNIEA7 | | | CNIEA4 | | _ | CNIEA1 | CNIEA0 | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0090 | CNSTATA | 15:0 | CN<br>STATA15 | CN<br>STATA14 | _ | CN<br>STATA12 | CN<br>STATA11 | CN<br>STATA10 | _ | CN<br>STATA8 | CN<br>STATA7 | _ | _ | CN<br>STATA4 | _ | _ | CN<br>STATA1 | CN<br>STATA0 | 0000 | | 00A0 | CNNEA | 31:16 | _ | | I | 1 | I | 1 | I | _ | - | _ | I | _ | _ | _ | | | 0000 | | 0070 | CIVINEA | 15:0 | CNNEA15 | CNNEA14 | I | CNNEA12 | CNNEA11 | CNNEA10 | I | CNNEA8 | CNNEA7 | _ | I | CNNEA4 | _ | _ | CNNEA1 | CNNEA0 | 0000 | | 00B0 | CNFA | 31:16 | _ | _ | ı | 1 | 1 | | I | _ | _ | _ | | _ | _ | _ | _ | _ | 0000 | | ОДО | CIVIA | 15:0 | CNFA15 | CNFA14 | - | CNFA12 | CNFA11 | CNFA10 | - | CNFA8 | CNFA7 | _ | _ | CNFA4 | _ | _ | CNFA1 | CNFA0 | 0000 | | 00C0 | SRCON0A | 31:16 | _ | _ | - | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | SR0A10 | _ | SR0A8 | SR0A7 | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | ODOON() | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | סטטט | SRCON1A | 15:0 | _ | _ | _ | _ | _ | SR1A10 | _ | SR1A8 | SR1A7 | _ | _ | _ | _ | _ | _ | _ | 0000 | PIC32MK GPK/MCM with CAN FD Family **Legend:** x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PORTA REGISTER MAP FOR 64-PIN DEVICES ONLY **TABLE 13-4**: | ssə. | | Φ | | | | | | | | Bir | ts | | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|---------------|----------------|---------------|------|--------------|----------------|------|------|--------------|------|------|--------------|--------------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0000 | ANSELA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | ANGLLA | 15:0 | _ | _ | _ | ANSA12 | ANSA11 | _ | | ANSA8 | _ | _ | | ANSA4 | _ | _ | ANSA1 | ANSA0 | 0623 | | 0010 | TRISA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0010 | 11(10/1 | 15:0 | _ | _ | _ | TRISA12 | TRISA11 | TRISA10 | _ | TRISA8 | TRISA7 | _ | _ | TRISA4 | _ | _ | TRISA1 | TRISA0 | 06FF | | 0020 | PORTA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | 1 011171 | 15:0 | _ | _ | _ | RA12 | RA11 | RA10 | _ | RA8 | RA7 | _ | _ | RA4 | _ | _ | RA1 | RA0 | XXXX | | 0030 | LATA | 31:16 | | _ | | _ | _ | _ | | _ | _ | | | _ | | | | _ | 0000 | | | | 15:0 | | | | LATA12 | LATA11 | LATA10 | | LATA8 | LATA7 | | | LATA4 | | | LATA1 | LATA0 | XXXX | | 0040 | ODCA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | ODCA12 | ODCA11 | ODCA10 | _ | ODCA8 | ODCA7 | _ | _ | ODCA4 | _ | _ | ODCA1 | ODCA0 | 0000 | | 0050 | CNPUA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | 0000 | | | | 15:0 | _ | _ | _ | CNPUA12 | CNPUA11 | CNPUA10 | _ | CNPUA8 | CNPUA7 | _ | _ | CNPUA4 | _ | _ | CNPUA1 | CNPUA0 | 0000 | | 0060 | CNPDA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | 0000 | | | | 15:0 | _ | _ | _ | CNPDA12 | CNPDA11 | CNPDA10 | _ | CNPDA8 | CNPDA7 | _ | _ | CNPDA4 | _ | _ | CNPDA1 | CNPDA0 | 0000 | | 0070 | CNICONIA | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | 0000 | | 0070 | CNCONA | 15:0 | ON | _ | SIDL | _ | EDGE<br>DETECT | _ | - | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | 0080 | CNENA | 31:16 | _ | - | _ | _ | | - | - | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | 0000 | CINLINA | 15:0 | _ | _ | _ | CNIEA12 | CNIEA11 | CNIEA10 | _ | CNIEA8 | CNIEA7 | _ | _ | CNIEA4 | _ | _ | CNIEA1 | CNIEA0 | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | 0000 | | 0090 | CNSTATA | 15:0 | _ | - | I | CN<br>STATA12 | CN<br>STATA11 | CN<br>STATA10 | l | CN<br>STATA8 | CN<br>STATA7 | _ | l | CN<br>STATA4 | _ | l | CN<br>STATA1 | CN<br>STATA0 | 0000 | | 00A0 | CNNEA | 31:16 | _ | - | _ | _ | - | - | _ | _ | _ | | _ | _ | | _ | _ | _ | 0000 | | UUAU | CININEA | 15:0 | - | | 1 | CNNEA12 | CNNEA11 | CNNEA10 | ı | CNNEA8 | CNNEA7 | - | ı | CNNEA4 | - | 1 | CNNEA1 | CNNEA0 | 0000 | | 00B0 | CNFA | 31:16 | _ | I | - | _ | I | I | 1 | _ | _ | _ | 1 | _ | _ | 1 | _ | _ | 0000 | | 0000 | CNFA | 15:0 | _ | I | - | CNFA12 | CNFA11 | CNFA10 | 1 | CNFA8 | CNFA7 | _ | 1 | CNFA4 | _ | 1 | CNFA1 | CNFA0 | 0000 | | 00.00 | 000000 | 31:16 | | _ | | _ | _ | | | _ | _ | | | _ | _ | | _ | _ | 0000 | | 00C0 | SRCON0A | 15:0 | _ | _ | _ | _ | _ | SR0A10 | _ | SR0A8 | SR0A7 | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 00D0 | SRCON1A | 15:0 | _ | | | _ | | SR1A10 | | SR1A8 | SR1A7 | | | _ | | | _ | _ | 0000 | | | | | | | | | (a) D | | | | <i></i> ,,,,,, | | | | | | | | 1 | x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 13-5: PORTB REGISTER MAP FOR 64-PIN AND 100-PIN DEVICES | ess | | • | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|---------------|---------------|---------------|------------------|---------------|---------------|---------------|--------------|------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0100 | ANSELB | 31:16 | _ | | - | | | _ | _ | _ | - | _ | | _ | | _ | _ | | 0000 | | 0100 | ANOLLD | 15:0 | _ | _ | _ | _ | _ | _ | ANSB9 | _ | ANSB7 | _ | _ | _ | ANSB3 | ANSB2 | ANSB1 | ANSB0 | 008F | | 0110 | TRISB | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | TRISB15 | TRISB14 | TRISB13 | TRISB12 | TRISB11 | TRISB10 | TRISB9 | | TRISB7 | TRISB6 | TRISB5 | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0 | FFFF | | 0120 | PORTB | 31:16 | | _ | | | | | _ | | | | _ | | | | _ | | 0000 | | | | 15:0 | RB15 | RB14 | RB13 | RB12 | RB11 | RB10 | RB9 | RB8 | RB7 | RB6 | RB5 | RB4 | RB3 | RB2 | RB1 | RB0 | XXXX | | 0130 | LATB | 31:16 | | | | | | | | | | | | | - | | | - | 0000 | | | | 15:0 | LATB15 | LATB14 | LATB13 | LATB12 | LATB11 | LATB10 | LATB9 | | LATB7 | LATB6 | LATB5 | LATB4 | LATB3 | LATB2 | LATB1 | LATB0 | XXXX | | 0140 | ODCB | 31:16 | - | - | - | - | - | - | - | | | - | - | | - | - | - | - | 0000 | | | | 15:0 | ODCB15 | ODCB14 | ODCB13 | ODCB12 | ODCB11 | ODCB10 | ODCB9 | | ODCB7 | ODCB6 | ODCB5 | ODCB4 | ODCB3 | ODCB2 | ODCB1 | ODCB0 | 0000 | | 0150 | CNPUB | 31:16 | - CNPUB15 | - CNIDLIDAA | —<br>CNPUB13 | CNPUB12 | —<br>CNPUB11 | - CNIDLIDAO | - CNDUDO | | <br>CNPUB7 | - CNPUB6 | - CNIDLIDE | - CNDUDA | - CNIDLIDA | CNPUB2 | - CNIDLIDA | - CNDUDA | 0000 | | | | 15:0<br>31:16 | CNPUB15 | CNPUB14 | CNPUB13 | CNPUB12 | CNPUBIT | CNPUB10 | CNPUB9 | | CNPUB/ | CNPUB6 | CNPUB5 | CNPUB4 | CNPUB3 | CNPUBZ | CNPUB1 | CNPUB0 | 0000 | | 0160 | CNPDB | 15:0 | CNPDB15 | CNPDB14 | CNPDB13 | CNPDB12 | CNPDB11 | CNPDB10 | CNPDB9 | | CNPDB7 | CNPDB6 | CNPDB5 | CNPDB4 | CNPDB3 | CNPDB2 | CNPDB1 | CNPDB0 | 0000 | | | | 31:16 | — — | — CINFUB 14 | — | CINFUBIZ | — | — | — CINFDB9 | | CINFUBI | — | CINFUBS | CINFUD4 | CINFIDES | — | — | CINFUBU | 0000 | | 0170 | CNCONB | | _ | _ | | _ | EDGE | _ | _ | | | _ | _ | | | _ | _ | | 0000 | | 0170 | ONOOND | 15:0 | ON | _ | SIDL | _ | DETECT | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0180 | CNENB | 15:0 | CNIEB15 | CNIEB14 | CNIEB13 | CNIEB12 | CNIEB11 | CNIEB10 | CNIEB9 | _ | CNIEB7 | CNIEB6 | CNIEB5 | CNIEB4 | CNIEB3 | CNIEB2 | CNIEB1 | CNIEB0 | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0190 | CNSTATB | 15:0 | CN<br>STATB15 | CN<br>STATB14 | CN<br>STATB13 | CN<br>STATB12 | CN<br>STATB11 | CN<br>STATB10 | CN<br>STATB9 | _ | CN<br>STATB7 | CN<br>STATB6 | CN<br>STATB5 | CN<br>STATB4 | CN<br>STATB3 | CN<br>STATB2 | CN<br>STATB1 | CN<br>STATB0 | 0000 | | 0440 | ONNED | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 01A0 | CNNEB | 15:0 | CNNEB15 | CNNEB14 | CNNEB13 | CNNEB12 | CNNEB11 | CNNEB10 | CNNEB9 | _ | CNNEB7 | CNNEB6 | CNNEB5 | CNNEB4 | CNNEB3 | CNNEB2 | CNNEB1 | CNNEB0 | 0000 | | 0400 | CNFB | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 01B0 | CNFB | 15:0 | CNFB15 | CNFB14 | CNFB13 | CNFB12 | CNFB11 | CNFB10 | CNFB9 | _ | CNFB7 | CNFB6 | CNFB5 | CNFB4 | CNFB3 | CNFB2 | CNFB1 | CNFB0 | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 01C0 | SRCON0B | 15:0 | SR0B15 | SR0B14 | SR0B13 | SR0B12 | SR0B11 | SR0B10 | _ | _ | SR0B7 | SR0B6 | _ | SR0B4 | _ | _ | _ | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 01D0 | SRCON1B | 15:0 | SR1B15 | SR1B14 | SR1B13 | SR1B12 | SR1B11 | SR1B10 | _ | _ | SR1B7 | SR1B6 | | SR1B4 | | _ | _ | | 0000 | | | | 10.0 | | | Unine de la cons | SICIDIZ | - 101- D4 | 5111510 | | | 51(15) | 511150 | | JIKID# | | | | | | Legend: x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more Note 1: | τ | | |----------|-----| | Č | מ | | | 5 | | 9 | 2 | | 9 | 3 | | _ | | | <u>-</u> | , | | Ξ | ` | | Ø | Ē | | 10195 | Г | | | | | g | í | | چ | 200 | | a | ) | | ٨ | ٠ | | 0 | Í, | | C | 7 | | | | PORTC REGISTER MAP FOR 64-PIN AND 100-PIN DEVICES **TABLE 13-6:** | ess | | • | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|-----------|---------------|---------------|-------|---------------|----------------|---------------|--------------|--------------|--------------|--------------|------|------|------|--------------|--------------|--------------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0200 | ANSELC | 31:16 | _ | I | _ | - | _ | | 1 | | _ | _ | _ | _ | | _ | _ | - | 0000 | | 0200 | 7 W TOLLO | 15:0 | _ | _ | _ | ANSC12 | ANSC11 | ANSC10 | _ | _ | _ | _ | _ | _ | _ | ANSC2 | ANSC1 | ANSC0 | 1007 | | 0210 | TRISC | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | 0000 | | | | 15:0 | TRISC15 | TRISC14 | | TRISC12 | TRISC11 | TRISC10 | TRIS92 | TRISC8 | TRISC7 | TRISC6 | | _ | | TRISC2 | TRISC1 | TRISC0 | FFC7 | | 0220 | PORTC | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | _ | _ | _ | 0000 | | | | 15:0 | RC15 | RC14 | RC13 | RC12 | RC11 | RC10 | RC9 | RC8 | RC7 | RC6 | | _ | | RC2 | RC1 | RC0 | XXXX | | 0230 | LATC | 31:16 | _ | _ | | _ | _ | _ | _ | | _ | _ | _ | _ | | _ | _ | _ | 0000 | | | | 15:0 | LATC15 | LATC14 | | LATC12 | LATC11 | LATC10 | LATC9 | LATC8 | LATC7 | LATC6 | _ | _ | | LATC2 | LATC1 | LATC0 | XXXX | | 0240 | ODCC | 31:16 | | _ | _ | | _ | _ | | | | _ | _ | _ | _ | | | | 0000 | | | | 15:0 | ODCC15 | ODCC14 | | ODCC12 | ODCC11 | ODCC10 | ODCC9 | ODCC8 | ODCC7 | ODCC6 | _ | _ | _ | ODCC2 | ODCC1 | ODCC0 | 0000 | | 0250 | CNPUC | 31:16 | | | _ | | | | | | | | | | | | | | 0000 | | | | 15:0 | CNPUC15 | CNPUC14 | _ | CNPUC12 | CNPUC11 | CNPUC10 | CNPUC9 | CNPUC8 | CNPUC7 | CNPUC6 | | | | CNPUC2 | CNPUC1 | CNPUC0 | 0000 | | 0260 | CNPDC | 31:16 | - | | _ | - | - | - | | | | - | | | | | | — | 0000 | | | | 15:0 | CNPDC15 | CNPDC14 | | CNPDC12 | CNPDC11 | CNPDC10 | CNPDC9 | CNPDC8 | CNPDC7 | CNPDC6 | | | | CNPDC2 | CNPDC1 | CNPDC0 | 0000 | | 0270 | CNCONC | 31:16 | _ | | _ | | - | | | | | _ | | | | _ | | | 0000 | | 0270 | CINCOINC | 15:0 | ON | _ | SIDL | _ | EDGE<br>DETECT | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0280 | CNENC | 31:16 | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | ONLINO | 15:0 | CNIEC15 | CNIEC14 | _ | CNIEC12 | CNIEC11 | CNIEC10 | CNIEC9 | CNIEC8 | CNIEC7 | CNIEC7 | _ | _ | _ | CNIEC2 | CNIEC1 | CNIEC0 | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0290 | CNSTATC | 15:0 | CN<br>STATC15 | CN<br>STATC14 | _ | CN<br>STATC12 | CN<br>STATC11 | CN<br>STATC10 | CN<br>STATC9 | CN<br>STATC8 | CN<br>STATC7 | CN<br>STATC6 | _ | _ | 1 | CN<br>STATC2 | CN<br>STATC1 | CN<br>STATC0 | 0000 | | 02A0 | CNNEC | 31:16 | _ | I | _ | I | _ | 1 | 1 | 1 | _ | _ | _ | - | 1 | _ | _ | 1 | 0000 | | 02A0 | CININEC | 15:0 | CNNEC15 | CNNEC14 | _ | CNNEC12 | CNNEC11 | CNNEC10 | CNNEC9 | CNNEC8 | CNNEC7 | CNNEC6 | _ | - | 1 | CNNEC2 | CNNEC1 | CNNEC0 | 0000 | | 02B0 | CNFC | 31:16 | _ | - | _ | _ | _ | _ | - | - | _ | _ | _ | _ | | _ | _ | - | 0000 | | 0200 | CIVIC | 15:0 | CNFC15 | CNFC14 | _ | CNFC12 | CNFC11 | CNFC10 | CNFC9 | CNFC8 | CNFC7 | CNFC6 | _ | _ | _ | CNFC2 | CNFC1 | CNFC0 | 0000 | | 0000 | SRCON0C | 31:16 | _ | I | _ | ı | _ | 1 | _ | 1 | _ | _ | _ | _ | _ | _ | _ | - | 0000 | | 0200 | OKCONOC | 15:0 | SR0C15 | I | _ | 1 | SR0C11 | 1 | SR0C9 | SR0C8 | SR0C7 | SR0C6 | _ | _ | 1 | _ | _ | 1 | 0000 | | 0000 | 0000110 | 31:16 | _ | | _ | _ | _ | | _ | - | _ | _ | _ | _ | | _ | _ | _ | 0000 | | 02D0 | SRCON1C | 15:0 | SR1C15 | 1 | _ | - | SR1C11 | _ | SR1C9 | SR1C8 | SR1C7 | SR1C6 | _ | _ | _ | _ | _ | _ | 0000 | | 1 | | Linkson | um valua an l | | | ad raad as ' | | | um in hove | | | | | | | | | | | x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more infor-Note 1: mation. PORTD REGISTER MAP FOR 100-PIN DEVICES ONLY **TABLE 13-7:** | ess | | • | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|---------------|---------------|---------------|---------------|---------------|----------------|-------|------|-----------------------------|------|--------------|--------------|--------------|--------------|--------------|--------------|------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0300 | ANSELD | 31:16 | _ | _ | | 1 | _ | - | _ | _ | _ | _ | _ | - | - | _ | _ | _ | 0000 | | 0000 | / 110222 | 15:0 | ANSD15 | ANSD14 | _ | | _ | _ | _ | _ | | | _ | | _ | | _ | | C000 | | 0310 | TRISD | 31:16 | | | | | _ | | _ | — (2) | | | _ | | | | | | 0000 | | | | 15:0 | TRISD15 | TRISD14 | TRISD13 | TRISD12 | _ | _ | _ | TRISD8 <sup>(2)</sup> | | TRISD6 | TRISD5 | TRISD4 | TRISD3 | TRISD2 | TRISD1 | | F1FE | | 0320 | PORTD | 31:16 | | | | | _ | _ | _ | —<br>====(2) | | | | | | | | | 0000 | | | | 15:0 | RD15 | RD14 | RD13 | RD12 | | | | RD8 <sup>(2)</sup> | | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | | XXXX | | 0330 | LATD | 31:16 | | | —<br>- | — | | | | — (2) | | - | - | | | - | | | 0000 | | | | 15:0 | LATD15 | LATD14 | LATD13 | LATD12 | | | | LATD8 <sup>(2)</sup> | | LATD6 | LATD5 | LATD4 | LATD3 | LATD2 | LATD1 | | XXXX | | 0340 | ODCD | 31:16 | - | —<br>— | —<br>— | —<br>— | | | | —<br>ODODO(2) | | - | | | | | - | | 0000 | | - | | 15:0 | ODCD15 | ODCD14 | ODCD13 | ODCD12 | | | | ODCD8 <sup>(2)</sup> | | ODCD6 | ODCD5 | ODCD4 | ODCD3 | ODCD2 | ODCD1 | _ | 0000 | | 0350 | CNPUD | 31:16<br>15:0 | CNPUD15 | CNPUD14 | —<br>CNPUD13 | —<br>CNPUD12 | _ | _ | _ | CNPUD8 <sup>(2)</sup> | | CNPUD6 | CNPUD5 | - CNPUD4 | CNPUD3 | CNPUD2 | CNPUD1 | | 0000 | | | | 31:16 | CNPUD15 | CNPUD14 | CNPUD13 | CNPUD12 | _ | | | CNPUD8'- | | CNPUD6 | CNPUD5 | CNPUD4 | CNPUD3 | CNPUD2 | CNPUDT | | 0000 | | 0360 | CNPDD | 15:0 | CNPDD15 | CNPDD14 | CNPDD13 | CNPDD12 | | | | CNPDD8 <sup>(2)</sup> | | CNPDD6 | CNPDD5 | CNPDD4 | CNPDD3 | CNPDD2 | CNPDD1 | | 0000 | | | | 31:16 | | — CNPDD 14 | — | | | | | — CINFDD6: 7 | | - CNPDD0 | CINFUUS | CINFDD4 | CINFUUS | CNPDD2 | — | | 0000 | | 0370 | CNCOND | 15:0 | ON | _ | SIDL | | EDGE<br>DETECT | | _ | _ | | _ | | | | _ | _ | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | | _ | | | _ | | | | _ | | 0000 | | 0380 | CNEND | 15:0 | CNIED15 | CNIED14 | CNIED13 | CNIED12 | _ | | _ | CNIED8 <sup>(2)</sup> | | CNIED6 | CNIED5 | CNIED4 | CNIED3 | CNIED2 | CNIED1 | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | _ | _ | _ | _ | | 0000 | | 0390 | CNSTATD | 15:0 | CNS<br>TATD15 | CN<br>STATD14 | CN<br>STATD13 | CN<br>STATD12 | _ | _ | _ | CN<br>STATD8 <sup>(2)</sup> | _ | CN<br>STATD6 | CN<br>STATD5 | CN<br>STATD4 | CN<br>STATD3 | CN<br>STATD2 | CN<br>STATD1 | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | _ | _ | _ | _ | | 0000 | | 03A0 | CNNED | 15:0 | CNNED15 | CNNED14 | CNNED13 | CNNED12 | _ | | _ | CNNED8 <sup>(2)</sup> | | CNNED6 | CNNED5 | CNNED4 | CNNED3 | CNNED2 | CNNED1 | | 0000 | | | | 31:16 | _ | _ | | | _ | | _ | _ | | _ | _ | | | _ | _ | | 0000 | | 03B0 | CNFD | 15:0 | CNFD15 | CNFD14 | CNFD13 | CNFD12 | _ | | _ | CNFD8 <sup>(2)</sup> | _ | CNFD6 | CNFD5 | CNFD4 | CNFD3 | CNFD2 | CNFD1 | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 03C0 | SRCON0D | 15:0 | _ | _ | _ | _ | _ | _ | _ | SR0D8 <sup>(2)</sup> | _ | SR0D6 | SR0D5 | SR0D4 | SR0D3 | SR0D2 | SR0D1 | _ | 0000 | | | | 31:16 | _ | | | | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 03D0 | SRCON1D | 15:0 | _ | | ı | 1 | _ | 1 | _ | SR1D8 <sup>(2)</sup> | _ | SR1D6 | SR1D5 | SR1D4 | SR1D3 | SR1D2 | SR1D1 | _ | 0000 | Legend: x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more infor-Note 1: This bit is not available on general purpose devices. | Ö | |---------------| | ര് | | Õ | | 0 | | 0 | | $\rightarrow$ | | $^{\circ}$ | | $\rightarrow$ | | 9 | | Ш | | | | $\approx$ | | Œ. | | ñ | | Œ | | N | | Ö | | Ñ | | • | | | PORTD REGISTER MAP FOR 64-PIN DEVICES ONLY **TABLE 13-8:** | ess | | | | | | | | | | Bit | s | | | | | | | | | |-----------------------------|---------------------------------|---------------|-------|-------|-------|-------|----------------|-------|------|-----------------------------|------|--------------|--------------|------|------|------|------|------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0310 | TRISD | 31:16<br>15:0 | | | _ | _ | - | | _ | TRISD8 <sup>(2)</sup> | _ | TRISD6 | —<br>TRISD5 | | | _ | _ | | 0000 | | | | 31:16 | | | | | | | | — | | — | — | | | | | | 0000 | | 0320 | PORTD | 15:0 | _ | _ | _ | _ | _ | _ | _ | RD8 <sup>(2)</sup> | | RD6 | RD5 | _ | _ | _ | _ | _ | xxxx | | 0000 | LATD | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0330 | LATD | 15:0 | _ | | _ | _ | _ | - | _ | LATD8 <sup>(2)</sup> | _ | LATD6 | LATD5 | - | | _ | _ | _ | xxxx | | 0340 | ODCD | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0040 | 000 | 15:0 | _ | | _ | _ | _ | - | _ | ODCD8 <sup>(2)</sup> | _ | ODCD6 | ODCD5 | _ | | _ | _ | _ | 0000 | | 0350 | CNPUD | 31:16 | _ | _ | | _ | _ | _ | _ | — | | _ | _ | _ | _ | _ | | _ | 0000 | | | | 15:0 | _ | _ | | _ | _ | _ | _ | CNPUD8 <sup>(2)</sup> | | CNPUD6 | CNPUD5 | _ | _ | _ | _ | | 0000 | | 0360 | CNPDD | 31:16 | | _ | | _ | _ | | _ | — (2) | | - | - | _ | _ | _ | | | 0000 | | | | 15:0<br>31:16 | | _ | | _ | _ | _ | _ | CNPDD8 <sup>(2)</sup> | | CNPDD6 | CNPDD5 | | _ | | _ | _ | 0000 | | 0370 | CNCOND | 15:0 | ON | _ | SIDL | _ | EDGE<br>DETECT | | _ | _ | | _ | _ | _ | _ | | _ | | 0000 | | | | 31:16 | _ | | _ | _ | _ | | _ | _ | | _ | _ | _ | | _ | _ | _ | 0000 | | 0380 | CNEND | 15:0 | _ | _ | _ | _ | _ | _ | _ | CNIED8 <sup>(2)</sup> | _ | CNIED6 | CNIED5 | _ | _ | _ | _ | _ | 0000 | | | | 31:16 | _ | - | _ | _ | _ | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | 0000 | | 0390 | CNSTATD | 15:0 | - | ı | _ | _ | - | ı | _ | CN<br>STATD8 <sup>(2)</sup> | _ | CN<br>STATD6 | CN<br>STATD5 | 1 | | _ | _ | ı | 0000 | | 03A0 | CNNED | 31:16 | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | USAU | CIVINED | 15:0 | _ | _ | | _ | _ | _ | _ | CNNED8 <sup>(2)</sup> | _ | CNNED6 | CNNED5 | _ | _ | _ | _ | _ | 0000 | | 03B0 | CNFD | 31:16 | _ | _ | | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | | 0000 | | | | 15:0 | _ | _ | | _ | _ | | _ | CNFD8 <sup>(2)</sup> | | CNFD6 | CNFD5 | _ | _ | _ | _ | | 0000 | | 0300 | SRCON0D | 31:16 | _ | _ | | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | CINCONOD | 15:0 | _ | _ | _ | _ | _ | _ | _ | SR0D8 <sup>(2)</sup> | _ | SR0D6 | SR0D5 | _ | _ | _ | _ | _ | 0000 | | 0000 | CDCONAD | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | U3D0 | SRCON1D | 15:0 | _ | _ | _ | _ | _ | 1 | _ | SR1D8 <sup>(2)</sup> | _ | SR1D6 | SR1D5 | _ | | _ | _ | | 0000 | Legend: x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more Note 1: This bit is not available on general purpose devices. PORTE REGISTER MAP FOR 100-PIN DEVICES ONLY **TABLE 13-9:** | sse | | • | | | | | | | | В | its | | | | | | | | | |-----------------------------|-----------------------------------------|-----------|---------------|---------------|---------------|---------------|----------------|-------|--------------|--------------|------|------|------|------|------|------|--------------|--------------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0400 | ANSELE | 31:16 | | | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0100 | AUTOLLE | 15:0 | ANSE15 | ANSE14 | ANSE13 | ANSE12 | _ | | ANSE9 | ANSE8 | _ | _ | | _ | _ | _ | ANSE1 | ANSE0 | F303 | | 0410 | TRISE | 31:16 | | _ | _ | _ | _ | | _ | _ | _ | _ | | _ | _ | _ | _ | _ | 0000 | | 0110 | THIOL | 15:0 | TRISE15 | TRISE14 | TRISE13 | TRISE12 | _ | | TRISE9 | TRISE8 | _ | _ | | _ | _ | _ | TRISE1 | TRISE0 | F303 | | 0420 | PORTE | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0120 | TOTAL | 15:0 | RE15 | RE14 | RE13 | RE12 | _ | | RE9 | RE8 | _ | _ | | _ | _ | _ | RE1 | RE0 | XXXX | | 0440 | LATE | 31:16 | I | - | _ | _ | _ | - | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | 0.10 | | 15:0 | LATE15 | LATE14 | LATE13 | LATE12 | _ | - | LATE9 | LATE8 | _ | _ | - | _ | _ | _ | LATE1 | LATE0 | XXXX | | 0440 | ODCE | 31:16 | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | | _ | _ | _ | _ | 0000 | | | | 15:0 | ODCE15 | ODCE14 | ODCE13 | ODCE12 | | | ODCE9 | ODCE8 | | _ | | | | _ | ODCE1 | ODCE0 | 0000 | | 0450 | CNPUE | 31:16 | _ | - | _ | _ | | | _ | _ | | _ | | | | _ | _ | _ | 0000 | | | | 15:0 | CNPUE15 | CNPUE14 | CNPUE13 | CNPUE12 | | | CNPUE9 | CNPUE8 | | _ | | | | _ | CNPUE1 | CNPUE0 | 0000 | | 0460 | CNPDE | 31:16 | _ | - | _ | _ | | | _ | _ | | _ | | | | _ | | _ | 0000 | | | • • • • • • • • • • • • • • • • • • • • | 15:0 | CNPDE15 | CNPDE14 | CNPDE13 | CNPDE12 | | | CNPDE9 | CNPDE8 | | _ | | | | _ | CNPDE1 | CNPDE0 | 0000 | | 0.470 | 0110011 | 31:16 | | | _ | _ | _ | | _ | _ | | _ | | | | _ | | _ | 0000 | | 0470 | CNCONE | 15:0 | ON | _ | SIDL | _ | EDGE<br>DETECT | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0480 | CNENE | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | 0000 | | 0400 | CIVEINE | 15:0 | _ | _ | _ | _ | _ | _ | CNIEE9 | CNIEE8 | | _ | | _ | _ | _ | CNIEE1 | CNIEE0 | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | 0000 | | 0490 | CNSTATE | 15:0 | CN<br>STATE15 | CN<br>STATE14 | CN<br>STATE13 | CN<br>STATE12 | - | 1 | CN<br>STATE9 | CN<br>STATE8 | _ | _ | 1 | 1 | 1 | _ | CN<br>STATE1 | CN<br>STATE0 | 0000 | | 04A0 | CNNEE | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 04/40 | CIVINEL | 15:0 | CNNEE15 | CNNEE14 | CNNEE13 | CNNEE12 | _ | _ | CNNEE9 | CNNEE8 | _ | _ | _ | _ | _ | _ | CNNEE1 | CNNEE0 | 0000 | | 04B0 | CNFE | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | CNFE15 | CNFE14 | CNFE13 | CNFE12 | _ | | CNFE9 | CNFE8 | _ | _ | _ | _ | _ | _ | CNFE1 | CNFE0 | 0000 | | 04C0 | SRCON0E | 31:16 | _ | - | _ | _ | _ | | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | SR0E15 | SR0E14 | SR0E13 | SR0E12 | _ | | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | 04D0 | SRCON1E | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | SR1E15 | SR1E14 | SR1E13 | SR1E12 | _ | I | _ | _ | - | _ | ı | - | - | _ | _ | _ | 0000 | x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. Note 1: TABLE 13-10: PORTE REGISTER MAP FOR 64-PIN DEVICES ONLY | ess | | • | | | | | | | | Е | Bits | | | | | | | | | |-----------------------------|---------------------------------|-----------|---------------|---------------|---------------|---------------|----------------|-------|------|------|------|------|------|------|------|------|------|------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0400 | ANSELE | 31:16 | _ | _ | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | ANSE15 | ANSE14 | ANSE13 | ANSE12 | _ | | | _ | | _ | _ | _ | | _ | | _ | F000 | | 0410 | TRISE | 31:16 | | _ | _ | _ | _ | | | | | _ | _ | | | _ | _ | | 0000 | | | | 15:0 | TRISE15 | TRISE14 | TRISE13 | TRISE12 | _ | | | _ | | _ | _ | _ | | _ | | _ | F000 | | 0420 | PORTE | 31:16 | _ | _ | _ | _ | _ | | | _ | | _ | _ | _ | | _ | | _ | 0000 | | | | 15:0 | RE15 | RE14 | RE13 | RE12 | _ | | | _ | | _ | _ | _ | | _ | | _ | XXXX | | 0440 | LATE | 31:16 | _ | _ | _ | _ | _ | | | _ | | _ | _ | _ | | _ | _ | _ | 0000 | | | | 15:0 | LATE15 | LATE14 | LATE13 | LATE12 | _ | | | _ | | _ | _ | _ | | _ | _ | _ | XXXX | | 0440 | ODCE | 31:16 | | _ | _ | _ | _ | | | | | _ | _ | | | _ | _ | | 0000 | | | | 15:0 | ODCE15 | ODCE14 | ODCE13 | ODCE12 | _ | | | _ | | _ | _ | _ | | _ | | _ | 0000 | | 0450 | CNPUE | 31:16 | _ | _ | _ | _ | _ | | | _ | | _ | _ | _ | | _ | | _ | 0000 | | | | 15:0 | CNPUE15 | CNPUE14 | CNPUE13 | CNPUE12 | _ | | | _ | | _ | _ | _ | | _ | | _ | 0000 | | 0460 | CNPDE | 31:16 | _ | _ | _ | _ | _ | | | _ | | _ | _ | _ | | _ | | _ | 0000 | | | | 15:0 | CNPDE15 | CNPDE14 | CNPDE13 | CNPDE12 | _ | | | _ | | _ | _ | _ | | _ | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | | | _ | | _ | _ | _ | | _ | | _ | 0000 | | 0470 | CNCONE | 15:0 | ON | _ | SIDL | _ | EDGE<br>DETECT | 1 | - | _ | - | _ | _ | _ | - | _ | _ | _ | 0000 | | 0480 | CNENE | 31:16 | - | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0400 | CINLINL | 15:0 | - | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 31:16 | - | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0490 | CNSTATE | 15:0 | CN<br>STATE15 | CN<br>STATE14 | CN<br>STATE13 | CN<br>STATE12 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0440 | CNNEE | 31:16 | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 04A0 | CININEE | 15:0 | CNNEE15 | CNNEE14 | CNNEE13 | CNNEE12 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 04B0 | CNFE | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | U4DU | CINFE | 15:0 | CNFE15 | CNFE14 | CNFE13 | CNFE12 | _ | _ | | _ | | _ | _ | _ | 1 | _ | _ | _ | 0000 | | 04C0 | SRCON0E | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | SR0E15 | SR0E14 | SR0E13 | SR0E12 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 04D0 | SRCON1E | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | SR1E15 | SR1E14 | SR1E13 | SR1E12 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 13-11: PORTF REGISTER MAP FOR 100-PIN DEVICES ONLY | sse | | | | | | | | | | Bi | ts | | | | | | | | | |-----------------------------|---------------------------------|---------------|-------|-------|---------------|---------------|----------------|---------------|--------------|------|--------------|--------------|--------------|------|------|------|--------------|--------------|------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All | | 0500 | ANSELF | 31:16 | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | | ANSF13 | ANSF12 | | ANSF10 | ANSF9 | | _ | _ | ANSF5 | | | | _ | _ | 3620 | | 0510 | TRISF | 31:16 | _ | | | _ | _ | | | | | | | | _ | _ | | | 0000 | | | | 15:0 | _ | _ | TRISF13 | TRISF12 | _ | TRISF10 | TRISF9 | _ | TRISF7 | TRISF6 | TRISF5 | | _ | _ | TRISF1 | TRISF0 | 36E3 | | 0520 | PORTF | 31:16 | _ | _ | | | _ | | | _ | _ | _ | | | _ | _ | | | 0000 | | | | 15:0 | | | RF13 | RF12 | | RF10 | RF9 | | RF7 | RF6 | RF5 | | | | RF1 | RF0 | XXXX | | 0530 | LATF | 31:16 | | | | - | | - | - | | | - | | | | | | | 0000 | | | | 15:0 | | | LATF13 | LATF12 | | LATF10 | LATF9 | | LATF7 | LATF6 | LATF5 | | | | LATF1 | LATF0 | XXXX | | 0540 | ODCF | 31:16 | | | - | - | | —<br>ODOF40 | - | | - | - | - | | | | | - | 0000 | | | | 15:0 | _ | | ODCF13 | ODCF12 | | ODCF10 | ODCF9 | | ODCF7 | ODCF6 | ODCF5 | | | | ODCF1 | ODCF0 | 0000 | | 0550 | CNPUF | 31:16 | _ | | CNPUF13 | CNPUF12 | | CNPUF10 | CNPUF9 | | CNPUF7 | CNPUF6 | CNPUF5 | | _ | | CNPUF1 | CNPUF0 | 0000 | | | | 15:0<br>31:16 | | | CNPUF 13 | CNPUF 12 | | CNPUFIU | CNPUF9 | | CNPUF7 | CNPUF6 | CNPUF5 | | | | CNPUF I | CNPUFU | 0000 | | 0560 | CNPDF | 15:0 | | | CNPDF13 | CNPDF12 | | CNPDF10 | CNPDF9 | | CNPDF7 | CNPDF6 | CNPDF5 | | | | CNPDF1 | CNPDF0 | 0000 | | | | 31:16 | | | — | — — | | — | — | | — | — | — | | | | — | — | 0000 | | 0570 | | 15:0 | ON | | SIDL | _ | EDGE<br>DETECT | _ | _ | | _ | _ | _ | | _ | | _ | _ | 0000 | | | | 31:16 | _ | | _ | _ | _ | _ | _ | | | _ | _ | | _ | | | _ | 0000 | | 0580 | CNENF | 15:0 | _ | _ | CNIEF13 | CNIEF12 | _ | CNIEF10 | CNIEF9 | _ | CNIEF7 | CNIEF6 | CNIEF5 | | _ | _ | CNIEF1 | CNIEF0 | 0000 | | | | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0590 | CNSTATF | 15:0 | _ | _ | CN<br>STATF13 | CN<br>STATF12 | _ | CN<br>STATF10 | CN<br>STATF9 | _ | CN<br>STATF7 | CN<br>STATF6 | CN<br>STATF5 | _ | _ | _ | CN<br>STATF1 | CN<br>STATF0 | 0000 | | 0540 | 0111155 | 31:16 | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 05A0 | CNNEF | 15:0 | _ | _ | CNNEF13 | CNNEF12 | _ | CNNEF10 | CNNEF9 | _ | CNNEE7 | CNNEF6 | CNNEF5 | _ | _ | _ | CNNEF1 | CNNEF0 | 0000 | | ٥٥٥٥ | ONEE | 31:16 | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 05B0 | CNFF | 15:0 | _ | _ | CNFF13 | CNFF12 | | CNFF10 | CNFF9 | _ | CNFE7 | CNFF6 | CNFF5 | _ | _ | _ | CNFF1 | CNFF0 | 0000 | | 05C0 | SRCON0F | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | 1 | 1 | _ | _ | _ | _ | _ | _ | 1 | | SR0F1 | SR0F0 | 0000 | | 05D0 | SRCON1F | 31:16 | _ | _ | _ | _ | 1 | 1 | | _ | _ | _ | _ | _ | 1 | | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | I | - | _ | _ | _ | _ | _ | _ | - | | SR1F1 | SR1F0 | 0000 | x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. Note 1: | _ | | |--------|---| | LOODAC | ֡ | | ĕ | ֡ | | $\leq$ | ֡ | | 0 | | | 9 | | | 꾸 | | | Oa | | | ğ | | | | | ### TABLE 13-12: PORTF REGISTER MAP FOR 64-PIN DEVICES ONLY | sse | | | | | | | | | | Bi | ts | | | | | | | | | |-----------------------------|---------------------------------|---------------|-------|-------|-------|-------|----------------|-------|------------------|-------------|------|------|------|------|------|------|--------------|--------------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0510 | TRISF | 31:16 | _ | _ | _ | _ | _ | _ | | | | _ | | _ | _ | _ | | | 0000 | | | | 15:0<br>31:16 | _ | | _ | _ | | | | | | | | _ | _ | | TRISF1 | TRISF0 | 0003 | | 0520 | PORTF | 15:0 | | | | _ | | | | | | | _ | | | | RF1 | RF0 | xxxx | | | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0530 | LATF | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | LATF1 | LATF0 | XXXX | | 05.40 | 0005 | 31:16 | _ | | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0540 | ODCF | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ODCF1 | ODCF0 | 0000 | | 0550 | CNPUF | 31:16 | _ | ı | _ | _ | _ | _ | ı | ı | ı | | _ | _ | _ | | _ | _ | 0000 | | 0550 | CINFUL | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | CNPUF1 | CNPUF0 | 0000 | | 0560 | CNPDF | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | OI II DI | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CNPDF1 | CNPDF0 | 0000 | | | 01100115 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | | _ | _ | 0000 | | 0570 | CNCONF | 15:0 | ON | _ | SIDL | _ | EDGE<br>DETECT | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0580 | CNENF | 31:16 | _ | | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0360 | CINEINF | 15:0 | _ | - | _ | _ | _ | - | - | | - | _ | _ | _ | _ | _ | CNIEF1 | CNIEF0 | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0590 | CNSTATF | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CN<br>STATF1 | CN<br>STATF0 | 0000 | | 05A0 | CNNEF | 31:16 | _ | - | _ | _ | _ | _ | - | _ | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | UJAU | CIVINLI | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CNNEF1 | CNNEF0 | 0000 | | 05B0 | CNFF | 31:16 | _ | - | _ | _ | _ | _ | - | - | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | | CNFF1 | CNFF0 | 0000 | | 05C0 | SRCON0F | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | _ | | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | | _ | | _ | | _ | | _ | SR0F1 | SR0F0 | 0000 | | 05D0 | SRCON1F | - | | | _ | _ | _ | _ | _ | _ | | | | _ | | | - | - | 0000 | | Lame | | 15:0 | —<br> | — | | | — — | — | —<br>re cheum in | — havadasin | _ | _ | _ | _ | _ | _ | SR1F1 | SR1F0 | 0000 | PIC32MK GPK/MCM with CAN FD Family x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 13-13: PORTG REGISTER MAP FOR 100-PIN DEVICES ONLY | ess | | è | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|-----------|---------------|---------------|---------------|---------------|----------------|---------------|--------------|--------------|--------------|--------------|------|------|------|------|--------------|--------------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0600 | ANSELG | 31:16 | _ | _ | _ | _ | | _ | - | _ | - | _ | _ | _ | _ | | _ | | 0000 | | 0000 | | 15:0 | ANSG15 | _ | _ | _ | ANSG11 | ANSG10 | ANSG9 | ANSG8 | ANSG7 | ANSG6 | _ | _ | _ | _ | _ | _ | 8FC0 | | 0610 | TRISG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | | 0000 | | 0010 | _ | 15:0 | TRISG15 | TRISG14 | TRISG13 | TRISG12 | TRISG11 | TRISG10 | TRISG9 | TRISG8 | TRISG7 | TRISG6 | _ | _ | _ | _ | TRISG1 | TRISG0 | FFC3 | | 0620 | PORTG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | | 0000 | | 0020 | | 15:0 | RG15 | RG14 | RG13 | RG12 | RG11 | RG10 | RG9 | RG8 | RG7 | RG6 | _ | _ | _ | _ | RG1 | RG0 | XXXX | | 0630 | LATG | 31:16 | _ | _ | _ | _ | - | _ | - | _ | 1 | _ | _ | _ | _ | - | _ | - | 0000 | | | | 15:0 | LATG15 | LATG14 | LATG13 | LATG12 | LATG11 | LATG10 | LATG9 | LATG8 | LATG7 | LATG6 | _ | | | | LATG1 | LATG0 | XXXX | | 0640 | ODCG | 31:16 | _ | | _ | _ | - | _ | _ | _ | _ | _ | _ | | | | _ | | 0000 | | | | 15:0 | ODCG15 | ODCG14 | ODCG13 | ODCG12 | ODCG11 | ODCG10 | ODCG9 | ODCG8 | ODCG7 | ODCG6 | _ | _ | _ | | ODCG1 | ODCG0 | 0000 | | 0650 | CNPUG | 31:16 | | | | | | _ | _ | | _ | _ | _ | _ | _ | _ | | | 0000 | | | | 15:0 | CNPUG15 | CNPUG14 | CNPUG13 | CNPUG12 | CNPUG11 | CNPUG10 | CNPUG9 | CNPUG8 | CNPUG7 | CNPUG6 | _ | _ | _ | _ | CNPUG1 | CNPUG0 | 0000 | | 0660 | CNPDG | 31:16 | | | | | | | _ | | | | _ | _ | _ | _ | | _ | 0000 | | | | 15:0 | CNPDG15 | CNPDG14 | CNPDG13 | CNPDG12 | CNPDG11 | CNPDG10 | CNPDG9 | CNPDG8 | CNPDG7 | CNPDG6 | | | | | CNPDG1 | CNPDG0 | 0000 | | 0070 | L | 31:16 | _ | | _ | | | | | | | | | | | | | | 0000 | | 0670 | CNCONG | 15:0 | ON | - | SIDL | - | EDGE<br>DETECT | - | - | _ | 1 | _ | _ | _ | _ | I | _ | I | 0000 | | 0680 | CNENG | 31:16 | | - | _ | | ı | _ | | | I | _ | _ | | | I | _ | I | 0000 | | 0000 | CINEING | 15:0 | CNIEG15 | CNIEG14 | CNIEG13 | CNIEG12 | CNIEG11 | CNIEG10 | CNIEG9 | CNIEG8 | CNIEG7 | CNIEG6 | _ | | _ | I | CNIEG1 | CNIEG0 | 0000 | | | L | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | - | 0000 | | 0690 | CNSTATG | 15:0 | CN<br>STATG15 | CN<br>STATG14 | CN<br>STATG13 | CN<br>STATG12 | CN<br>STATG11 | CN<br>STATG10 | CN<br>STATG9 | CN<br>STATG8 | CN<br>STATG7 | CN<br>STATG6 | _ | _ | _ | _ | CN<br>STATG1 | CN<br>STATG0 | 0000 | | 06A0 | CNNEG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | | 0000 | | UBAU | CININEG | 15:0 | CNNEG15 | CNNEG14 | CNNEG13 | CNNEG12 | CNNEG11 | CNNEG10 | CNNEG9 | CNNEG8 | CNNEG7 | CNNEG6 | _ | _ | _ | _ | CNNEG1 | CNNEG0 | 0000 | | 06B0 | CNFG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | | 0000 | | 0080 | UNFG | 15:0 | CNFG15 | CNFG14 | CNFG13 | CNFG12 | CNFG11 | CNFG10 | CNFG9 | CNFG8 | CNFG7 | CNFG6 | _ | _ | _ | I | CNFG1 | CNFG0 | 0000 | Legend: x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 13-14: PORTG REGISTER MAP FOR 64-PIN DEVICES ONLY | ess | | | | | | | | | | Bits | ; | | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|----------------|-------|--------------|--------------|--------------|--------------|------|------|------|------|------|------|---------------| | Virtual Address<br>(BF86_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All<br>Resets | | 0600 | ANSELG | 31:16 | _ | | | | _ | _ | _ | _ | - | _ | | _ | _ | _ | _ | _ | 0000 | | 0000 | | 15:0 | | | | | _ | | ANSG9 | ANSG8 | ANSG7 | ANSG6 | | | _ | _ | _ | _ | 03C0 | | 0610 | TRISG | 31:16 | _ | _ | | | _ | | _ | _ | | _ | | | | | | _ | 0000 | | | | 15:0 | _ | _ | | | _ | | TRISG9 | TRISG8 | TRISG7 | TRISG6 | | | | | | _ | 03C0 | | 0620 | PORTG | 31:16 | _ | _ | | | _ | | _ | _ | | _ | | | | | | _ | 0000 | | | | 15:0 | _ | _ | | | _ | | RG9 | RG8 | RG7 | RG6 | | | | | | _ | xxxx | | 0630 | LATG | 31:16 | _ | _ | | | _ | | _ | _ | | _ | | | | | | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | | LATG9 | LATG8 | LATG7 | LATG6 | | | _ | | | _ | XXXX | | 0640 | ODCG | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | | _ | | | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | | ODCG9 | ODCG8 | ODCG7 | ODCG6 | | | _ | | | _ | 0000 | | 0650 | CNPUG | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | | _ | | | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | | CNPUG9 | CNPUG8 | CNPUG7 | CNPUG6 | | | _ | | | _ | 0000 | | 0660 | CNPDG | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | | _ | | | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | | CNPDG9 | CNPDG8 | CNPDG7 | CNPDG6 | | | _ | | | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | | _ | | | _ | 0000 | | 0670 | CNCONG | 15:0 | ON | _ | SIDL | ı | EDGE<br>DETECT | - | _ | _ | ı | _ | ı | ı | _ | _ | _ | _ | 0000 | | 0680 | CNENG | 31:16 | | _ | 1 | 1 | _ | _ | _ | _ | | _ | I | | _ | _ | | _ | 0000 | | 0000 | CINEING | 15:0 | | _ | 1 | 1 | _ | _ | CNIEG9 | CNIEG8 | CNIEG7 | CNIEG6 | I | | _ | _ | | _ | 0000 | | | | 31:16 | | _ | 1 | 1 | _ | _ | _ | _ | | _ | I | | _ | _ | | _ | 0000 | | 0690 | CNSTATG | 15:0 | - | 1 | 1 | 1 | - | _ | CN<br>STATG9 | CN<br>STATG8 | CN<br>STATG7 | CN<br>STATG6 | _ | _ | _ | _ | _ | _ | 0000 | | 0040 | ONNEC | 31:16 | _ | _ | | | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | 0000 | | 06A0 | CNNEG | 15:0 | _ | _ | | | _ | _ | CNNEG9 | CNNEG8 | CNNEG7 | CNNEG6 | _ | _ | _ | _ | _ | _ | 0000 | | 0000 | ONEO | 31:16 | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 06B0 | CNFG | 15:0 | _ | _ | _ | | _ | _ | CNFG9 | CNFG8 | CNFG7 | CNFG6 | | _ | _ | _ | _ | _ | 0000 | Legend: x = Unknown value on Reset; — = Unimplemented, read as '0'; Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PIC32MK GPK/MCM with CAN FD Family TABLE 13-15: PERIPHERAL PIN SELECT INPUT REGISTER MAP | SS | | | | | | | | | | В | Bits | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|-------|--------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1404 | INT1R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | INT1F | ?<3:0> | | 0000 | | 4.400 | INITOD | 31:16 | _ | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1408 | INT2R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | INT2F | R<3:0> | | 0000 | | 4.400 | INITOD | 31:16 | _ | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 140C | INT3R | 15:0 | _ | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | | INT3F | R<3:0> | | 0000 | | 4440 | INIT 4D | 31:16 | _ | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1410 | INT4R | 15:0 | _ | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | | INT4F | R<3:0> | | 0000 | | 4440 | TOOKE | 31:16 | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1418 | T2CKR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T2CK | R<3:0> | | 0000 | | 4440 | T3CKR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 141C | IJUKK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T3CK | R<3:0> | | 0000 | | 4.400 | TAOKD | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1420 | T4CKR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T4CK | R<3:0> | | 0000 | | 4404 | T5CKR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1424 | ISCKR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T5CK | R<3:0> | | 0000 | | 1400 | T6CKR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1428 | IOUNK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T6CK | R<3:0> | | 0000 | | 142C | T7CKR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1420 | ITCKK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T7CK | R<3:0> | | 0000 | | 1430 | T8CKR | 31:16 | - | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1430 | IOUNK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T8CK | R<3:0> | | 0000 | | 1434 | T9CKR | 31:16 | - | _ | _ | _ | _ | _ | _ | | - | _ | _ | _ | _ | | _ | _ | 0000 | | 1434 | IBONK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | T9CK | R<3:0> | | 0000 | | 1438 | IC1R | 31:16 | - | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1430 | ICIK | 15:0 | 1 | _ | _ | _ | _ | | _ | 1 | _ | _ | _ | _ | | IC1R | <3:0> | | 0000 | | 143C | IC2R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1430 | IU2R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC2R | <3:0> | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register is not available on 64-pin devices. This register is not available on devices without a CAN module. This register is only available on PIC32MKXXXGPEXXX devices. 3: This register is write only. | ⊓ | |---------------| | ñ | | × | | × | | $\simeq$ | | $\simeq$ | | $\circ$ | | | | S | | $\rightarrow$ | | 9 | | æ | | Υ. | | ਰ | | മ | | g | | Œ | | | | N | | $\neg$ | | 5 | | | | | TABLE 13-15: PERIPHERAL PIN SELECT INPUT REGISTER MAP (CONTINUED) | SS | | | | | | | | | | Е | Bits | | | | | | | | | |-----------------------------|------------------|---------------|-------|-----------|-------|-------|-------|-------|------|------|------|------|------|------|------|--------|----------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1440 | IC3R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1440 | IUSK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC3R | <3:0> | | 0000 | | 1444 | IC4R | 31:16 | 1 | _ | _ | _ | _ | _ | _ | 1 | - | _ | _ | _ | ı | ı | _ | 1 | 0000 | | 1444 | 10411 | 15:0 | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | | IC4R | <3:0> | | 0000 | | 1448 | IC5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1440 | 10011 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC5R | <3:0> | | 0000 | | 144C | IC6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 10011 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC6R | <3:0> | | 0000 | | 1450 | IC7R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | _ | | | | _ | _ | | IC7R | <3:0> | | 0000 | | 1454 | IC8R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | IC8R | <3:0> | | 0000 | | 1458 | IC9R | 31:16 | | _ | | | _ | | | | | | _ | _ | _ | | | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC9R | <3:0> | | 0000 | | 145C | OCFAR | 31:16 | _ | _ | _ | _ | | _ | _ | | _ | | | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | OCFAI | R<3:0> | | 0000 | | 1460 | OCFBR | 31:16 | | _ | | | _ | _ | _ | | | _ | _ | _ | _ | | <u> </u> | | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | _ | | | | _ | _ | | OCFB | | | 0000 | | 1464 | U1RXR | 31:16<br>15:0 | | _ | | | | _ | _ | | | | | | _ | —<br>— | <u> </u> | _ | 0000 | | | | 31:16 | _ | | _ | _ | | _ | _ | | | _ | _ | | _ | U1RXI | K<3:0> | _ | 0000 | | 1468 | U1CTSR | 15:0 | | | | _ | | | | | | _ | | | | U1CTS | .B<3:0> | | 0000 | | | | 31:16 | | | | | | _ | | | | | | | | 01013 | | | 0000 | | 146C | U2RXR | 15:0 | | | | _ | _ | _ | _ | | _ | _ | _ | _ | _ | U2RXI | 3<3:0> | _ | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | — | — | _ | 0000 | | 1470 | U2CTSR | 15:0 | | | | | | | | | | | | _ | | U2CTS | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | — | _ | 0000 | | 1474 | U3RXR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | U3RXI | R<3:0> | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1478 | U3CTSR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | U3CTS | R<3:0> | | 0000 | | Logon | | | | cot: - ur | | | | | | | | | | | | 00010 | | | 3000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register is not available on 64-pin devices. This register is not available on devices without a CAN module. 2: This register is only available on PIC32MKXXXGPEXXX devices. 3: This register is write only. TABLE 13-15: PERIPHERAL PIN SELECT INPUT REGISTER MAP (CONTINUED) | SS | | | | | | | | | | Е | Bits | | | | | | | | | | | |-----------------------------|---------------------|---------------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|---------|--------|------|------------|--|--| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | | 147C | U4RXR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 1470 | U4IXXIX | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | U4RXI | R<3:0> | | 0000 | | | | 1480 | U4CTSR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 1400 | 0401010 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | U4CTS | R<3:0> | | 0000 | | | | 1484 | U5RXR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | | 0010111 | 15:0 | _ | _ | _ | _ | _ | _ | _ | | _ | - | _ | _ | | U5RXI | R<3:0> | | 0000 | | | | 1488 | U5CTSR | 31:16 | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | _ | _ | _ | 0000 | | | | | 0001011 | 15:0 | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | | U5CTS | R<3:0> | | 0000 | | | | 148C | U6RXR | 31:16 | _ | _ | _ | _ | | _ | _ | | | | | _ | _ | _ | _ | _ | 0000 | | | | | | 15:0 | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | | U6RXI | R<3:0> | | 0000 | | | | 1490 | U6CTSR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | 0000 | | | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | U6CTS | | | 0000 | | | | 1498 | SDI1R | 31:16 | | | _ | _ | | _ | | | _ | | | _ | _ | _ | _ | _ | 0000 | | | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | | SDI1F | R<3:0> | | 0000 | | | | 149C | SS1R | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | 0000 | | | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | | SS1R | | 1 | 0000 | | | | 14A4 | SDI2R | 31:16 | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | —<br>— | | _ | 0000 | | | | | | 15:0 | _ | _ | _ | _ | | _ | _ | | | | | _ | | SDIZE | R<3:0> | | 0000 | | | | 14A8 | SS2R <sup>(4)</sup> | 31:16 | | | | _ | | _ | _ | | _ | | | _ | _ | _ | _ | _ | 0000 | | | | | | 15:0 | | _ | _ | _ | | | _ | | | | | _ | | SS2R | | | 0000 | | | | 14AC | SCK3R | 31:16 | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | | SCK3I | | _ | 0000 | | | | | | 15:0<br>31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SCKSI | | | 0000 | | | | 14B0 | SDI3R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | - CDISE | R<3:0> | _ | 0000 | | | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | | | | _ | | _ | 30136 | | I _ | _ | | | | 14B4 | SS3R | 15:0 | | | _ | | | _ | _ | _ | | _ | | _ | _ | SS3R | - | _ | 0000 | | | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | | | | | 0000 | | | | 14B8 | SCK4R | 15:0 | | | | | | _ | | | _ | | _ | | _ | SCK4F | - | _ | 0000 | | | | | | 1 | | | | | | _ | | _ | _ | | | | | 3UK41 | | | _ | | | | 14BC | SDI4R | 31:16 | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | - CD14F | R<3:0> | _ | 0000 | | | | | | 15:0 | - | _ | _ | _ | _ | _ | _ | | - | _ | _ | - | | 3D14F | <<3:U> | | 0000 | | | **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register is not available on 64-pin devices. <sup>2:</sup> This register is not available on devices without a CAN module. <sup>3:</sup> This register is only available on PIC32MKXXXGPEXXX devices. <sup>4:</sup> This register is write only. TABLE 13-15: PERIPHERAL PIN SELECT INPUT REGISTER MAP (CONTINUED) | SS | | | | | | | | | | Е | Bits | | | | | | | | | |-----------------------------|----------------------|---------------|-------|--------------|-------|-------|-------|-------|------|------|------|------|------|------|------|--------|----------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1400 | SS4R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 14C0 | 554K | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SS4R | <3:0> | | 0000 | | 14C4 | C1RXR <sup>(2)</sup> | 31:16 | 1 | _ | _ | _ | _ | _ | _ | 1 | 1 | _ | _ | _ | 1 | 1 | _ | 1 | 0000 | | 1404 | CHAIN. | 15:0 | - | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | | C1RXI | R<3:0> | | 0000 | | 14C8 | C2RXR <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1400 | OZIVIN | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | C2RXI | R<3:0> | | 0000 | | 14CC | REFIR | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | 0000 | | 1100 | 1121111 | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | REFIF | R<3:0> | | 0000 | | 14D0 | QEA1R | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | _ | _ | | _ | | | | | _ | _ | | QEA1I | R<3:0> | | 0000 | | 14D4 | QEB1R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | QEB1I | R<3:0> | | 0000 | | 14D8 | INDX1R | 31:16 | | | | _ | _ | _ | _ | | | | _ | _ | _ | | | _ | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | INDX1 | R<3:0> | | 0000 | | 14DC | HOME1R | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | | _ | 0000 | | | | 15:0 | _ | _ | _ | | _ | _ | | | | _ | _ | _ | | HOME1 | | | 0000 | | 14E0 | QEA2R | 31:16 | | | | _ | _ | _ | _ | | | _ | _ | | _ | | | | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | | | | | _ | _ | | QEA2I | | | 0000 | | 14E4 | QEB2R | 31:16 | | _ | _ | | | _ | | | _ | | _ | | _ | —<br>— | <u> </u> | _ | 0000 | | | | 15:0<br>31:16 | | | | | | _ | | _ | | | _ | _ | | QEB2I | K<3:0> | | 0000 | | 14E8 | INDX2R | 15:0 | | | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | INDX2 | D<2:0> | _ | 0000 | | | | 31:16 | | | | | | _ | | _ | | | | | | INDX2 | K<3:0> | | _ | | 14EC | HOME2R | 15:0 | | _ | | _ | _ | | _ | | _ | _ | _ | _ | | HOME2 | D<3:0> | _ | 0000 | | | | 31:16 | | _ | _ | | _ | | _ | | | _ | _ | _ | _ | — | _ | _ | 0000 | | 14F0 | FLT1R | 15:0 | | | | | _ | | _ | | | _ | _ | | | FLT1F | | | 0000 | | | | 31:16 | | <del>-</del> | | | _ | | | | | | | | | - | | _ | 0000 | | 14F4 | FLT2R | 15:0 | | | | | _ | | | | _ | | _ | _ | | FLT2F | 2<3.0> | | 0000 | | | | 31:16 | | | _ | | _ | _ | _ | | | _ | _ | _ | _ | | | _ | 0000 | | 14F8 | IC10R | 15:0 | | | _ | | _ | | | | | _ | _ | | | IC10F | 2<3:0> | | 0000 | | Logon | | | | eot: - ur | | | | | | | | | | | | 10 101 | 0.0- | | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register is not available on 64-pin devices. > This register is not available on devices without a CAN module. 2: This register is only available on PIC32MKXXXGPEXXX devices. 3: This register is write only. TABLE 13-15: PERIPHERAL PIN SELECT INPUT REGISTER MAP (CONTINUED) | SS | | | | | | | | | | Е | Bits | | | | | | | | | | |-----------------------------|-----------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|-------|--------|------|------------|--| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | 14FC | IC11R | 31:16 | | _ | _ | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | 0000 | | | 14FC | ICTIK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC11F | <3:0> | | 0000 | | | 1500 | IC12R | 31:16 | 1 | _ | _ | _ | _ | _ | _ | 1 | 1 | 1 | 1 | _ | _ | _ | _ | _ | 0000 | | | 1300 | ICIZK | 15:0 | - | _ | _ | _ | _ | _ | _ | - | - | - | - | _ | | IC12F | R<3:0> | | 0000 | | | 1504 | IC13R | 31:16 | 1 | | _ | _ | _ | _ | _ | 1 | 1 | 1 | I | _ | _ | _ | _ | _ | 0000 | | | 1304 | ICISK | 15:0 | 1 | | _ | _ | _ | _ | _ | 1 | 1 | 1 | 1 | _ | | IC13F | R<3:0> | | 0000 | | | 1508 | IC14R | 31:16 | - | _ | _ | _ | _ | _ | _ | - | - | _ | - | _ | _ | _ | _ | _ | 0000 | | | 1306 | 10 14K | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC14F | R<3:0> | | 0000 | | | 150C | IC15R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1500 | ICISK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC15F | R<3:0> | | 0000 | | | 1510 | IC16R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1510 | ICTOR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | IC16F | R<3:0> | | 0000 | | | 1514 | SCK5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | 1514 | SUNDR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SCK5 | R<3:0> | | | | | 1518 | SDI5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1316 | SDISK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SDI5F | ?<3:0> | | 0000 | | | 151C | SS5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1510 | SSSK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SS5R | <3:0> | | 0000 | | | 1520 | SCK6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | 1520 | SCROR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SCK6 | R<3:0> | | | | | 1524 | SDI6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1324 | SDIOK | 15:0 | | _ | _ | _ | _ | _ | _ | - | - | _ | - | _ | | SDI6F | ?<3:0> | | 0000 | | | 1528 | SS6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1526 | 330K | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | SS6R | <3:0> | | 0000 | | | 1500 | C3RXR <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 152C | COKAK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | C3RXI | R<3:0> | | 0000 | | | 1530 | C4RXR <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1530 | ∪4K∧K\ <del>-</del> / | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | C4RXI | R<3:0> | | 0000 | | | 1504 | OEASD | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1534 | QEA3R | 15:0 | _ | _ | _ | _ | _ | _ | _ | - | _ | - | - | _ | | QEA3I | R<3:0> | | 0000 | | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register is not available on 64-pin devices. 2: This register is not available on devices without a CAN module. 3: This register is only available on PIC32MKXXXGPEXXX devices. 4: This register is write only. TABLE 13-15: PERIPHERAL PIN SELECT INPUT REGISTER MAP (CONTINUED) | SS | | | | | | | | | | В | Bits | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|-------|---------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 4500 | QEB3R | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1538 | QEB3R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEB3 | R<3:0> | | 0000 | | 153C | INDX3R | 31:16 | - | _ | _ | _ | _ | _ | _ | 1 | 1 | _ | _ | _ | 1 | _ | _ | _ | 0000 | | 1330 | INDXSIX | 15:0 | _ | _ | _ | _ | _ | _ | | 1 | 1 | _ | _ | _ | | INDX3 | R<3:0> | | 0000 | | 1540 | HOME3R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1340 | TIONILSIX | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | HOME | 3R<3:0> | | 0000 | | 1544 | QEA4R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1044 | QLAHI | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEA4 | R<3:0> | | 0000 | | 1548 | QEB4R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1340 | QLD+IN | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEB4 | R<3:0> | | 0000 | | 154C | INDX4R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1340 | INDX4IX | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | INDX4 | R<3:0> | | 0000 | | 1550 | HOME4R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1330 | TIONILTI | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | HOME | 1R<3:0> | | 0000 | | 1554 | QEA5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1004 | QL/1011 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEA5 | R<3:0> | | 0000 | | 1558 | QEB5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1330 | QLDJIN | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEB5 | R<3:0> | | 0000 | | 155C | INDX5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | INDXOR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | INDX5 | R<3:0> | | 0000 | | 1560 | HOME5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | TIOMEOR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | HOME | R<3:0> | | 0000 | | 1564 | QEA6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1004 | QL/1011 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEA6 | R<3:0> | | 0000 | | 1568 | QEB6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | QLD011 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | QEB6 | R<3:0> | | 0000 | | 156C | INDX6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | HUDAUIA | 15:0 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | INDX6 | R<3:0> | | 0000 | | 1570 | HOME6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1370 | HOWLON | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | HOME | SR<3:0> | | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. This register is not available on 64-pin devices. Note 1: This register is not available on devices without a CAN module. This register is only available on PIC32MKXXXGPEXXX devices. 3: This register is write only. TABLE 13-16: PERIPHERAL PIN SELECT OUTPUT REGISTER MAP | SS | | | | | | | | | | В | its | | | | | | | | | |-----------------------------|------------------|---------------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|----------------|------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1600 | RPA0R | 31:16<br>15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | —<br>RPA0R<4:0 | _ | _ | 0000 | | | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | I _ | _ | _ | 0000 | | 1604 | RPA1R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | | I<br>RPA1R<4:0 | | ļ | 0000 | | | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 1608 | RPA2R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | ı | RPA2R<4:0 | > | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 160C | RPA3R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | · | RPA3R<4:0 | > | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1610 | RPA4R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | - | RPA4R<4:0 | > | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 161C | RPA7R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | · | RPA7R<4:0 | > | | 0000 | | | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1620 | RPA8R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | · | RPA8R<4:0 | > | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 162C | RPA11R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | PA11R<4:0 | > | | 0000 | | | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1630 | RPA12R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | PA12R<4:0 | )> | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1638 | RPA14R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | PA14R<4:0 | )> | | 0000 | | 1000 | DD445D | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 163C | RPA15R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPA15R<4:0 | )> | • | 0000 | | 1010 | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1640 | RPB0R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPB0R<4:0 | > | | 0000 | | 1011 | DDD4D | 31:16 | | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1644 | RPB1R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPB1R<4:0 | > | | 0000 | | 1640 | DDDAD | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1648 | RPB2R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPB2R<4:0 | > | • | 0000 | | 1610 | DDD2D | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 164C | RPB3R | 15:0 | I | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPB3R<4:0 | > | | 0000 | | 1650 | RPB4R | 31:16 | I | _ | _ | _ | _ | _ | - | | I | | | _ | _ | _ | 1 | _ | 0000 | | 1650 | RPD4K | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPB4R<4:0 | > | | 0000 | | 1654 | RPB5R | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 1004 | NEDOK | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPB5R<4:0 | > | | 0000 | | 1650 | DDDGD | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 1658 | RPB6R | 15:0 | I | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPB6R<4:0 | > | | 0000 | | 165C | RPB7R | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | INFD/K | 15:0 | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | F | RPB7R<4:0 | > | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. DS60001519E-page 281 | SS | | | | | | | | | | В | its | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|-----------------|------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 1664 | RPB9R | 31:16 | 1 | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | — | _ | _ | 0000 | | | 1 | 15:0 | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | | RPB9R<4:0 | | 1 | 0000 | | 1668 | RPB10R | 31:16 | | _ | | _ | _ | _ | _ | _ | | | _ | _ | | —<br>PD40D :4.0 | _ | _ | 0000 | | | | 15:0 | | _ | | _ | _ | _ | _ | _ | | | _ | | | :PB10R<4:0 | | | 0000 | | 166C | RPB11R | 31:16 | | _ | | _ | _ | _ | _ | _ | | | _ | _ | | —<br>DD44D +4+0 | _ | _ | 0000 | | | 1 | 15:0 | | _ | | _ | _ | _ | _ | _ | | | _ | | | PB11R<4:0 | )> | 1 | 0000 | | 1670 | RPB12R | 31:16 | _ | _ | | _ | _ | _ | _ | _ | | _ | _ | _ | | —<br>DD40D +4.0 | _ | _ | 0000 | | | | 15:0 | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | | PB12R<4:0 | | | 0000 | | 1674 | RPB13R | 31:16 | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | — | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | | PB13R<4:0 | | | 0000 | | 1678 | RPB14R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | 0000 | | | | 15:0 | | _ | | _ | _ | _ | _ | _ | | _ | _ | | | PB14R<4:0 | )> | | 0000 | | 167C | RPB15R | 31:16 | | _ | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | | 0000 | | | 2.0 | 15:0 | | _ | | _ | _ | _ | _ | _ | | _ | _ | | R | PB15R<4:0 | )> | | 0000 | | 1680 | RPC0R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | THE COIL | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPC0R<4:0 | > | | 0000 | | 1684 | RPC1R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1004 | IXI O IIX | 15:0 | - | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | | F | RPC1R<4:0 | > | | 0000 | | 1688 | RPC2R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | IXI OZIX | 15:0 | - | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | | F | RPC2R<4:0 | > | | 0000 | | 1690 | RPC4R | 31:16 | I | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1090 | KPC4K | 15:0 | - | _ | _ | _ | _ | _ | _ | _ | ı | _ | _ | | F | RPC4R<4:0 | > | | 0000 | | 1698 | RPC6R | 31:16 | I | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1090 | KECOK | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPC6R<4:0 | > | | 0000 | | 1600 | RPC7R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 169C | KPC/K | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPC7R<4:0 | > | • | 0000 | | 1640 | DDC0D | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 16A0 | RPC8R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPC8R<4:0 | > | | 0000 | | 4044 | DDOOD | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 16A4 | RPC9R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | | F | RPC9R<4:0 | > | | 0000 | | 1010 | DD040D | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 16A8 | RPC10R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | R | PC10R<4:0 | )> | | 0000 | | 4055 | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 16B0 | RPC12R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | R | PC12R<4:0 | )> | | 0000 | | | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 16BC | RPC15R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | R | PC15R<4:( | )> | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 16CC | RPD3R | 15:0 | | _ | | | | | | | | | _ | | | RPD3R<4:0 | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. TABLE 13-16: PERIPHERAL PIN SELECT OUTPUT REGISTER MAP (CONTINUED) | SS | | | | | | | Bits | | | | | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------------|------|------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 16D0 | RPD4R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | TAI DAIX | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPD4R<4:0 | > | | 0000 | | 16D4 | RPD5R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1004 | IXI DOIX | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPD5R<4:0 | > | | 0000 | | 16D8 | RPD6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | IXI DOIX | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPD6R<4:0 | > | | 0000 | | 1700 | RPE0R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | | _ | 0000 | | 1700 | IXI LOIX | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPE0R<4:0 | > | | 0000 | | 1704 | RPE1R | 31:16 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | 1 | _ | | _ | 0000 | | 1704 | REIK | 15:0 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | ı | | F | RPE1R<4:0 | > | | 0000 | | 1738 | RPE14R | 31:16 | I | _ | _ | _ | _ | _ | _ | _ | _ | _ | I | _ | I | _ | _ | _ | 0000 | | 1730 | KPE 14K | 15:0 | I | | _ | _ | _ | _ | _ | | _ | | I | | R | PF14R<4:0 | > | | 0000 | | 173C | RPE15R | 31:16 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | ı | _ | I | _ | _ | _ | 0000 | | 1730 | KELIJK | 15:0 | I | _ | _ | _ | _ | _ | _ | _ | _ | _ | I | | R | PE15R<4:0 | > | • | 0000 | | 1740 | RPF0R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | 0000 | | 1740 | RPFUR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPF0R<4:0> | > | | 0000 | | 1744 | RPF1R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | 0000 | | 1744 | RPFIR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPF1R<4:0> | > | | 0000 | | 1780 | RPG0R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | | _ | 0000 | | 1760 | RPGUR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPG0R<4:0 | > | | 0000 | | 1784 | RPG1R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | 0000 | | 1704 | RPGIR | 15:0 | I | _ | _ | _ | _ | _ | _ | _ | _ | _ | I | | F | RPG1R<4:0 | > | | 0000 | | 1700 | RPG6R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | 0000 | | 1798 | RPGOR | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPG6R<4:0 | > | | 0000 | | 179C | RPG7R | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1790 | RPG/R | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | F | RPG7R<4:0 | > | • | 0000 | | 1700 | DDCOD | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 17A0 | RPG8R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | F | RPG8R<4:0: | > | | 0000 | | 4744 | DDCOD | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | 17A4 | RPG9R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | F | RPG9R<4:0: | > | | 0000 | | 4700 | DDC40D | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | 0000 | | 17B0 | RPG12R | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | R | PG12R<4:0 | > | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. ### REGISTER 13-1: [pin name]R: PERIPHERAL PIN SELECT INPUT REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.46 | U-0 | 23:16 | _ | _ | - | _ | - | _ | - | _ | | 45.0 | U-0 | 15:8 | _ | _ | - | - | - | _ | | _ | | 7.0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | _ | | _ | | [pin name | ?]R<3:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-4 Unimplemented: Read as '0' bit 3-0 [pin name]R<3:0>: Peripheral Pin Select Input bits Where [pin name] refers to the pins that are used to configure peripheral input mapping. See Table 13-1 for input pin selection values. Note: Register values can only be changed if the IOLOCK Configuration bit (CFGCON<13>) = 0. #### REGISTER 13-2: RPnR: PERIPHERAL PIN SELECT OUTPUT REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | | - | 1 | _ | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | _ | - | _ | _ | _ | _ | _ | | 7.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | _ | _ | | | RPnR<4:0> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-5 Unimplemented: Read as '0' bit 4-0 **RPnR<4:0>:** Peripheral Pin Select Output bits See Table 13-2 for output pin selection values. Note: Register values can only be changed if the IOLOCK Configuration bit (CFGCON<13>) = 0. ### REGISTER 13-3: CNCONx: CHANGE NOTICE CONTROL FOR PORTX REGISTER (x = A - G) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | _ | | _ | _ | | 23:16 | U-0 | | _ | - | - | - | _ | _ | _ | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | U-0 | R/W-0 | r-0 | U-0 | U-0 | | 15:8 | ON | _ | SIDL | _ | EDGEDETECT | _ | _ | _ | | 7:0 | U-0 | | _ | | | | _ | - | _ | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 ON: Change Notice (CN) Control ON bit 1 = CN is enabled0 = CN is disabled bit 14 Unimplemented: Read as '0' bit 13 SIDL: Stop in Idle Control bit 1 = CPU Idle mode halts CN operation 0 = CPU Idle mode does not affect CN operation bit 12 Unimplemented: Read as '0' bit 11 **EDGEDETECT:** Edge Detection Type Control bit 1 = Detects any edge on the pin (CNx is used for the CN event) 0 = Detects any edge on the pin (CNSTATx is used for the CN event) bit 10 **Reserved:** Always write '0' bit 9-0 **Unimplemented:** Read as '0' #### 14.0 TIMER1 Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 14.** "Timers" (DS60001105), which is available from the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). PIC32MK GPK/MCM with CAN FD Family of devices feature one synchronous/asynchronous 16-bit timer that can operate as a free-running interval timer for various timing applications and counting external events. This timer can also be used with the low-power Secondary Oscillator (Sosc) for real-time clock applications. The following modes are supported by Timer1: - · Synchronous Internal Timer - · Synchronous Internal Gated Timer - · Synchronous External Timer - · Asynchronous External Timer ### 14.1 Additional Supported Features - · Selectable clock prescaler - · Timer operation during Sleep and Idle modes - Fast bit manipulation using CLR, SET, and INV registers - Asynchronous mode can be used with the Sosc to function as a real-time clock - · ADC event trigger ### 14.2 Timer1 Usage Model Guidelines ### 14.2.1 EXTERNAL CLOCK MODE OPERATION When the Timer is operating with an external clock mode with the TCS bit (TxCON<1>) = 1, the mode bits of the TxCON register must be initialized using a separate Write operation from that used to enable the Timer. Specifically, the TCS, TSYNC, etc. bits must be written first, and then the ON bit (TxCON<15>) must be set in a subsequent write. Once the ON bit is set, any writes to the TxCON register may cause erroneous counter operation. Note: The ON bit should be clear when updates are made to any other bits in the TxCON register. ### 14.2.2 ASYNCHRONOUS MODE OPERATION When writing the ON bit when the Timer is configured in Asynchronous mode or in an external clock mode with the prescaler enabled, the act of setting the ON bit does not take effect until two rising edges of the external clock input have occurred. # 14.2.3 ASYNCHRONOUS MODE OPERATION WITH A PENDING TMRx REGISTER WRITE When the Timer is configured in Asynchronous mode and the Timer is attempting to write to the TMRx register while a previous write is awaiting synchronization, the value written to the timer can become corrupted. To ensure that writes will not cause the TMRx value to become corrupted, the TWDIS bit (TxCON<12>), when set, will ignore a write to the TMRx register when a previous write to the TMRx register is awaiting synchronization into the Asynchronous Timer Clock domain. The TWIP bit (TxCON<11>) indicates when write synchronization is complete, and it is safe to write another value to the timer. #### 14.2.4 PRx REGISTER WRITES Writing to the PRx register while the Timer is active, may cause erratic operation. #### 14.2.5 TIMER1 FORMULA PR1 = ((Desired Time \* FPBCLK2) - Prescaler Count) - Prescaler Count = 1, 8, 64, 256 - FPBCLK2 = (FSYSCLK / PB2DIV<PBDIV>) Note: Timer1 interrupt occurs one additional prescaler cycle count *after* the timer and period match (TMR1 = PR1). FIGURE 14-1: TIMER1 BLOCK DIAGRAM Note: Timer1 ADC trigger and interrupt occurs on match + 1 count, therefore set the period to PR1 - 1 to compensate irregardless of the pre-scaler. ### 14.3 Timer1 Control Register ### TABLE 14-1: TIMER1 REGISTER MAP | Virtual Address<br>(BF82_#)<br>Register | | 0 | | Bits | | | | | | | | | | | | | ts | | | |-----------------------------------------|---------------------------------|--------------------|------------|-------|-------|-------|-------|-------|-----------|------|-------|------|------------|------|------|-------|------|------|-----------| | | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | 0000 | T1CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | 0000 | | 0000 | TICON | 15:0 | ON | _ | SIDL | TWDIS | TWIP | _ | TECS<1:0> | | TGATE | _ | TCKPS<1:0> | | _ | TSYNC | TCS | | 0000 | | 0010 | TMR1 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0010 | TIVIKT | 15:0 | TMR1<15:0> | | | | | | | | | | | | 0000 | | | | | | 0020 | PR1 | 31:16 | _ | 1 | - | _ | I | _ | _ | _ | _ | - | | _ | _ | _ | I | | 0000 | | 0020 | FIXI | TK1 15:0 PR1<15:0> | | | | | | | | | | | FFFF | | | | | | | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PIC32MK GPK/MCM with CAN FD Family #### REGISTER 14-1: T1CON: TYPE A TIMER CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | - | _ | - | - | _ | _ | _ | _ | | 00:40 | U-0 | 23:16 | | _ | - | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | ON | _ | SIDL | TWDIS | TWIP | _ | TECS | i<1:0> | | 7:0 | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | | | TGATE | _ | TCKPS | S<1:0> | _ | TSYNC | TCS | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 ON: Timer On bit 1 = Timer is enabled 0 = Timer is disabled bit 14 Unimplemented: Read as '0' bit 13 SIDL: Stop in Idle Mode bit 1 = Discontinue operation when device enters Idle mode 0 = Continue operation even in Idle mode bit 12 **TWDIS:** Asynchronous Timer Write Disable bit 1 = Writes to TMR1 are ignored until pending write operation completes 0 = Back-to-back writes are enabled (Legacy Asynchronous Timer functionality) bit 11 **TWIP:** Asynchronous Timer Write in Progress bit In Asynchronous Timer mode: 1 = Asynchronous write to TMR1 register in progress 0 = Asynchronous write to TMR1 register complete In Synchronous Timer mode: This bit is read as '0'. bit 10 **Unimplemented:** Read as '0' bit 9-8 TECS<1:0>: Timer1 External Clock Selection bits 11 =Reserved 10 =External clock comes from the LPRC 01 =External clock comes from the T1CK pin 00 = External clock comes from the Sosc bit 7 TGATE: Timer Gated Time Accumulation Enable bit $\frac{\text{When TCS} = 1:}{\text{This bit is ignored.}}$ When TCS = 0: 1 = Gated time accumulation is enabled 0 = Gated time accumulation is disabled bit 6 Unimplemented: Read as '0' bit 5-4 TCKPS<1:0>: Timer Input Clock Prescale Select bits 11 =1:256 prescale value 10 =1:64 prescale value 01 =1:8 prescale value 00 =1:1 prescale value ### REGISTER 14-1: T1CON: TYPE A TIMER CONTROL REGISTER (CONTINUED) bit 3 Unimplemented: Read as '0' bit 2 TSYNC: Timer External Clock Input Synchronization Selection bit When TCS = 1: 1 = External clock input is synchronized 0 = External clock input is not synchronized $\frac{\text{When TCS = } 0:}{\text{This bit is ignored.}}$ bit 1 TCS: Timer Clock Source Select bit 1 = External clock is defined by the TECS<1:0> bits 0 = Internal peripheral clock bit 0 Unimplemented: Read as '0' | NOTES: | <del>-</del> | <del>-</del> | <br><del>-</del> | | |--------|--------------|--------------|------------------|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 15.0 TIMER2 THROUGH TIMER9 Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 14.** "Timers" (DS60001105), which is available from the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). The PIC32MK GPK/MCM with CAN FD Family of devices features eight native synchronous/ asynchronous 16/32-bit timers (default 16-bit mode) that can operate as free-running interval timers for various timing applications and counting external events. #### 15.1 Features The following are key features of the timers: - · External 16/32-bit Counter Input mode - Asynchronous external clock with/without selectable prescaler - Synchronous internal clock with/without selectable prescaler - External gate control (External pulse width measurement) - · Automatic timer synchronization control - · Operation in Idle mode - Interrupt on a period register match or falling edge of external gate signal - Time base for Input Capture and/or Output Compare modules #### 15.2 Timer2-Timer9 Formula PRx = ((Desired Time \* FPBCLK2) - Prescaler Count) - Prescaler Count = 1, 2, 4, 8, 16, 32, 64, 256 - FPBCLK2 = (FSYSCLK / PB2DIV<PBDIV>) **Note:** Timer interrupts and triggers occur one additional prescaler cycle count *after* the timer and period match (TMRx = PRx). FIGURE 15-1: TIMER2 THROUGH TIMER9 BLOCK DIAGRAM (16/32-BIT) less of the pre-scaler. FIGURE 15-2: TIMER SYNCHRONIZATION BLOCK DIAGRAM ### 15.3 Timer2-Timer9 Control Registers ### TABLE 15-1: TIMER2 THROUGH TIMER9 REGISTER MAP | ess | | | | | | | | | | В | its | | | | | | | | (0) | |-----------------------------|---------------------------------|-----------|-------|-------|-----------|-------|-------|-------|------|-------|---------|------|------------|------|----------|------|------|------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0200 | T2CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | 120014 | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | | TCKPS<2:0: | > | T32 | _ | TCS | _ | 0000 | | 0210 | TMR2 | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | 0210 | TIVITAL | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | 0220 | PR2 | 31:16 | | | | | | | | | 31:16> | | | | | | | | FFFF | | 0220 | 1112 | 15:0 | | | | | | | | PR2< | :15:0> | | | | | | | | FFFF | | 0400 | T3CON | 31:16 | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0.00 | 100011 | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | | TCKPS<2:0: | > | T32 | _ | TCS | _ | 0000 | | 0410 | TMR3 | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | 0110 | 1111110 | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | 0420 | PR3 | 31:16 | | | | | | | | | 31:16> | | | | | | | | FFFF | | 0.20 | | 15:0 | | | ı | ı | ı | | | _ | :15:0> | | 1 | ı | 1 | | ı | ı | FFFF | | 0600 | T4CON | 31:16 | _ | | _ | _ | _ | | | _ | _ | | _ | _ | _ | | _ | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | | TCKPS<2:0: | > | T32 | _ | TCS | _ | 0000 | | 0610 | TMR4 | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | 0620 | PR4 | 31:16 | | | | | | | | | 31:16> | | | | | | | | FFFF | | | | 15:0 | | | | | | | | PR4< | :15:0> | | | | | | | | FFFF | | 0800 | T5CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | | _ | _ | _ | | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | | TCKPS<2:0: | > | T32 | _ | TCS | _ | 0000 | | 0810 | TMR5 | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | 0820 | PR5 | 31:16 | | | | | | | | | 31:16> | | | | | | | | FFFF | | | | 15:0 | | | | | | | | PR5< | :15:0> | | | | | | | | FFFF | | 0A00 | T6CON | 31:16 | _ | | —<br>OID! | _ | | | | - | | | —<br> | _ | | | | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | | TCKPS<2:0 | > | T32 | _ | TCS | _ | 0000 | | 0A10 | TMR6 | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | 0A20 | PR6 | 31:16 | | | | | | | | | 31:16> | | | | | | | | FFFF | | - | | 15:0 | | | | | | | | PR6< | :15:0> | | | | | | | | FFFF | | 0C00 | T7CON | 31:16 | | | - CIDI | _ | | _ | _ | CVAIC | | | | | —<br>T20 | _ | | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | | TCKPS<2:0: | > | T32 | _ | TCS | _ | 0000 | PIC32MK GPK/MCM with CAN FD Family **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information TABLE 15-1: TIMER2 THROUGH TIMER9 REGISTER MAP (CONTINUED) | ess | | | | | | | | | | В | its | | | | | | | | | |-----------------------------|---------------------------------|-----------|-------|------------------|-------|-------|-------|-------|------|-------|---------|------|----------|------|------|------|------|------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0C10 | TMR7 | 31:16 | | | | | | | | TMR7< | <31:16> | | | | | | | | 0000 | | 0010 | | 15:0 | | | | | | | | TMR7 | <15:0> | | | | | | | | 0000 | | 0C20 | PR7 | 31:16 | | PR7<31:16> FFFF | | | | | | | | | | | | | | | | | 0020 | | 15:0 | | | | | | | | PR7< | 15:0> | | | | | | | | FFFF | | 0F00 | T8CON | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | - | CKPS<2:0 | > | T32 | _ | TCS | _ | 0000 | | 0E10 | TMR8 | 31:16 | | | | | | | | | 31:16> | | | | | | | | 0000 | | 02.0 | | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | 0E20 | PR8 | 31:16 | | | | | | | | | 31:16> | | | | | | | | FFFF | | 0220 | | 15:0 | | | | | | | | PR8< | 15:0> | | | | | | | | FFFF | | 1000 | T9CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1000 | 13001 | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | TGATE | - | CKPS<2:0 | > | T32 | _ | TCS | _ | 0000 | | 1010 | TMR9 | 31:16 | | TMR9<31:16> 0000 | | | | | | | 0000 | | | | | | | | | | .510 | | 15:0 | | TMR9<15:0> 0000 | | | | | | | | 0000 | | | | | | | | | 1020 | PR9 | 31:16 | | PR9<31:16> FFFF | | | | | | | | | | | | | | | | | 1020 | 1113 | 15:0 | | | | | | | | PR9< | :15:0> | | | | | | | | FFFF | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PIC32MK GPK/MCM with CAN FD Family ### REGISTER 15-1: TxCON: TYPE B TIMER CONTROL REGISTER ('x' = 2-9) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | | 15:8 | ON | _ | SIDL | _ | _ | _ | _ | SYNC | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | U-0 | | 7:0 | TGATE | | TCKPS<2:0> | | T32 | _ | TCS | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 ON: Timer On bit 1 = Module is enabled0 = Module is disabled bit 14 **Unimplemented:** Read as '0' bit 13 SIDL: Stop in Idle Mode bit 1 = Discontinue operation when device enters Idle mode 0 = Continue operation even in Idle mode bit 12-9 Unimplemented: Read as '0' bit 8 SYNC: TMRx Synchronized Timer Start/Stop Enable bit 1 = TMRx synchronized timer start/stop is enabled 0 = TMRx synchronized timer start/stop is disabled **Note:** Setting this bit chains all timers whose corresponding SYNC bit is also set such that when the TON bit of all corresponding timers is set, the timers are enabled simultaneously. If any timers in the group are disabled, they are all disabled simultaneously. See Figure 15-2 for additional information. bit 7 TGATE: Timer Gated Time Accumulation Enable bit When TCS = 1: This bit is ignored and is read as '0'. When TCS = 0: 1 = Gated time accumulation is enabled 0 = Gated time accumulation is disabled bit 6-4 TCKPS<2:0>: Timer Input Clock Prescale Select bits 111 = 1:256 prescale value 110 = 1:64 prescale value 101 = 1:32 prescale value 100 = 1:16 prescale value 011 = 1:8 prescale value 010 = 1:4 prescale value 001 = 1:2 prescale value 000 = 1:1 prescale value bit 3 T32: 32-Bit Timer Mode Select bit 1 = 32-bit Timer mode 0 = 16-bit Timer mode bit 2 Unimplemented: Read as '0' bit 1 TCS: Timer Clock Source Select bit 1 = External clock from TxCK pin 0 = Internal peripheral clock bit 0 **Unimplemented:** Read as '0' | | | y | | |--------|--|---|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 16.0 DEADMAN TIMER (DMT) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 9. "Watchdog, Deadman, and Timers" Power-up (DS60001114), which is available from Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The primary function of the Deadman Timer (DMT) is to reset the processor in the event of a software malfunction. The DMT is a free-running instruction fetch timer, which is clocked whenever an instruction fetch occurs until a count match occurs. Instructions are not fetched when the processor is in Sleep mode. The DMT consists of a 32-bit counter with a time-out count match value as specified by the DMTCNT<3:0> bits in the DEVCFG1 Configuration register. A Deadman Timer is typically used in mission critical and safety critical applications, where any single failure of the software functionality and sequencing must be detected. Figure 16-1 shows a block diagram of the Deadman Timer module. ### FIGURE 16-1: DEADMAN TIMER BLOCK DIAGRAM ### 16.1 Deadman Timer Control Registers ### TABLE 16-1: DEADMAN TIMER REGISTER MAP | ess | | | | | | | | | | | Bits | | | | | | | | | |-----------------------------|------------------|-----------|-------|-------|-------|-------------------|--------|-------|------|------|-------------|------|----------|------|--------|------|------|--------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0E00 | DMTCON | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | 0000 | | OLOO | DIVITOON | 15:0 | ON | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 0E10 | DMTPRECLR | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | 0000 | | OL 10 | DIVITI NECEN | 15:0 | | | | STEP <sup>-</sup> | 1<7:0> | | | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 0E20 | DMCLR | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | ULZU | DIVICEIX | 15:0 | _ | _ | _ | _ | _ | _ | _ | | | | | STEP | 2<7:0> | | | | 0000 | | 0E30 | DMTSTAT | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | OLSO | DIVITOTAL | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | BAD1 | BAD2 | DMTEVENT | | _ | _ | _ | WINOPN | 0000 | | 0E40 | DMTCNT | 31:16 | | | | | | | | COLI | NTER<31:0 | )> | | | | | | | 0000 | | 0240 | DIVITORT | 15:0 | | | | | | | | 0001 | VILIX-01. | ,- | | | | | | | 0000 | | 0E60 | DMTPSCNT | 31:16 | | | | | | | | PSC | CNT<31:0> | | | | | | | | 0000 | | OLOO | DIVITI OCIVI | 15:0 | | | | | | | | 1 00 | JINT \01.02 | | | | | | | | 0000 | | 0E70 | DMTPSINTV | 31:16 | | | | | | | | DSI | NTV<31:0> | | | | | | | | 0000 | | 0270 | DIVITEDINITY | 15:0 | | | | | | | | FOI | NIV-31.02 | - | | | | | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. #### REGISTER 16-1: DMTCON: DEADMAN TIMER CONTROL REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22,46 | U-0 | 23:16 | _ | _ | _ | _ | _ | - | _ | _ | | 45.0 | R/W-0 | U-0 | 15:8 | ON <sup>(1)</sup> | _ | _ | _ | _ | - | _ | _ | | 7.0 | U-0 | 7:0 | _ | _ | _ | _ | _ | _ | _ | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 **ON:** Deadman Timer Module Enable bit<sup>(1)</sup> 1 = Deadman Timer module is enabled0 = Deadman Timer module is disabled bit 13-0 **Unimplemented:** Read as '0' **Note 1:** This bit only has control when FDMTEN (DEVCFG1<3>) = 0. ### REGISTER 16-2: DMTPRECLR: DEADMAN TIMER PRECLEAR REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | 15:8 | | | | STEP1 | <7:0> | | | | | 7.0 | U-0 | 7:0 | _ | _ | _ | _ | _ | - | _ | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-8 STEP1<7:0>: Preclear Enable bits 01000000 = Enables the Deadman Timer Preclear (Step 1) All other write patterns = Set BAD1 flag. These bits are cleared when a DMT reset event occurs. STEP1<7:0> is also cleared if the STEP2<7:0> bits are loaded with the correct value in the correct sequence. bit 7-0 **Unimplemented:** Read as '0' #### REGISTER 16-3: DMTCLR: DEADMAN TIMER CLEAR REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | _ | _ | _ | | 7:0 | R/W-0 | 7:0 | | | | STEP2 | <7:0> | | • | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 **Unimplemented:** Read as '0' bit 7-0 **STEP2<7:0>:** Clear Timer bits 00001000 = Clears STEP1<7:0>, STEP2<7:0> and the Deadman Timer if, and only if, preceded by correct loading of STEP1<7:0> bits in the correct sequence. The write to these bits may be verified by reading DMTCNT and observing the counter being reset. All other write patterns = Set BAD2 bit, the value of STEP1<7:0> will remain unchanged, and the new value being written STEP2<7:0> will be captured. These bits are also cleared when a DMT reset event occurs. #### REGISTER 16-4: DMTSTAT: DEADMAN TIMER STATUS REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.16 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R-0, HC | R-0, HC | R-0, HC | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0 | | 7:0 | BAD1 | BAD2 | DMTEVENT | | | | | WINOPN | **Legend:** HC = Hardware Cleared R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7 BAD1: Bad STEP1<7:0> Value Detect bit 1 = Incorrect STEP1<7:0> value or out of sequence write to STEP2<7:0> was detected 0 = Incorrect STEP1<7:0> value was not detected bit 6 BAD2: Bad STEP2<7:0> Value Detect bit 1 = Incorrect STEP2<7:0> value was detected 0 = Incorrect STEP2<7:0> value was not detected bit 5 DMTEVENT: Deadman Timer Event bit 1 = Deadman timer event was detected (counter expired or bad STEP1<7:0> or STEP2<7:0> value was entered prior to counter increment) 0 = Deadman timer even was not detected Note: This bit is cleared only on a Reset. bit 4-1 **Unimplemented:** Read as '0' bit 0 WINOPN: Deadman Timer Clear Window bit 1 = Deadman timer clear window is open 0 = Deadman timer clear window is not open #### REGISTER 16-5: DMTCNT: DEADMAN TIMER COUNT REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | R-0 | 31:24 | | | | COUNTER | <31:24> | | | | | 00.40 | R-0 | 23:16 | | | | COUNTER | ?<23:16> | | | | | 45.0 | R-0 | 15:8 | | | | COUNTER | R<15:8> | | | | | 7.0 | R-0 | 7:0 | | | | COUNTE | R<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 COUNTER<31:0>: Read current contents of DMT counter ### REGISTER 16-6: DMTPSCNT: POST STATUS CONFIGURE DMT COUNT STATUS REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | R-0 | 31.24 | | | | PSCNT< | 31:24> | | | | | 23:16 | R-0 | 23.10 | | | | PSCNT< | 23:16> | | | | | 15.0 | R-0 | 15:8 | | | | PSCNT< | <15:8> | | | | | 7:0 | R-0 | R-0 | R-0 | R-y | R-y | R-y | R-y | R-y | | 7.0 | | | • | PSCNT | <7:0> | • | • | | **Legend:** y= Value set from Configuration bits on POR R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 **PSCNT<31:0>:** DMT Instruction Count Value Configuration Status bits This is always the value of the DMTCNT<4:0> bits in the DEVCFG1 Configuration register. ### REGISTER 16-7: DMTPSINTV: POST STATUS CONFIGURE DMT INTERVAL STATUS REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | | | | |-----------|-------------------|-------------------|-------------------|-------------------|---------------------|-------------------|------------------|------------------|--|--|--|--|--|--|--|--|--| | 24.04 | R-0 | | | | | | | | | | 31:24 | PSINTV<31:24> | | | | | | | | | | | | | | | | | | 00.40 | R-0 | | | | | | | | | | 23:16 | | PSINTV<23:16> | | | | | | | | | | | | | | | | | 45.0 | R-0 | | | | | | | | | | 15:8 | | | | PSINTV- | <15:8> | | | | | | | | | | | | | | 7.0 | R-0 | R-0 | R-0 | R-0 | R-0 | R-y | R-y | R-y | | | | | | | | | | | 7:0 | | | | PSINTV | <b>′&lt;7:0&gt;</b> | PSINTV<7:0> | | | | | | | | | | | | | Legend: | | y= Value set from Configuration bits on POR | | | | | | |-------------------|------------------|---------------------------------------------|--------------------|--|--|--|--| | R = Readable bit | W = Writable bit | U = Unimplemented b | oit, read as '0' | | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | | | | bit 31-8 **PSINTV<31:0>:** DMT Window Interval Configuration Status bits This is always the value of the DMTINTV<2:0> bits in the DEVCFG1 Configuration register. | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # PIC32MK GPK/MCM WITH CAN FD FAMILY ### 17.0 WATCHDOG TIMER (WDT) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 9. "Watchdog, Deadman, and Power-up Timers"** (DS60001114), which is available from the *Documentation > Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). When enabled, the Watchdog Timer (WDT) operates from the internal Low-Power Oscillator (LPRC) clock source and can be used to detect system software malfunctions by resetting the device if the WDT is not cleared periodically in software. Various WDT time-out periods can be selected using the WDT postscaler. The WDT can also be used to wake the device from Sleep or Idle mode. The following are key features of the WDT module: - · Configuration or software controlled - · User-configurable time-out period - · Can wake the device from Sleep or Idle #### FIGURE 17-1: WATCHDOG TIMER BLOCK DIAGRAM ### 17.1 Watchdog Timer Control Registers ### TABLE 17-1: WATCHDOG TIMER REGISTER MAP | ess | | Ф | | Bits | | | | | | | | | | | | (n | | | | |---------------------------|-----------------------|-----------|-------|----------------------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|------------| | Virtual Addre<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0000 | WDTCON <sup>(1)</sup> | 31:16 | | WDTCLRKEY<15:0> 0000 | | | | | | | | | | | | | | | | | 0C00 | WDTCON | 15:0 | ON | _ | _ | — | | | | | | | | | | | | | | PIC32MK GPK/MCM WITH CAN FD FAMILY **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register has corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. ## PIC32MK GPK/MCM WITH CAN FD FAMILY #### REGISTER 17-1: WDTCON: WATCHDOG TIMER CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--| | 24.24 | W-0 | | | | | 31:24 | | | | WDTCLRKEY<15:8> | | | | | | | | | | 22.46 | W-0 | | | | | 23:16 | WDTCLRKEY<7:0> | | | | | | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R-y | R-y | R-y | R-y | R-y | | | | | | 15:8 | ON <sup>(1)</sup> | _ | _ | | | RUNDIV<4:0 | )> | | | | | | | 7.0 | U-0 | U-0 | R-y | R-y | R-y | R-y | R-y | R/W-0 | | | | | | 7:0 | _ | _ | | | WDTWINEN | | | | | | | | **Legend:** y = Values set from Configuration bits on POR R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 31-16 WDTCLRKEY<15:0>: Watchdog Timer Clear Key bits To clear the Watchdog Timer to prevent a time-out, software must write the value 0x5743 to these bits using a single 16-bit write. - bit 15 **ON:** Watchdog Timer Enable bit<sup>(1)</sup> - 1 = The Watchdog Timer module is enabled - 0 = The Watchdog Timer module is disabled - bit 14-13 Unimplemented: Read as '0' - bit 12-8 RUNDIV<4:0>: Watchdog Timer Postscaler Value in Run Mode bits In Run mode, these bits are set to the values of the WDTPS<4:0> Configuration bits in the DEVCFG1 register. - bit 7-6 Unimplemented: Read as '0' - bit 5-1 **SLPDIV<4:0>:** Watchdog Timer Postscaler Value in Sleep Mode bits In Sleep mode, these bits are set to the values of the WDTPS <4:0> Configuration bits in the DEVCFG1 register. - bit 0 WDTWINEN: Watchdog Timer Window Enable bit - 1 = Enable windowed Watchdog Timer - 0 = Disable windowed Watchdog Timer **Note 1:** This bit only has control when FWDTEN (DEVCFG1<23>) = 0. # PIC32MK GPK/MCM WITH CAN FD FAMILY | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 18.0 INPUT CAPTURE Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 15.** "Input Capture" (DS60001122), which is available from the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). The Input Capture module is useful in applications requiring frequency (period) and pulse measurement. The Input Capture module captures the 16-bit or 32-bit value of the selected Time Base registers when an event occurs at the ICx pin. Capture events are caused by the following factors: - Capture timer value on every edge (rising and falling), specified edge first - Prescaler capture event modes: - Capture timer value on every 4th rising edge of input at ICx pin - Capture timer value on every 16th rising edge of input at ICx pin - Capture every falling edge of input at ICx pin - Capture every rising edge of input at ICx pin - Capture every 4th rising edge of input at ICx pin - Capture every 16th rising edge of input at ICx pin - Capture every rising and falling edge of input at ICx pin - Capture timer values based on internal or external clocks Each input capture channel can select between either eight 16-bit time bases or four 32-bit time base. The selected timer can use either an internal or external clock. Other operational features include: - Device wake-up from capture pin during Sleep and Idle modes - Interrupt on input capture event - 4-word FIFO buffer for capture values; Interrupt optionally generated after 1, 2, 3, or 4 buffer locations are filled - Input capture can also be used to provide additional sources of external interrupts ### FIGURE 18-1: INPUT CAPTURE BLOCK DIAGRAM The timer source for each Input Capture module depends on the setting of the ICACLK bit in the CFGCON register and the C32 bit in the ICxCON register. The available configurations are shown in Table . TABLE 18-1: TIMER SOURCE CONFIGURATIONS | ICAPx | CFGCON<br><icaclk></icaclk> | ICxCON<br><ic32></ic32> | ICxCON<br><ictmr></ictmr> | TIMER_x | TIMER_y | ICxBUF CONTENT | |---------------|-----------------------------|-------------------------|---------------------------|--------------------|--------------------|--------------------| | | | | 0 | | 0x0000_TMR3 [15:0] | 0x0000_TMR3 [15:0] | | | 0 | 0 | 1 | 0x0000_TMR2 [15:0] | | 0x0000_TMR2 [15:0] | | | | 4 | 0 | | TMR2 [31:0] | TMR2 [31:0] | | 10 4 D (2 4 1 | 0 | 1 | 1 | TMR2 [31:0] | | TMR2 [31:0] | | ICAP[3-1] | | | 0 | | 0x0000_TMR5 [15:0] | 0x0000_TMR5 [15:0] | | | 1 | 0 | 1 | 0x0000_TMR4 [15:0] | | 0x0000_TMR4 [15:0] | | | | 4 | 0 | | TMR4 [31:0] | TMR4 [31:0] | | | 1 | 1 | 1 | TMR4 [31:0] | | TMR4 [31:0] | | | | | 0 | | 0x0000_TMR3 [15:0] | 0x0000_TMR3 [15:0] | | | 0 | 0 | 1 | 0x0000_TMR2 [15:0] | | 0x0000_TMR2 [15:0] | | | | 4 | 0 | | TMR2 [31:0] | TMR2 [31:0] | | ICAP[6-4] | 0 | 1 | 1 | TMR2 [31:0] | | TMR2 [31:0] | | ICAP[16-13] | | | 0 | | 0x0000_TMR3 [15:0] | 0x0000_TMR3 [15:0] | | | 1 | 0 | 1 | 0x0000_TMR2 [15:0] | | 0x0000_TMR2 [15:0] | | | | , | 0 | | TMR2 [31:0] | TMR2 [31:0] | | | 1 | 1 | 1 | TMR2 [31:0] | | TMR2 [31:0] | | | | | 0 | ] | 0x0000_TMR3 [15:0] | 0x0000_TMR3 [15:0] | | | 0 | 0 | 1 | 0x0000_TMR2 [15:0] | | 0x0000_TMR2 [15:0] | | | | , | 0 | | TMR2 [31:0] | TMR2 [31:0] | | 10.4850 =1 | 0 | 1 | 1 | TMR2 [31:0] | | TMR2 [31:0] | | ICAP[9-7] | | | 0 | | 0x0000_TMR7 [15:0] | 0x0000_TMR7 [15:0] | | | 1 | 0 | 1 | 0x0000_TMR6 [15:0] | | 0x0000_TMR6 [15:0] | | | | 4 | 0 | | TMR6 [31:0] | TMR6 [31:0] | | | 1 | 1 | 1 | TMR6 [31:0] | | TMR6 [31:0] | | | | | 0 | | 0x0000_TMR3 [15:0] | 0x0000_TMR3 [15:0] | | | 0 | 0 | 1 | 0x0000_TMR2 [15:0] | | 0x0000_TMR2 [15:0] | | | | , | 0 | | TMR2 [31:0] | TMR2 [31:0] | | 104540 401 | 0 | 1 | 1 | TMR2 [31:0] | | TMR2 [31:0] | | ICAP[12-10] | | • | 0 | | 0x0000_TMR9 [15:0] | 0x0000_TMR9 [15:0] | | | 1 | 0 | 1 | 0x0000_TMR8 [15:0] | | 0x0000_TMR8 [15:0] | | | | | 0 | | TMR8 [31:0] | TMR8 [31:0] | | | 1 | 1 | 1 | TMR8 [31:0] | | TMR8 [31:0] | | | _ | _ | 0 | | 0x0000_TMR3 [15:0] | 0x0000_TMR3 [15:0] | | | 0 | 0 | 1 | 0x0000_TMR2 [15:0] | | 0x0000_TMR2 [15:0] | | | | | 0 | | TMR2 [31:0] | TMR2 [31:0] | | IOADI:: | 0 | 1 | 1 | TMR2 [31:0] | | TMR2 [31:0] | | ICAP[16-13] | | | 0 | | 0x0000_TMR3 [15:0] | 0x0000_TMR3 [15:0] | | | 1 | 0 | 1 | 0x0000_TMR2 [15:0] | | 0x0000_TMR2 [15:0] | | | | | 0 | | TMR2 [31:0] | TMR2 [31:0] | | | 1 | 1 | 1 | TMR2 [31:0] | | TMR2 [31:0] | ### 18.1 Input Capture Control Registers ### TABLE 18-2: INPUT CAPTURE 1 THROUGH INPUT CAPTURE 9 REGISTER MAP | SS | | | | | | | | | | Bit | :s | | | | | | | | | |---------------------------|-----------------------|---------------|-------|--------------|-------|-----------|-------|-------|------------|--------|--------|------|------|------|-------|------|----------|------|------------| | Virtual Address<br>BF82_# | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | IC1CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 2000 | IC ICON | 15:0 | ON | _ | SIDL | ı | 1 | I | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2010 | IC1BUF | 31:16<br>15:0 | | IC1BUF<31:U> | | | | | | | | | | | | XXXX | | | | | 2200 | IC2CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 2200 | ICZCON* * | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2210 | IC2BUF | 31:16<br>15:0 | | IC2BUF<31:0> | | | | | | | | | | XXXX | | | | | | | 2400 | IC3CON <sup>(1)</sup> | 31:16 | - | _ | | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | | _ | | 0000 | | 2400 | 1000011 | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2410 | IC3BUF | 31:16<br>15:0 | | | | | | | | IC3BUF | <31:0> | | | | | | | | XXXX | | 2600 | IC4CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | | | | _ | | _ | _ | _ | _ | | _ | 0000 | | 2000 | | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2610 | IC4BUF | 31:16<br>15:0 | | | | | | | | IC4BUF | <31:0> | | | | | | | | XXXX | | 2800 | IC5CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | - | _ | | _ | _ | _ | _ | _ | - | _ | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2810 | IC5BUF | 31:16<br>15:0 | | | | | | | | IC5BUF | <31:0> | | | | | | | | XXXX | | 2A00 | IC6CON <sup>(1)</sup> | 31:16 | _ | _ | | | | | | | | | | _ | _ | _ | | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2A10 | IC6B0F | 31:16<br>15:0 | | | | | | | | IC6BUF | <31:0> | | | | | | | | XXXX | | 2C00 | IC7CON <sup>(1)</sup> | 31:16 | _ | _ | | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | 0000 | | | | 15:0<br>31:16 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2C10 | IC/BUF | 15:0 | | | | | | | | IC7BUF | <31:0> | | | | | | | | XXXX | | 2E00 | IC8CON <sup>(1)</sup> | 31:16 | _ | _ | | | | | _ | _ | - | _ | | _ | _ | _ | | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:U> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 2E10 | IC8B0F | 31:16<br>15:0 | | | | | | | | IC8BUF | <31:0> | | | | | | | | XXXX | | 3000 | IC9CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | | | | | _ | _ | _ | _ | _ | _ | | _ | 0000 | | | | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3010 | IC9BUF | 31:16<br>15:0 | | | | | | | | IC9BUF | <31:0> | | | | | | | | XXXX | | | | 15:0 | | | | tad raada | | | ahaum in h | | | | | | | | | | XXXX | PIC32MK GPK/MCM with CAN FD Family **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:This register has corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. | Ō | |---------------| | ഉ | | 8 | | Ō | | ㅠ | | Ξ. | | 9 | | Ψ | | ್ದ | | ğ | | Ø | | ω | | $\frac{1}{2}$ | | w | | | | TADIE 40 2. | INPUT CAPTURE 10 THROUGH INPUT CAPTURE 16 REGISTER MAP | |-------------|--------------------------------------------------------| | IADLE 10-0: | INPUT CAPTURE IU TOROUGO INPUT CAPTURE IO REGISTER MAP | | ess | | 0 | | | | | | | | Bit | ts | | | | | | | | ·o | |---------------------------|------------------------|---------------|-------|--------------------------|-------|-------|-------|-------|-------|---------|--------|------|------|------|-------|------|----------|------|------------| | Virtual Address<br>BF84_# | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 3200 | IC10CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | | | | | _ | _ | | _ | _ | _ | 0000 | | | | 15:0 | ON | | SIDL | | _ | | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3210 | IC10BUF | 31:16<br>15:0 | | IC10B0F<31:0> | | | | | | | | | | | | XXXX | | | | | 2400 | IC11CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3400 | ICTICON, 7 | 15:0 | ON | _ | SIDL | 1 | _ | 1 | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3410 | IC11BUF | 31:16<br>15:0 | | IC11BUF<31:0> xxxx xxxx | | | | | | | | | | | | | | | | | 3600 | IC12CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | | 0000 | | 3000 | 10 1200N 7 | 15:0 | ON | _ | SIDL | - | _ | - | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3610 | IC12BUF | 31:16<br>15:0 | | | | | | | | IC12BUF | <31:0> | | | | | | | | xxxx | | 2000 | 1C12CON(1) | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3800 | IC13CON <sup>(1)</sup> | 15:0 | ON | _ | SIDL | _ | _ | | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3810 | IC13BUF | 31:16<br>15:0 | _ | | | | | | | IC13BUF | <31:0> | | | • | • | | | | XXXX | | 2400 | IC14CON <sup>(1)</sup> | 31:16 | _ | _ | _ | - | _ | - | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 3A00 | 10 1400N 7 | 15:0 | ON | | SIDL | I | _ | - | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3A10 | IC14BUF | 31:16<br>15:0 | | | | | | | | IC14BUF | <31:0> | | | | | | | | xxxx | | 0000 | IC15CON <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3C00 | IC 15CON** | 15:0 | ON | _ | SIDL | _ | _ | | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3C10 | IC15BUF | 31:16<br>15:0 | | IC15BUF<31:0> | | | | | | | | | xxxx | | | | | | | | 0500 | 1040001:(1) | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3E00 | IC16CON <sup>(1)</sup> | 15:0 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | ICTMR | ICI< | 1:0> | ICOV | ICBNE | | ICM<2:0> | | 0000 | | 3E10 | IC16BUF | 31:16<br>15:0 | | IC16BUF<31:0> xxxx xxxx | | | | | | | | | | | | | | | | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:This register has corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. ### REGISTER 18-1: ICXCON: INPUT CAPTURE 'x' CONTROL REGISTER ('x' = 1-16) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|----------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | | _ | _ | _ | _ | _ | | 00.46 | U-0 | 23:16 | _ | _ | - | - | _ | - | _ | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | ON | _ | SIDL | _ | _ | _ | FEDGE | C32 | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R-0 | R-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | ICTMR <sup>(1)</sup> | ICI< | 1:0> | ICOV | ICBNE | ICM<2:0> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit -n = Bit Value at POR: ('0', '1', x = unknown) P = Programmable bit r = Reserved bit bit 31-16 Unimplemented: Read as '0' bit 15 **ON:** Input Capture Module Enable bit 1 = Module enabled 0 = Disable and reset module, disable clocks, disable interrupt generation and allow SFR modifications bit 14 **Unimplemented:** Read as '0' bit 13 SIDL: Stop in Idle Control bit 1 = Halt in CPU Idle mode 0 = Continue to operate in CPU Idle mode bit 12-10 Unimplemented: Read as '0' bit 9 FEDGE: First Capture Edge Select bit (only used in mode 6, ICM<2:0> = 110) 1 = Capture rising edge first0 = Capture falling edge first bit 8 C32: 32-bit Capture Select bit 1 = 32-bit timer resource capture 0 = 16-bit timer resource capture bit 7 ICTMR: Timer Select bit (Does not affect timer selection when C32 (ICxCON<8>) is '1')(1) 0 = Timery is the counter source for capture 1 = Timerx is the counter source for capture bit 6-5 ICI<1:0>: Interrupt Control bits 11 = Interrupt on every fourth capture event 10 = Interrupt on every third capture event 01 = Interrupt on every second capture event 00 = Interrupt on every capture event bit 4 ICOV: Input Capture Overflow Status Flag bit (read-only) 1 = Input capture overflow occurred0 = No input capture overflow occurred bit 3 ICBNE: Input Capture Buffer Not Empty Status bit (read-only) 1 = Input capture buffer is not empty; at least one more capture value can be read 0 = Input capture buffer is empty Note 1: Refer to Table for Timerx and Timery selections. ### REGISTER 18-1: ICXCON: INPUT CAPTURE 'x' CONTROL REGISTER ('x' = 1-16) (CONTINUED) bit 2-0 ICM<2:0>: Input Capture Mode Select bits - 111 = Interrupt-Only mode (only supported while in Sleep mode or Idle mode) - 110 = Simple Capture Event mode every edge, specified edge first and every edge thereafter - 101 = Prescaled Capture Event mode every sixteenth rising edge - 100 = Prescaled Capture Event mode every fourth rising edge - 011 = Simple Capture Event mode every rising edge - 010 = Simple Capture Event mode every falling edge - 001 = Edge Detect mode every edge (rising and falling) - 000 = Input Capture module is disabled Note 1: Refer to Table for Timerx and Timery selections. ### 19.0 OUTPUT COMPARE Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 16. "Output Compare" (DS60001111), which available from the Documentation section Reference Manual of the PIC32 Microchip web site (www.microchip.com/pic32). The Output Compare module is used to generate a single pulse or a train of pulses in response to selected time base events. For all modes of operation, the Output Compare module compares the values stored in the OCxR and/or the OCxRS registers to the value in the selected timer. When a match occurs, the Output Compare module generates an event based on the selected mode of operation. The following are key features of the Output Compare: - · Multiple Output Compare modules in a device - Programmable interrupt generation on compare event - · Single and Dual Compare modes - · Single and continuous output pulse generation - · Pulse-Width Modulation (PWM) mode - Hardware-based PWM Fault detection and automatic output disable - Programmable selection of 16-bit or 32-bit time bases - Can operate from either of two available 16-bit time bases or a single 32-bit time base - · ADC event trigger for OC1 through OC4 #### FIGURE 19-1: OUTPUT COMPARE MODULE BLOCK DIAGRAM Note 1:Where 'x' is shown, reference is made to the registers associated with the respective output compare channels, 1 through 9. - 2: The OCFA pin controls the OCMP1-OCMP3, OCMP7-OCMP9, and OCMP13-OCMP15 channels. The OCFB pin controls the OCMP4-OCMP6, OCMP10-OCMP12, and OCMP16 channels. - 3: Refer to Table 19-1 for Timerx and Timery selections - **4:** The ADC event trigger is only available on OC1 through OC4. - 5: PBCLK2 = Output Compare 1 through Output Compare 9; PBCLK3 = Output Compare 10 through Output Compare 16. The timer source for each Output Compare module depends on the setting of the OCACLK bit in the CFGCON register, the OC32 bit in the OCxCON register, and the OCTSEL bit in the OCxCON register. The available configurations are shown in Table 19-1. **TABLE 19-1: TIMER SOURCE CONFIGURATIONS** | OCx | OCACLK<br>CFGCON<16> | OC32<br>(OCxCON<5> | OCTSEL<br>OCxCON<3> | Timerx | Timery | Output<br>Compare<br>Timer Source | | |-----------|----------------------|--------------------|---------------------|------------|------------|-----------------------------------|--| | OC1-OC3 | 0 | | 0 | TMR2<15:0> | _ | TMR2<15:0> | | | | 0 | 0 | 1 | _ | TMR3<15:0> | TMR3<15:0> | | | | 0 | 1 | 0 | TMR2<31:0> | _ | TMR2<31:0> | | | | 0 | 1 | 1 | _ | TMR2<31:0> | TMR2<31:0> | | | | 1 | 0 | 0 | TMR4<15:0> | _ | TMR4<15:0> | | | | 1 | 0 | 1 | _ | TMR5<15:0> | TMR5<15:0> | | | | 1 | 1 | 0 | TMR4<31:0> | _ | TMR4<31:0> | | | | 1 | 1 | 1 | _ | TMR4<31:0> | TMR4<31:0> | | | OC4-OC6, | _ | | 0 | TMR2<15:0> | _ | TMR2<15:0> | | | OC13-OC16 | 0 | 0 | 1 | _ | TMR3<15:0> | TMR3<15:0> | | | | 0 | 1 | 0 | TMR2<31:0> | _ | TMR2<31:0> | | | | 0 | 1 | 1 | _ | TMR2<31:0> | TMR2<31:0> | | | | | | 0 | TMR2<15:0> | _ | TMR2<15:0> | | | | 1 | 0 | 1 | _ | TMR3<15:0> | TMR3<15:0> | | | | | | 0 | TMR2<31:0> | _ | TMR2<31:0> | | | | 1 | 1 | 1 | _ | TMR2<31:0> | TMR2<31:0> | | | OC7-OC9 | 0 | | 0 | TMR2<15:0> | _ | TMR2<15:0> | | | | 0 | 0 | 1 | _ | TMR3<15:0> | TMR3<15:0> | | | | 0 | 1 | 0 | TMR2<31:0> | _ | TMR2<31:0> | | | | 0 | 1 | 1 | _ | TMR2<31:0> | TMR2<31:0> | | | | | | 0 | TMR6<15:0> | _ | TMR6<15:0> | | | | 1 | 0 | 1 | _ | TMR7<15:0> | TMR7<15:0> | | | | 1 | 1 | 0 | TMR6<31:0> | _ | TMR6<31:0> | | | | 1 | 1 | 1 | _ | TMR6<31:0> | TMR6<31:0> | | | OC10-OC12 | 0 | | 0 | TMR2<15:0> | _ | TMR2<15:0> | | | | 0 | 0 | 1 | _ | TMR3<15:0> | TMR3<15:0> | | | | | - | 0 | TMR2<31:0> | _ | TMR2<31:0> | | | | 0 | 1 | 1 | _ | TMR2<31:0> | TMR2<31:0> | | | | 4 | | 0 | TMR8<15:0> | _ | TMR8<15:0> | | | | 1 | 0 | 1 | _ | TMR9<15:0> | TMR9<15:0> | | | | 1 | - | 0 | TMR8<31:0> | TMR8<31:0> | | | | | 1 | 1 | 1 | _ | TMR8<31:0> | TMR8<31:0> | | ### 19.1 Output Compare Control Registers ### TABLE 19-2: OUTPUT COMPARE 1 THROUGH OUTPUT COMPARE 9 REGISTER MAP | sse | | | | | | | | | | Bi | ts | | | | | | | | | |---------------------------|---------------------------------|---------------|------------|-------------|-----------|-------|-------|-------|------|-------|---------|------|-----------|------------|--------|------|----------|------|------------| | Virtual Address<br>BF82_# | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 4000 | OC1CON | 31:16<br>15:0 | —<br>ON | _ | —<br>SIDL | | _ | | | | _ | _ | —<br>OC32 | —<br>OCFLT | OCTSEL | _ | OCM<2:0> | _ | 0000 | | 4010 | OC1R | 31:16<br>15:0 | - | OC1R<31:0> | | | | | | | | | | XXXX | | | | | | | 4020 | OC1RS | 31:16<br>15:0 | | OC1RS<31:0> | | | | | | | | | | xxxx | | | | | | | 4200 | OC2CON | 31:16<br>15:0 | ON | | - SIDL | | | | | | | | —<br>OC32 | OCFLT | OCTSEL | _ | OCM<2:0> | _ | 0000 | | 4210 | OC2R | 31:16<br>15:0 | 0.1 | OC2R<31:0> | | | | | | | | | XXXX | | | | | | | | 4220 | OC2RS | 31:16<br>15:0 | | OC2RS<31:0> | | | | | | | | | xxxx | | | | | | | | 4400 | OC3CON | 31:16<br>15:0 | ON | _ | - SIDL | _ | _ | | | | _ | _ | —<br>OC32 | OCFLT | OCTSEL | _ | OCM<2:0> | _ | 0000 | | 4410 | OC3R | 31:16<br>15:0 | | | | | | | | OC3R | <31:0> | | | | | | | | xxxx | | 4420 | OC3RS | 31:16<br>15:0 | | | | | | | | OC3RS | 5<31:0> | | | | | | | | xxxx | | 4600 | OC4CON | 31:16<br>15:0 | ON | _ | - SIDL | _ | _ | _ | _ | _ | _ | _ | —<br>OC32 | OCFLT | OCTSEL | _ | OCM<2:0> | _ | 0000 | | 4610 | OC4R | 31:16<br>15:0 | | | | | | | | OC4R | <31:0> | | | | | | | | xxxx | | 4620 | OC4RS | 31:16<br>15:0 | | | | | | | | OC4RS | S<31:0> | | | | | | | | xxxx | | 4800 | OC5CON | 31:16<br>15:0 | ON | | | | | | | | | | | | | | | | | | 4810 | OC5R | 31:16<br>15:0 | OC5R<31:0> | | | | | | | | | | | xxxx | | | | | | | 4820 | OC5RS | 31:16<br>15:0 | | | | | | | | OC5RS | S<31:0> | | | | | | | | xxxx | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 19-2: OUTPUT COMPARE 1 THROUGH OUTPUT COMPARE 9 REGISTER MAP (CONTINUED) | sse | | | | | | | | | | В | ts | | | | | | | | | |---------------------------|---------------------------------|---------------|--------------------------------------|--------------------------------------|-------|-------|-------|-------|------|-------|---------|------|------|-------|--------|------|----------|------|------------| | Virtual Address<br>BF82_# | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 4A00 | OC6CON | 31:16 | _ | _ | _ | 1 | 1 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | ON | ON - SIDL OC32 OCFLT OCTSEL OCM<2:0> | | | | | | | | | | | 0000 | | | | | | 4A10 | OC6R | 31:16<br>15:0 | | OC6R<31:0> xxxx xxxx | | | | | | | | | | | | XXXX | | | | | 4A20 | OC6RS | 31:16<br>15:0 | | OC6RS<31:0> | | | | | | | | | | _ | | | | | | | 4C00 | OC7CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 4000 | 0070011 | 15:0 | ON - SIDL OC32 OCFLT OCTSEL OCM<2:0> | | | | | | | | | | 0000 | | | | | | | | 4C10 | OC7R | 31:16<br>15:0 | UC/R<31:0> | | | | | | | | | | XXXX | | | | | | | | 4C20 | OC7RS | 31:16<br>15:0 | | | | | | | | OC7RS | S<31:0> | | | | | | | | XXXX | | 4E00 | OC8CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 4E00 | OCOCON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | OC32 | OCFLT | OCTSEL | | OCM<2:0> | | 0000 | | 4E10 | OC8R | 31:16<br>15:0 | | | | | | | | OC8R | <31:0> | | | | | | | | XXXX | | 4E20 | OC8RS | 31:16<br>15:0 | | | | | | | | OC8RS | 5<31:0> | | | | | | | | XXXX | | 5000 | OC9CON | 31:16 | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3000 | OCSCON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | OC32 | OCFLT | OCTSEL | | OCM<2:0> | | 0000 | | 5010 | OC9R | 31:16<br>15:0 | | OC9R<31:0> | | | | | | | | | | | XXXX | | | | | | 5020 | OC9RS | 31:16<br>15:0 | | OC9RS<31:0> xxxx | | | | | | | | | | | | | | | | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. | TARI F 19-3. | OUTPUT COMPARE 10 THROUGH OUTPUT COMPARE 16 REGISTER MAP | |--------------|----------------------------------------------------------| | IADLE 13-3. | OUTPUT COMPARE TO THROUGH OUTPUT COMPARE TO REGISTER MAP | | ess | | • | | | | | | | | Ві | ts | | | | | | | | ω. | |---------------------------|---------------------------------|---------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|------|-------|---------|------|------|-------|------------------------------------------------|------|----------|------|------------| | Virtual Address<br>BF84_# | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | OC10CON | 31:16 | 1 | _ | _ | 1 | 1 | 1 | _ | - | 1 | - | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | 00100011 | 15:0 | ON | ON — SIDL — — — — — OC32 OCFLT OCTSEL OCM<2:0> 0 | | | | | | | | | | | 0000 | | | | | | 5210 | OC10R | 31:16<br>15:0 | | OC10R<31:0> | | | | | | | | | | | xxxx | | | | | | 5220 | OC10RS | 31:16<br>15:0 | | OC10RS<31:0> | | | | | | | | | | | xxxx | | | | | | 5400 | 004400N | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 5400 | OC11CON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | OC32 | OCFLT | OCTSEL | | OCM<2:0> | | 0000 | | 5410 | OC11R | 31:16<br>15:0 | | | | | | | | OC11R | <31:0> | | | | | | | | xxxx | | 5420 | OC11RS | 31:16<br>15:0 | | OC11RS<31:0> | | | | | | | | | | xxxx | | | | | | | 5000 | 0040004 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 5600 | OC12CON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | OC32 | OCFLT | OCTSEL | | OCM<2:0> | | 0000 | | 5610 | OC12R | 31:16<br>15:0 | | | | | | | | OC12R | <31:0> | | | | | | | | xxxx | | 5620 | OC12RS | 31:16<br>15:0 | | | | | | | | OC12R | S<31:0> | | | | | | | | xxxx | | 5000 | 00400011 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 5800 | OC13CON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | OC32 | OCFLT | OCTSEL | | OCM<2:0> | | 0000 | | 5810 | OC13R | 31:16<br>15:0 | | | | | | | | OC13R | <31:0> | | | | | | | | xxxx | | 5820 | OC13RS | 31:16<br>15:0 | | | | | | | | OC13R | S<31:0> | | | | | | | | xxxx | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 5A00 | OC14CON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | OC32 | OCFLT | OCTSEL | | OCM<2:0> | | 0000 | | 5A10 | OC14R | 31:16 | | | ı | | | | | 00145 | z21.0> | | ı | | <u>. </u> | | | | xxxx | | DATU | UC 14R | 15:0 | OC14R<31:0> | | | | | | | | | | | XXXX | | | | | | | 5A20 | OC14RS | 31:16<br>15:0 | | | | | _ | | | OC14R | S<31:0> | | | _ | | | | | xxxx | | | | | | | | | tol D | | | | | | | | | | | | | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 19-3: OUTPUT COMPARE 10 THROUGH OUTPUT COMPARE 16 REGISTER MAP (CONTINUED) | ess | | Ф | | | | | | | | В | its | | | | | | | | ø | |---------------------------|---------|---------------|------------------|-------------------------------------------|-------|-------|-------|-------|------|--------|-------------|------|------|-------|--------|------|----------|------|------------| | Virtual Address<br>BF84_# | | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 5000 | OC15CON | 31:16 | _ | | 1 | _ | 1 | _ | 1 | 1 | _ | _ | 1 | _ | _ | _ | _ | 1 | 0000 | | 3000 | OCISCON | 15:0 | ON | ON - SIDL OC32 OCFLT OCTSEL OCM<2:0> 0000 | | | | | | | | | | | 0000 | | | | | | 5C10 | OC15R | 31:16 | 6<br>OC15R<31:0> | | | | | | | | | xxxx | | | | | | | | | 3010 | OCISIC | 15:0 | | | | | | | | 00131 | ( \ 0 1.0 > | | | | | | | | xxxx | | 5C20 | OC15RS | 31:16 | | | | | | | | OC15R | S<31:0> | | | | | | | | xxxx | | 3020 | 001010 | 15:0 | | | | | | | | 001310 | 0 1.02 | | | | | | | | xxxx | | 5E00 | OC16CON | 31:16 | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 3200 | OCTOCON | 15:0 | ON | _ | SIDL | _ | _ | _ | _ | _ | _ | _ | OC32 | OCFLT | OCTSEL | | OCM<2:0> | | 0000 | | 5E10 | OC16R | 31:16 | | | | | | | | 00165 | 2/31:0> | | | | | | | | xxxx | | JE 10 | COTOR | 15:0 | OC16R<31:0> | | | | | | | | | | | xxxx | | | | | | | 5E20 | OC16RS | 31:16<br>15:0 | | OC16RS<31:0> xxxx | | | | | | | | | | xxxx | | | | | | **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information PIC32MK GPK/MCM with CAN FD Family ### REGISTER 19-1: OCxCON: OUTPUT COMPARE 'x' CONTROL REGISTER ('x' = 1-16) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|----------------------|-----------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | - | _ | _ | | 00.40 | U-0 | 23:16 | _ | _ | ı | _ | | ı | _ | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 15:8 | ON | _ | SIDL | _ | _ | - | _ | _ | | 7.0 | U-0 | U-0 | R/W-0 | R-0, HS, HC | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | _ | OC32 | OCFLT <sup>(1)</sup> | OCTSEL <sup>(2)</sup> | OCM<2:0> | | | Legend:HS = Set in hardwareHC = Cleared by hardwareR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 ON: Output Compare Peripheral On bit 1 = Output Compare peripheral is enabled 0 = Output Compare peripheral is disabled **Unimplemented:** Read as '0' bit 13 SIDL: Stop in Idle Mode bit bit 14 1 = Discontinue operation when CPU enters Idle mode 0 = Continue operation in Idle mode bit 12-6 Unimplemented: Read as '0' bit 5 OC32: 32-bit Compare Mode bit 1 = OCxR<31:0> and/or OCxRS<31:0> are used for comparisons to the 32-bit timer source 0 = OCxR<15:0> and OCxRS<15:0> are used for comparisons to the 16-bit timer source bit 4 OCFLT: PWM Fault Condition Status bit<sup>(1)</sup> 1 = PWM Fault condition has occurred (cleared in HW only) 0 = No PWM Fault condition has occurred bit 3 OCTSEL: Output Compare Timer Select bit<sup>(2)</sup> 1 = Timery is the clock source for this Output Compare module 0 = Timerx is the clock source for this Output Compare module bit 2-0 OCM<2:0>: Output Compare Mode Select bits 111 = PWM mode on OCx; Fault pin enabled 110 = PWM mode on OCx; Fault pin disabled 101 = Initialize OCx pin low; generate continuous output pulses on OCx pin 100 = Initialize OCx pin low; generate single output pulse on OCx pin 011 = Compare event toggles OCx pin 010 = Initialize OCx pin high; compare event forces OCx pin low 001 = Initialize OCx pin low; compare event forces OCx pin high 000 = Output compare peripheral is disabled but continues to draw current **Note 1:** This bit is only used when OCM<2:0> = '111'. It is read as '0' in all other modes. 2: Refer to Table 19-1 for Timerx and Timery selections. | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 20.0 SERIAL PERIPHERAL INTERFACE (SPI) AND INTER-IC SOUND (I<sup>2</sup>S) Note: This the data sheet summarizes features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 23. "Serial Peripheral Interface (SPI)" (DS60001106), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The SPI/I<sup>2</sup>S module is a synchronous serial interface that is useful for communicating with external peripherals and other microcontroller devices, as well as digital audio devices. These peripheral devices may be Serial EEPROMs, Shift registers, display drivers, analog-to-digital converters (ADC), etc. The SPI/I<sup>2</sup>S module is compatible with Motorola<sup>®</sup> SPI and SIOP interfaces. The following key features of the SPI module: - · Host and Client modes support - · Four different clock formats - · Enhanced Framed SPI protocol support - User-configurable 32/24/16/8-bit data width - · Separate SPI FIFO buffers for receive and transmit - FIFO buffers act as 4/8/16-level deep FIFOs based on 32/24/16/8-bit data width - Programmable interrupt event on every 8-bit, 16-bit and 32-bit data transfer - · Operation during Sleep and Idle modes - · Audio codec support: FIGURE 20-1: SPI/I<sup>2</sup>S MODULE BLOCK DIAGRAM ### 20.1 SPI Control Registers ### TABLE 20-1: SPI1 AND SPI2 REGISTER MAP | ess | | • | | | | | | | | Bi | ts | | | | | | | | | |-----------------------------|---------------------------------|-------------------------------------------|---------------|---------|--------|--------------|--------------|--------------|-----------|--------|---------|----------|--------|--------|-------------|----------|--------|---------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 7000 | SPI1CON | 31:16 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | FF | RMCNT<2:0 | )> | MCLKSEL | _ | _ | _ | _ | | SPIFE | ENHBUF | 0000 | | 7000 | SPITCON | 15:0 | ON | _ | SIDL | DISSDO | MODE32 | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | DISSDI | STXISE | L<1:0> | SRXISE | EL<1:0> | 0000 | | 7010 | SPI1STAT | 31:16 | _ | _ | - | | RXE | SUFELM<4: | 0> | | _ | _ | _ | | TXI | BUFELM<4 | 1:0> | | 0000 | | 7010 | SPITSTAL | 15:0 | _ | _ | - | FRMERR | SPIBUSY | _ | - | SPITUR | SRMT | SPIROV | SPIRBE | _ | SPITBE | - | SPITBF | SPIRBF | 0028 | | 7020 | SPI1BUF | BUE ├──────────────────────────────────── | | | | | | | | 0000 | | | | | | | | | | | . 020 | | 15:0 | | | | | | | | | 1 | ı | 1 | 1 | 1 | | | 1 | 0000 | | 7030 | SPI1BRG | 31:16 | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | | | | | В | RG<12:0> | 1 | 1 | 1 | | | | 0000 | | | | 31:16 | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 7040 | SPI1CON2 | 15:0 | SPI<br>SGNEXT | _ | _ | FRM<br>ERREN | SPI<br>ROVEN | SPI<br>TUREN | IGNROV | IGNTUR | AUDEN | _ | _ | _ | AUD<br>MONO | _ | AUDMO | D<1:0> | 0000 | | 7000 | SPI2CON | 31:16 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | FF | RMCNT<2:0 | )> | MCLKSEL | _ | _ | _ | _ | _ | SPIFE | ENHBUF | 0000 | | 7200 | SPIZCON | 15:0 | ON | _ | SIDL | DISSDO | MODE32 | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | DISSDI | STXISE | L<1:0> | SRXISE | EL<1:0> | 0000 | | 7040 | SPI2STAT | 31:16 | _ | _ | _ | | RXE | SUFELM<4: | 0> | | _ | _ | _ | | TXI | BUFELM<4 | l:0> | | 0000 | | 7210 | SPIZSTAT | 15:0 | _ | _ | _ | FRMERR | SPIBUSY | 1 | _ | SPITUR | SRMT | SPIROV | SPIRBE | _ | SPITBE | _ | SPITBF | SPIRBF | 0028 | | 7000 | SPI2BUF | DATA<31:0> | | | | | | | | | 0000 | | | | | | | | | | 7220 | SPIZBUF | 15:0 | | | | | | | | DATAS | 31:0> | | | | | | | | 0000 | | 7230 | SPI2BRG | 31:16 | _ | _ | | - | _ | _ | - | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 1230 | OF IZDING | 15:0 | _ | _ | _ | | | | | | В | RG<12:0> | | | | | | | 0000 | | | | 31:16 | _ | _ | | - | _ | _ | - | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | 7240 | SPI2CON2 | 15:0 | SPI<br>SGNEXT | _ | | FRM<br>ERREN | SPI<br>ROVEN | SPI<br>TUREN | IGNROV | IGNTUR | AUDEN | _ | _ | _ | AUD<br>MONO | 1 | AUDMO | )D<1:0> | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table except SPIxBUF have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 20-2: SPI3 THROUGH SPI6 REGISTER MAP | ess | | 4 | | | | | | | | Bit | ts | | | | | | | | " | |-----------------------------|---------------------------------|---------------|---------------|---------|--------|--------------|--------------|--------------|----------|--------|---------|----------|--------|--------|-------------|----------|--------|---------|------------| | Virtual Address<br>(BF84_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | SPI3CON | 31:16 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | FF | RMCNT<2: | )> | MCLKSEL | _ | _ | _ | _ | _ | SPIFE | ENHBUF | 0000 | | 7400 | SPISCON | 15:0 | ON | _ | SIDL | DISSDO | MODE32 | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | DISSDI | STXISE | EL<1:0> | SRXISI | EL<1:0> | 0000 | | 7440 | SPI3STAT | 31:16 | _ | _ | | | RXE | BUFELM<4: | 0> | | _ | _ | _ | | TXI | BUFELM<4 | 1:0> | | 0000 | | 7410 | 3F133 1A1 | 15:0 | _ | _ | | FRMERR | SPIBUSY | | | SPITUR | SRMT | SPIROV | SPIRBE | _ | SPITBE | _ | SPITBF | SPIRBF | 0028 | | 7420 | SPI3BUF | 31:16<br>15:0 | | | | | | | | DATA< | :31:0> | | | | | | | | 0000 | | 7400 | SPI3BRG | 31:16 | _ | _ | - | 1 | _ | I | ı | 1 | _ | _ | _ | _ | | _ | _ | _ | 0000 | | 7430 | SPISBRG | 15:0 | _ | _ | - | | | | | | В | RG<12:0> | | | | | | | 0000 | | | | 31:16 | _ | _ | - | 1 | _ | I | ı | 1 | _ | _ | _ | _ | | _ | _ | _ | 0000 | | 7440 | SPI3CON2 | 15:0 | SPI<br>SGNEXT | | 1 | FRM<br>ERREN | SPI<br>ROVEN | SPI<br>TUREN | IGNROV | IGNTUR | AUDEN | _ | _ | _ | AUD<br>MONO | _ | AUDMO | )D<1:0> | 0000 | | 7600 | SPI4CON | 31:16 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | FF | RMCNT<2: | )> | MCLKSEL | _ | _ | _ | - | _ | SPIFE | ENHBUF | 0000 | | 7600 | 3F14CON | 15:0 | ON | _ | SIDL | DISSDO | MODE32 | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | DISSDI | STXISE | EL<1:0> | SRXISI | EL<1:0> | 0000 | | 7610 | SPI4STAT | 31:16 | _ | | | | RXE | BUFELM<4: | 0> | | - | _ | _ | | TXI | BUFELM<4 | | | 0000 | | 7610 | 3F143 IAI | 15:0 | _ | | | FRMERR | SPIBUSY | 1 | | SPITUR | SRMT | SPIROV | SPIRBE | _ | SPITBE | _ | SPITBF | SPIRBF | 0028 | | 7620 | SPI4BUF | 31:16<br>15:0 | | | | | | | | DATA< | 31:0> | | | | | | | | 0000 | | 7000 | SPI4BRG | 31:16 | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 7630 | SF14BRG | 15:0 | _ | _ | _ | | | | | | В | RG<12:0> | | | | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 7640 | SPI4CON2 | 15:0 | SPI<br>SGNEXT | - | - | FRM<br>ERREN | SPI<br>ROVEN | SPI<br>TUREN | IGNROV | IGNTUR | AUDEN | _ | _ | _ | AUD<br>MONO | _ | AUDMO | D<1:0> | 0000 | | 7000 | CDICOON | 31:16 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | FF | RMCNT<2: | )> | MCLKSEL | _ | _ | _ | _ | _ | SPIFE | ENHBUF | 0000 | | 7800 | SPI5CON | 15:0 | ON | _ | SIDL | DISSDO | MODE32 | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | DISSDI | STXISE | L<1:0> | SRXISI | EL<1:0> | 0000 | | 7040 | CDIECTAT | 31:16 | _ | _ | _ | | RXE | BUFELM<4: | 0> | | _ | _ | _ | | TXI | BUFELM<4 | 1:0> | | 0000 | | 7810 | SPI5STAT | 15:0 | _ | _ | _ | FRMERR | SPIBUSY | _ | _ | SPITUR | SRMT | SPIROV | SPIRBE | _ | SPITBE | _ | SPITBF | SPIRBF | 0028 | | 7820 | SPI5BUF | 31:16<br>15:0 | | | | | | | | DATA< | 31:0> | | | | | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 7830 | SPI5BRG | 15:0 | _ | _ | _ | | | | | | В | RG<12:0> | | | | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 7840 | SPI5CON2 | 15:0 | SPI<br>SGNEXT | _ | _ | FRM<br>ERREN | SPI<br>ROVEN | SPI<br>TUREN | IGNROV | IGNTUR | AUDEN | _ | _ | _ | AUD<br>MONO | _ | AUDMO | )D<1:0> | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table except SPIxBUF have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. ### TABLE 20-2: SPI3 THROUGH SPI6 REGISTER MAP (CONTINUED) | ess | | • | | | | | | | | Bi | ts | | | | | | | | | |-----------------------------|---------------------------------|---------------|---------------|---------|--------|--------------|--------------|--------------|-----------|--------|---------|--------|--------|--------|-------------|----------|--------|---------|------------| | Virtual Address<br>(BF84_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 7400 | SPI6CON | 31:16 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | FF | RMCNT<2:0 | )> | MCLKSEL | _ | _ | _ | _ | _ | SPIFE | ENHBUF | 0000 | | 7A00 | SFIOCON | 15:0 | ON | _ | SIDL | DISSDO | MODE32 | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | DISSDI | STXISE | EL<1:0> | SRXISE | EL<1:0> | 0000 | | 7440 | SPI6STAT | 31:16 | _ | _ | _ | | RXE | BUFELM<4: | 0> | | _ | _ | _ | | TXI | BUFELM<4 | 1:0> | | 0000 | | 7A10 | 3F1031K1 | 15:0 | _ | _ | - | FRMERR | SPIBUSY | I | ı | SPITUR | SRMT | SPIROV | SPIRBE | I | SPITBE | _ | SPITBF | SPIRBF | 0028 | | 7A20 | SPI6BUF | 31:16<br>15:0 | | | | | | | | DATA< | :31:0> | | | | | | | | 0000 | | 7400 | CDICDDC | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 7A30 | SPI6BRG | 15:0 | BRG<12:0> | | | | | | | | | | 0000 | | | | | | | | | | 31:16 | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 7A40 | SPI6CON2 | 15:0 | SPI<br>SGNEXT | _ | _ | FRM<br>ERREN | SPI<br>ROVEN | SPI<br>TUREN | IGNROV | IGNTUR | AUDEN | _ | _ | | AUD<br>MONO | _ | AUDMO | D<1:0> | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table except SPIxBUF have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PIC32MK GPK/MCM with CAN FD Family #### REGISTER 20-1: SPIXCON: SPI CONTROL REGISTER (X=1-6) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|--------------------|-------------------|-----------------------|-------------------|-------------------|------------------|-----------------------| | 24.24 | R/W-0 | 31:24 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | F | RMCNT<2:0 | > | | 00.40 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 23:16 | MCLKSEL <sup>(1)</sup> | _ | _ | _ | _ | _ | SPIFE | ENHBUF <sup>(1)</sup> | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15:8 | ON | _ | SIDL | DISSDO <sup>(4)</sup> | MODE32 | MODE16 | SMP | CKE <sup>(2)</sup> | | 7.0 | R/W-0 | 7:0 | SSEN | CKP <sup>(3)</sup> | MSTEN | DISSDI <sup>(4)</sup> | STXISE | L<1:0> | SRXIS | EL<1:0> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown - bit 31 FRMEN: Framed SPI Support bit - 1 = Framed SPI support is enabled ( $\overline{SSx}$ pin used as FSYNC input/output) - 0 = Framed SPI support is disabled - bit 30 FRMSYNC: Frame Sync Pulse Direction Control on SSx pin bit (Framed SPI mode only) - 1 = Frame sync pulse input (Client mode) - 0 = Frame sync pulse output (Host mode) - bit 29 FRMPOL: Frame Sync Polarity bit (Framed SPI mode only) - 1 = Frame pulse is active-high - 0 = Frame pulse is active-low - bit 28 MSSEN: Host Mode SPI Select Enable bit - 1 = SPI select support enabled. The SS pin is automatically driven during transmission in Host mode. Polarity is determined by the FRMPOL bit. - 0 = SPI select support is disabled. - bit 27 FRMSYPW: Frame Sync Pulse Width bit - 1 = Frame sync pulse is one character wide - 0 = Frame sync pulse is one clock wide - bit 26-24 **FRMCNT<2:0>:** Frame Sync Pulse Counter bits. Controls the number of data characters transmitted per pulse. This bit is only valid in Framed mode. - 111 = Reserved - 110 = Reserved - 101 = Generate a frame sync pulse on every 32 data characters - 100 = Generate a frame sync pulse on every 16 data characters - 011 = Generate a frame sync pulse on every 8 data characters - 010 = Generate a frame sync pulse on every 4 data characters - 001 = Generate a frame sync pulse on every 2 data characters - 000 = Generate a frame sync pulse on every data character - bit 23 MCLKSEL: Host Clock Enable bit<sup>(1)</sup> - 1 = REFCLKO1 is used by the Baud Rate Generator - 0 = PBCLK2 is used by the Baud Rate Generator for SPI1 and SPI2 or PBCLK3 if SPI3 through SPI6 - bit 22-18 Unimplemented: Read as '0' - **Note 1:** This bit can only be written when the ON bit = 0. Refer to **37.0** "Electrical Characteristics" for maximum clock frequency requirements. - 2: This bit is not used in the Framed SPI mode. The user should program this bit to '0' for the Framed SPI mode (FRMEN = 1). - **3:** When AUDEN = 1, the SPI/I<sup>2</sup>S module functions as if the CKP bit is equal to '1', regardless of the actual value of the CKP bit. - 4: This bit present for legacy compatibility and is superseded by PPS functionality on these devices (see 13.3 "Peripheral Pin Select (PPS)" for more information). ### REGISTER 20-1: SPIxCON: SPI CONTROL REGISTER (X=1-6\_) (CONTINUED) SPIFE: Frame Sync Pulse Edge Select bit (Framed SPI mode only) 1 = Frame synchronization pulse coincides with the first bit clock 0 = Frame synchronization pulse precedes the first bit clock ENHBUF: Enhanced Buffer Enable bit(1) bit 16 1 = Enhanced Buffer mode is enabled 0 = Enhanced Buffer mode is disabled ON: SPI/I<sup>2</sup>S Module On bit bit 15 $1 = SPI/I^2S$ module is enabled 0 = SPI/I<sup>2</sup>S module is disabled Unimplemented: Read as '0' bit 14 bit 13 SIDL: Stop in Idle Mode bit 1 = Discontinue operation when CPU enters in Idle mode 0 = Continue operation in Idle mode DISSDO: Disable SDOx pin bit(4) bit 12 1 = SDOx pin is not used by the module. Pin is controlled by associated PORT register 0 = SDOx pin is controlled by the module bit 11-10 MODE<32,16>: 32/16-Bit Communication Select bits When AUDEN = 1: MODE32 MODE16 Communication 24-bit Data, 32-bit FIFO, 32-bit Channel/64-bit Frame 10 32-bit Data, 32-bit FIFO, 32-bit Channel/64-bit Frame 16-bit Data, 16-bit FIFO, 32-bit Channel/64-bit Frame 00 16-bit Data, 16-bit FIFO, 16-bit Channel/32-bit Frame When AUDEN = 0: MODE32 MODE16 Communication 1x 32-bit 01 **16-bit** 00 **8-bit** bit 9 SMP: SPI Data Input Sample Phase bit Host mode (MSTEN = 1): 1 = Input data sampled at end of data output time 0 = Input data sampled at middle of data output time Client mode (MSTEN = 0): SMP value is ignored when SPI is used in Client mode. The module always uses SMP = 0. CKE: SPI Clock Edge Select bit(2) bit 8 1 = Serial output data changes on transition from active clock state to Idle clock state (see CKP bit) 0 = Serial output data changes on transition from Idle clock state to active clock state (see CKP bit) bit 7 SSEN: SPIx Select Enable (Client mode) bit $1 = \overline{SSx}$ pin used for Client mode $0 = \overline{SSx}$ pin not used for Client mode, pin controlled by port function. - bit 6 **CKP:** Clock Polarity Select bit<sup>(3)</sup> - ${\tt 1}$ = Idle state for clock is a high level; active state is a low level - 0 = Idle state for clock is a low level; active state is a high level - **Note 1:** This bit can only be written when the ON bit = 0. Refer to **37.0 "Electrical Characteristics"** for maximum clock frequency requirements. - 2: This bit is not used in the Framed SPI mode. The user should program this bit to '0' for the Framed SPI mode (FRMEN = 1). - 3: When AUDEN = 1, the SPI/I $^2$ S module functions as if the CKP bit is equal to '1', regardless of the actual value of the CKP bit. - 4: This bit present for legacy compatibility and is superseded by PPS functionality on these devices (see 13.3 "Peripheral Pin Select (PPS)" for more information). ### REGISTER 20-1: SPIXCON: SPI CONTROL REGISTER (X=1-6\_) (CONTINUED) - bit 5 MSTEN: Host Mode Enable bit - 1 = Host mode - 0 = Client mode - bit 4 **DISSDI:** Disable SDI bit<sup>(4)</sup> - 1 = SDI pin is not used by the SPI module (pin is controlled by PORT function) - 0 = SDI pin is controlled by the SPI module - bit 3-2 STXISEL<1:0>: SPI Transmit Buffer Empty Interrupt Mode bits - 11 = Interrupt is generated when the buffer is not full (has one or more empty elements) - 10 = Interrupt is generated when the buffer is empty by one-half or more - 01 = Interrupt is generated when the buffer is completely empty - 00 = Interrupt is generated when the last transfer is shifted out of SPISR and transmit operations are complete - bit 1-0 SRXISEL<1:0>: SPI Receive Buffer Full Interrupt Mode bits - 11 = Interrupt is generated when the buffer is full - 10 = Interrupt is generated when the buffer is full by one-half or more - 01 = Interrupt is generated when the buffer is not empty - 00 = Interrupt is generated when the last word in the receive buffer is read (i.e., buffer is empty) - **Note 1:** This bit can only be written when the ON bit = 0. Refer to **37.0** "Electrical Characteristics" for maximum clock frequency requirements. - 2: This bit is not used in the Framed SPI mode. The user should program this bit to '0' for the Framed SPI mode (FRMEN = 1). - **3:** When AUDEN = 1, the SPI/I<sup>2</sup>S module functions as if the CKP bit is equal to '1', regardless of the actual value of the CKP bit. - 4: This bit present for legacy compatibility and is superseded by PPS functionality on these devices (see 13.3 "Peripheral Pin Select (PPS)" for more information). REGISTER 20-2: SPIxCON2: SPI CONTROL REGISTER 2 (X=1-6\_) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|----------------------|-------------------|-------------------|-------------------|--------------------------|-------------------|------------------|------------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | | _ | _ | _ | | 00.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | | 15:8 | SPISGNEXT | _ | _ | FRMERREN | SPIROVEN | SPITUREN | IGNROV | IGNTUR | | 7.0 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | | 7:0 | AUDEN <sup>(1)</sup> | _ | _ | _ | AUDMONO <sup>(1,2)</sup> | _ | AUDMOD | <1:0> <sup>(1,2)</sup> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 SPISGNEXT: Sign Extend Read Data from the RX FIFO bit 1 = Data from RX FIFO is sign extended 0 = Data from RX FIFO is not sign extended bit 14-13 Unimplemented: Read as '0' bit 12 FRMERREN: Enable Interrupt Events via FRMERR bit 1 = Frame Error overflow generates error events 0 = Frame Error does not generate error events bit 11 SPIROVEN: Enable Interrupt Events via SPIROV bit 1 = Receive overflow generates error events 0 = Receive overflow does not generate error events bit 10 SPITUREN: Enable Interrupt Events via SPITUR bit 1 = Transmit Underrun Generates Error Events 0 = Transmit Underrun Does Not Generates Error Events bit 9 IGNROV: Ignore Receive Overflow bit (for Audio Data Transmissions) 1 = A ROV is not a critical error; during ROV data in the FIFO is not overwritten by receive data 0 = A ROV is a critical error which stop SPI operation bit 8 IGNTUR: Ignore Transmit Underrun bit (for Audio Data Transmissions) 1 = A TUR is not a critical error and zeros are transmitted until the SPIxTXB is not empty 0 = A TUR is a critical error which stop SPI operation bit 7 **AUDEN:** Enable Audio CODEC Support bit<sup>(1)</sup> 1 = Audio protocol is enabled 0 = Audio protocol is disabled bit 6-5 **Unimplemented:** Read as '0' bit 3 **AUDMONO:** Transmit Audio Data Format bit<sup>(1,2)</sup> 1 = Audio data is mono (Each data word is transmitted on both left and right channels) 0 = Audio data is stereo bit 2 Unimplemented: Read as '0' bit 1-0 **AUDMOD<1:0>:** Audio Protocol Mode bit<sup>(1,2)</sup> 11 = PCM/DSP mode 10 = Right Justified mode 01 = Left Justified mode $00 = I^2S \text{ mode}$ **Note 1:** This bit can only be written when the ON bit = 0. 2: This bit is only valid for AUDEN = 1. #### REGISTER 20-3: SPIXSTAT: SPI STATUS REGISTER (X=1-6) | | | | | | <u> </u> | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | 24.24 | U-0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 31:24 | _ | _ | _ | | RX | (BUFELM<4:0 | )> | | | 00:40 | U-0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 23:16 | _ | _ | _ | | TX | (BUFELM<4:0 | )> | | | 45.0 | U-0 | U-0 | U-0 | R/C-0, HS | R-0, HS, HC | U-0 | U-0 | R-0 | | 15:8 | _ | _ | _ | FRMERR | SPIBUSY | _ | _ | SPITUR | | 7.0 | R-0, HS, HC | R/C-0, HS | R-1, HS, HC | U-0 | R-1, HS, HC | U-0 | R-0, HS, HC | R-0, HS, HC | | 7:0 | SRMT | SPIROV | SPIRBE | _ | SPITBE | _ | SPITBF | SPIRBF | Legend:HC = Cleared in hardwareHS = Set in hardwareC = Clearable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-29 Unimplemented: Read as '0' bit 28-24 **RXBUFELM<4:0>:** Receive Buffer Element Count bits (valid only when ENHBUF = 1) bit 23-21 Unimplemented: Read as '0' bit 20-16 **TXBUFELM<4:0>:** Transmit Buffer Element Count bits (valid only when ENHBUF = 1) bit 15-13 Unimplemented: Read as '0' bit 12 FRMERR: SPI Frame Error status bit 1 = Frame error is detected0 = No Frame error is detected This bit is only valid when FRMEN = 1. bit 11 SPIBUSY: SPI Activity Status bit 1 = SPI peripheral is currently busy with some transactions 0 = SPI peripheral is currently idle bit 10-9 Unimplemented: Read as '0' bit 8 SPITUR: Transmit Under Run bit 1 = Transmit buffer has encountered an underrun condition 0 = Transmit buffer has no underrun condition This bit is only valid in Framed Sync mode; the underrun condition must be cleared by disabling/re-enabling the module. bit 7 **SRMT:** Shift Register Empty bit (valid only when ENHBUF = 1) 1 = When SPI module shift register is empty 0 = When SPI module shift register is not empty bit 6 SPIROV: Receive Overflow Flag bit 1 = A new data is completely received and discarded. The user software has not read the previous data in the SPIxBUF register. 0 = No overflow has occurred This bit is set in hardware; can only be cleared (= 0) in software. bit 5 **SPIRBE:** RX FIFO Empty bit (valid only when ENHBUF = 1) 1 = RX FIFO is empty (CRPTR = SWPTR) 0 = RX FIFO is not empty (CRPTR ≠ SWPTR) bit 4 **Unimplemented:** Read as '0' ### REGISTER 20-3: SPIXSTAT: SPI STATUS REGISTER (X=1-6\_) - bit 3 SPITBE: SPI Transmit Buffer Empty Status bit - 1 = Transmit buffer, SPIxTXB is empty - 0 = Transmit buffer, SPIxTXB is not empty Automatically set in hardware when SPI transfers data from SPIxTXB to SPIxSR. Automatically cleared in hardware when SPIxBUF is written to, loading SPIxTXB. - bit 2 Unimplemented: Read as '0' - bit 1 SPITBF: SPI Transmit Buffer Full Status bit - 1 = Transmit not yet started, SPITXB is full - 0 = Transmit buffer is not full #### Standard Buffer Mode: Automatically set in hardware when the core writes to the SPIBUF location, loading SPITXB. Automatically cleared in hardware when the SPI module transfers data from SPITXB to SPISR. #### **Enhanced Buffer Mode:** Set when CWPTR + 1 = SRPTR; cleared otherwise - bit 0 SPIRBF: SPI Receive Buffer Full Status bit - 1 = Receive buffer, SPIxRXB is full - 0 = Receive buffer, SPIxRXB is not full #### Standard Buffer Mode: Automatically set in hardware when the SPI module transfers data from SPIxSR to SPIxRXB. Automatically cleared in hardware when SPIxBUF is read from, reading SPIxRXB. #### Enhanced Buffer Mode: Set when SWPTR + 1 = CRPTR; cleared otherwise ### REGISTER 20-4: SPIxBUF: SPIx BUFFER REGISTER ('x' = 1-6) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | R/W-0 | 31:24 | | | | DATA<3 | 1:24> | | | | | 22.46 | R/W-0 | 23:16 | | | | DATA<2 | 3:16> | | | | | 45.0 | R/W-0 | 15:8 | | | | DATA< | 15:8> | | | | | 7.0 | R/W-0 | 7:0 | | | | DATA< | 7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 DATA<31:0> FIFO Data bits When MODE32 or MODE16 selects 32-bit data, the SPI uses DATA<31:0>. When MODE32 or MODE16 selects 24-bit data, the SPI only uses DATA<24:0>. When MODE32 or MODE16 selects 16-bit data, the SPI only uses DATA<15:0>. When MODE32 or MODE16 selects 8-bit data, the SPI only uses DATA<7:0>. ### REGISTER 20-5: SPIXBRG: SPIX BAUD RATE GENERATOR REGISTER ('x' = 1-6) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | | | 15:8 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15.6 | _ | _ | _ | | | BRG<12:8> | | | | 7.0 | R/W-0 | 7:0 | | · | | BRG< | 7:0> | · | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-13 Unimplemented: Read as '0' bit 12-0 BRG<12:0> Baud Rate Generator Divisor bits Baud Rate = FPBCLKx / (2 \* (SPIxBRG + 1)), where 'x' = 2 and 3, (FPBCLK2 for SPI1-SPI2, FPBCLK3 for SPI3-SPI6.) Therefore, the maximum baud rate possible is FPBCLKx / 2 (SPIXBRG = 0) and the minimum baud rate possible is FPBCLKx / 16384. Note: Changing the BRG value when the ON bit is equal to '1' causes undefined behavior. | NOTES: | | | |--------|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 21.0 INTER-INTEGRATED CIRCUIT (I<sup>2</sup>C) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 24.** "InterIntegrated Circuit (I<sup>2</sup>C)" (DS60001116), which is available from the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). The I<sup>2</sup>C module provides complete hardware support for both Client and Multi-Host modes of the I<sup>2</sup>C serial communication standard. Each I<sup>2</sup>C module has a 2-pin interface: - · SCLx pin is clock - · SDAx pin is data Each I<sup>2</sup>C module offers the following key features: - I<sup>2</sup>C interface supporting both host and client operation - I<sup>2</sup>C Client mode supports 7-bit and 10-bit addressing - I<sup>2</sup>C Host mode supports 7-bit and 10-bit addressing - I<sup>2</sup>C port allows bidirectional transfers between host and clients - Serial clock synchronization for the I<sup>2</sup>C port can be used as a handshake mechanism to suspend and resume serial transfer (SCLREL control) - I<sup>2</sup>C supports multi-host operation; detects bus collision and arbitrates accordingly - · Provides support for address bit masking - · SMBus support Figure 21-1 illustrates the I<sup>2</sup>C module block diagram. FIGURE 21-1: I<sup>2</sup>C BLOCK DIAGRAM ### 21.1 I<sup>2</sup>C Control Registers ### TABLE 21-1: I2C1 AND I2C2 REGISTER MAP | SSS | | | | | | | | | | Bi | ts | | | | | | | | | |---------------------------|---------------------------------|-----------|---------|--------|--------|--------|--------|-------|--------|------------|-------------|-------|------------|------------|----------|-------|------|------|------------| | Virtual Address<br>BF82_# | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 6000 | I2C1CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | 0000 | | 0000 | 12010014 | 15:0 | ON | | SIDL | SCLREL | STRICT | _ | DISSLW | SMEN | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | 1000 | | 6010 | I2C1STAT | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0010 | 120101711 | 15:0 | ACKSTAT | TRSTAT | ACKTIM | _ | _ | BCL | GCSTAT | ADD10 | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | 0000 | | 6020 | I2C1ADD | 31:16 | _ | | | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | 12017100 | 15:0 | _ | | _ | _ | _ | _ | | | | | Address | Register | | | | | 0000 | | 6030 | I2C1MSK | 31:16 | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 1201111011 | 15:0 | _ | _ | _ | | _ | | | | | , | Address Ma | sk Registe | r | 1 | | | 0000 | | 6040 | I2C1BRG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | .20.20 | 15:0 | | | ı | | 1 | | Bau | d Rate Gen | erator Regi | ister | | | | 1 | | | 0000 | | 6050 | I2C1TRN | 31:16 | _ | | _ | _ | _ | _ | _ | | _ | _ | _ | | | _ | | | 0000 | | | | 15:0 | _ | | _ | | _ | | _ | _ | | 1 | | Transmit | Register | | | | 0000 | | 6060 | I2C1RCV | 31:16 | | | _ | | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | .20 | 15:0 | _ | | | | _ | | _ | _ | | 1 | | | Register | 1 | | | 0000 | | 6200 | I2C2CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | 0000 | | 0200 | .20200.1 | 15:0 | ON | | SIDL | SCLREL | STRICT | _ | DISSLW | SMEN | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | 1000 | | 6210 | I2C2STAT | 31:16 | _ | - | _ | _ | _ | _ | _ | _ | - | _ | _ | - | _ | _ | - | _ | 0000 | | 0210 | 120201711 | 15:0 | ACKSTAT | TRSTAT | ACKTIM | _ | _ | BCL | GCSTAT | ADD10 | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | 0000 | | 6220 | I2C2ADD | 31:16 | _ | _ | _ | | _ | | — | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0220 | .202, 132 | 15:0 | _ | _ | _ | _ | _ | _ | | | | | Address | Register | | | | | 0000 | | 6230 | I2C2MSK | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | IZOZIIIOIX | 15:0 | _ | _ | _ | | _ | | | | | , | Address Ma | sk Registe | r | 1 | | | 0000 | | 6240 | I2C2BRG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 02.0 | .2025.10 | 15:0 | | | ı | | 1 | | Bau | d Rate Gen | erator Regi | ister | | | | | | | 0000 | | 6250 | I2C2TRN | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | 021141 | 15:0 | _ | | _ | _ | _ | _ | _ | | | | | | | | | | 0000 | | 6260 | I2C2RCV | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0200 | 12021101 | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | | | Receive | Register | | | | 0000 | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table except I2CxRCV have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 21-2: I2C3 AND I2C4 REGISTER MAP | ess | | | | | | | | | | Bi | ts | | | | | | | | | |---------------------------|---------------------------------|---------------|---------|--------|--------|--------|--------|-------|--------|-----------------|------------|-------|------------|---------------|----------|-------|------|------|------------| | Virtual Address<br>BF84_# | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 6400 | I2C3CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | 0000 | | 0400 | 12000011 | 15:0 | ON | _ | SIDL | SCLREL | STRICT | _ | DISSLW | SMEN | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | 1000 | | 6410 | I2C3STAT | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | | ACKSTAT | TRSTAT | ACKTIM | _ | _ | BCL | GCSTAT | ADD10 | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | 0000 | | 6420 | I2C3ADD | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | _ | | | | | | | Address | Register | | | | I | 0000 | | 6430 | I2C3MSK | 31:16 | | | _ | | | | _ | _ | | _ | | —<br>-!- D:-t | _ | _ | _ | _ | 0000 | | | | 15:0<br>31:16 | | _ | _ | _ | _ | _ | | | | | Address Ma | | r | | | | 0000 | | 8440 | I2C3BRG | 15:0 | _ | | _ | _ | _ | _ | | —<br>d Rate Gen | — | | _ | | | | | _ | 0000 | | | | 31:16 | _ | | | _ | _ | _ | Dau | u Rate Gen | erator Reg | ister | | | | _ | | _ | 0000 | | 6450 | I2C3TRN | 15:0 | | | | | | | | | | _ | _ | Transmit | Register | | | _ | 0000 | | | | 31:16 | _ | | _ | _ | _ | _ | _ | | | _ | _ | — | — | _ | _ | _ | 0000 | | 6460 | I2C3RCV | 15:0 | _ | | _ | _ | _ | _ | _ | _ | | | | Receive | Register | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | 0000 | | 6600 | I2C4CON | 15:0 | ON | _ | SIDL | SCLREL | STRICT | _ | DISSLW | SMEN | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | 1000 | | 2010 | 100 10717 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 6610 | I2C4STAT | 15:0 | ACKSTAT | TRSTAT | ACKTIM | _ | _ | BCL | GCSTAT | ADD10 | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | 0000 | | 0000 | I2C4ADD | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | 0000 | | 6620 | I2C4ADD | 15:0 | _ | _ | | _ | | | | | | | Address | Register | | | | | 0000 | | 6630 | I2C4MSK | 31:16 | _ | _ | - | _ | - | - | _ | _ | _ | _ | _ | - | 1 | _ | - | _ | 0000 | | 0030 | 120410131 | 15:0 | _ | _ | _ | _ | _ | | | | | | Address Ma | ısk Registeı | | | | | 0000 | | 6640 | I2C4BRG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 00.0 | | 15:0 | | | | | | | Bau | d Rate Gen | erator Reg | ister | | | | | | | 0000 | | 6650 | I2C4TRN | 31:16 | _ | _ | | _ | _ | | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | _ | _ | _ | _ | _ | _ | | | | Transmit | Register | | | | 0000 | | 6660 | I2C4RCV | 31:16 | | | | _ | | | _ | | | _ | _ | | | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | _ | | _ | _ | _ | | | | Receive | Register | | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table except I2CxRCV have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. ### REGISTER 21-1: I2CxCON: I<sup>2</sup>C CONTROL REGISTER (X=1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | | _ | _ | _ | | 00.46 | U-0 | R/W-0 | 23:16 | _ | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-1, HC | R/W-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | ON | _ | SIDL | SCKREL | STRICT | _ | DISSLW | SMEN | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0, HC | R/W-0, HC | R/W-0, HC | R/W-0, HC | R/W-0, HC | | 7:0 | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | **Legend:** HC = Cleared in Hardware R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-23 Unimplemented: Read as '0' bit 22 **PCIE:** Stop Condition Interrupt Enable bit (I<sup>2</sup>C Client mode only) 1 = Enable interrupt on detection of Stop condition 0 = Stop detection interrupts are disabled bit 21 SCIE: Start Condition Interrupt Enable bit (I<sup>2</sup>C Client mode only) 1 = Enable interrupt on detection of Start or Restart conditions 0 = Start detection interrupts are disabled bit 20 **BOEN:** Buffer Overwrite Enable bit (I<sup>2</sup>C Client mode only) 1 = I2CxRCV is updated and ACK is generated for a received address/data byte, ignoring the state of the I2COV bit (I2CxSTAT<6>)only if the RBF bit (I2CxSTAT<2>) = 0 0 = I2CxRCV is only updated when the I2COV bit (I2CxSTAT<6>) is clear bit 19 SDAHT: SDA Hold Time Selection bit 1 = Minimum of 300 ns hold time on SDA after the falling edge of SCL 0 = Minimum of 100 ns hold time on SDA after the falling edge of SCL bit 18 SBCDE: Client Mode Bus Collision Detect Enable bit (I<sup>2</sup>C Client mode only) 1 = Enable client bus collision interrupts 0 = Client bus collision interrupts are disabled bit 18 AHEN: Address Hold Enable bit (Client mode only) 1 = Following the 8th falling edge of SCL for a matching received address byte; SCKREL bit will be cleared and the SCL will be held low. 0 = Address holding is disabled bit 16 **DHEN:** Data Hold Enable bit (I<sup>2</sup>C Client mode only) 1 = Following the 8th falling edge of SCL for a received data byte; client hardware clears the SCKREL bit and SCL is held low 0 = Data holding is disabled bit 15 **ON:** I<sup>2</sup>C Enable bit 1 = Enables the $I^2C$ module and configures the SDA and SCL pins as serial port pins $0 = \text{Disables the } 1^2\text{C module}$ ; all $1^2\text{C pins}$ are controlled by PORT functions bit 14 **Unimplemented:** Read as '0' bit 13 SIDL: Stop in Idle Mode bit 1 = Discontinue module operation when device enters Idle mode 0 = Continue module operation in Idle mode ### REGISTER 21-1: I2CxCON: I<sup>2</sup>C CONTROL REGISTER (CONTINUED)(X=1-4) - bit 12 **SCLREL:** SCLx Release Control bit (when operating as I<sup>2</sup>C client) - 1 = Release SCLx clock - 0 = Hold SCLx clock low (clock stretch) #### If STREN = 1: Bit is R/W (i.e., software can write '0' to initiate stretch and write '1' to release clock). Hardware clear at beginning of client transmission. Hardware clear at end of client reception. #### If STREN = 0: Bit is R/S (i.e., software can only write '1' to release clock). Hardware clear at beginning of client transmission. - bit 11 **STRICT:** Strict I<sup>2</sup>C Reserved Address Rule Enable bit - 1 = Strict reserved addressing is enforced. Device does not respond to reserved address space or generate addresses in reserved address space. - 0 = Strict I<sup>2</sup>C Reserved Address Rule not enabled - bit 10 **Unimplemented:** Read as '0' - bit 9 DISSLW: Disable Slew Rate Control bit - 1 = Slew rate control is disabled - 0 = Slew rate control is enabled - bit 8 SMEN: SMBus Input Levels bit - 1 = Enable I/O pin thresholds compliant with SMBus specification - 0 = Disable SMBus input thresholds - bit 7 **GCEN:** General Call Enable bit (when operating as I<sup>2</sup>C client) - 1 = Enable interrupt when a general call address is received in the I2CxRSR (module is enabled for reception) - 0 = General call address disabled - bit 6 STREN: SCLx Clock Stretch Enable bit (when operating as I<sup>2</sup>C client) Used in conjunction with SCLREL bit. - 1 = Enable software or receive clock stretching - 0 = Disable software or receive clock stretching - bit 5 **ACKDT:** Acknowledge Data bit (when operating as I<sup>2</sup>C host, applicable during host receive) Value that is transmitted when the software initiates an Acknowledge sequence. - 1 = Send NACK during Acknowledge - 0 = Send ACK during Acknowledge - bit 4 ACKEN: Acknowledge Sequence Enable bit (when operating as I<sup>2</sup>C host, applicable during host receive) - 1 = Initiate Acknowledge sequence on SDAx and SCLx pins and transmit ACKDT data bit. Hardware clear at end of host Acknowledge sequence. - 0 = Acknowledge sequence not in progress - bit 3 **RCEN**: Receive Enable bit (when operating as I<sup>2</sup>C host) - 1 = Enables Receive mode for I<sup>2</sup>C. Hardware clear at end of eighth bit of host receive data byte. - 0 = Receive sequence not in progress - bit 2 **PEN:** Stop Condition Enable bit (when operating as I<sup>2</sup>C host) - 1 = Initiate Stop condition on SDAx and SCLx pins. Hardware clear at end of Host Stop sequence. - 0 = Stop condition not in progress - bit 1 RSEN: Repeated Start Condition Enable bit (when operating as I<sup>2</sup>C host) - 1 = Initiate Repeated Start condition on SDAx and SCLx pins. Hardware clear at end of host Repeated Start sequence. - 0 = Repeated Start condition not in progress - bit 0 **SEN:** Start Condition Enable bit (when operating as I<sup>2</sup>C host) - 1 = Initiate Start condition on SDAx and SCLx pins. Hardware clear at end of host Start sequence. - 0 = Start condition not in progress ### REGISTER 21-2: I2CXSTAT: I<sup>2</sup>C STATUS REGISTER (X=1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | - | | | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | | | 45.0 | R-0, HS, HC | R-0, HS, HC | R/C-0, HS, HC | U-0 | U-0 | R/C-0, HS | R-0, HS,HC | R-0, HS, HC | | 15:8 | ACKSTAT | TRSTAT | ACKTIM | _ | _ | BCL | GCSTAT | ADD10 | | 7.0 | R/C-0, HS, SC | R/C-0, HS, SC | R-0, HS, HC | R/C-0, HS, HC | R/C-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 7:0 | IWCOL | I2COV | D_A | Р | S | R_W | RBF | TBF | Legend:HS = Hardware SetHC = Hardware ClearedSC = Software ClearedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedC = Clearable bit #### bit 31-16 Unimplemented: Read as '0' bit 15 ACKSTAT: Acknowledge Status bit (when operating as I<sup>2</sup>C host, applicable to host transmit operation) - 1 = NACK received from client - 0 = ACK received from client Hardware set or clear at end of client Acknowledge. bit 14 TRSTAT: Transmit Status bit (when operating as I<sup>2</sup>C host, applicable to host transmit operation) - 1 = Host transmit is in progress (8 bits + ACK) - 0 = Host transmit is not in progress Hardware set at beginning of host transmission. Hardware clear at end of client Acknowledge. - bit 13 **ACKTIM:** Acknowledge Time Status bit (Valid in I<sup>2</sup>C Client mode only) - $1 = I^2C$ bus is in an Acknowledge sequence, set on 8th falling edge of SCL clock - 0 = Not an Acknowledge sequence, cleared on 9th rising edge of SCL clock - bit 12-11 Unimplemented: Read as '0' - bit 10 BCL: Host Bus Collision Detect bit - 1 = A bus collision has been detected during a host operation - 0 = No collision Hardware set at detection of bus collision. - bit 9 GCSTAT: General Call Status bit - 1 = General call address was received - 0 = General call address was not received Hardware set when address matches general call address. Hardware clear at Stop detection. - bit 8 ADD10: 10-bit Address Status bit - 1 = 10-bit address was matched - 0 = 10-bit address was not matched Hardware set at match of 2nd byte of matched 10-bit address. Hardware clear at Stop detection. - bit 7 **IWCOL:** Write Collision Detect bit - 1 = An attempt to write the I2CxTRN register failed because the I<sup>2</sup>C module is busy - 0 = No collision Hardware set at occurrence of write to I2CxTRN while busy (cleared by software). - bit 6 I2COV: Receive Overflow Flag bit - 1 = A byte was received while the I2CxRCV register is still holding the previous byte - 0 = No overflow Hardware set at attempt to transfer I2CxRSR to I2CxRCV (cleared by software). ### REGISTER 21-2: I2CxSTAT: I<sup>2</sup>C STATUS REGISTER (CONTINUED)(X=1-4) - bit 5 **D\_A:** Data/Address bit (when operating as I<sup>2</sup>C client) - 1 = Indicates that the last byte received was data - 0 = Indicates that the last byte received was device address Hardware clear at device address match. Hardware set by reception of client byte. - bit 4 **P:** Stop bit - 1 = Indicates that a Stop bit has been detected last - 0 = Stop bit was not detected last Hardware set or clear when Start, Repeated Start or Stop detected. - bit 3 **S:** Start bit - 1 = Indicates that a Start (or Repeated Start) bit has been detected last - 0 = Start bit was not detected last Hardware set or clear when Start, Repeated Start or Stop detected. - bit 2 **R\_W**: Read/Write Information bit (when operating as I<sup>2</sup>C client) - 1 = Read indicates data transfer is output from client - 0 = Write indicates data transfer is input to client Hardware set or clear after reception of I<sup>2</sup>C device address byte. - bit 1 RBF: Receive Buffer Full Status bit - 1 = Receive complete, I2CxRCV is full - 0 = Receive not complete, I2CxRCV is empty Hardware set when I2CxRCV is written with received byte. Hardware clear when software reads I2CxRCV. - bit 0 TBF: Transmit Buffer Full Status bit - 1 = Transmit in progress, I2CxTRN is full - 0 = Transmit complete, I2CxTRN is empty Hardware set when software writes I2CxTRN. Hardware clear at completion of data transmission. # 22.0 UNIVERSAL ASYNCHRONOUS RECEIVER TRANSMITTER (UART) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 21. "Universal Asynchronous Receiver Transmitter (IJART)" (DS60001107) which is (UART)" (DS60001107), which is available from the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). The UART module is one of the serial I/O modules available in PIC32MK GPK/MCM with CAN FD Family of devices. The UART is a full-duplex, asynchronous communication channel that communicates with peripheral devices and personal computers through protocols, such as RS-232, RS-485, LIN, and IrDA®. The module also supports the hardware flow control option, with UxCTS and UxRTS pins, and also includes an IrDA encoder and decoder. The following are key features of the UART module: - · Ability to receive data during Sleep mode - · Full-duplex, 8-bit or 9-bit data transmission - Even, Odd, or No Parity options (for 8-bit data) - · One or two Stop bits - · Auto-baud support - Four clock source inputs for asynchronous clocking - Transmit and Receive (TX/RX) polarity control - · Hardware flow control option - Fully integrated Baud Rate Generator (BRG) with 16-bit prescaler - Baud rates up to 30 Mbps - 8-level deep First-In-First-Out (FIFO) transmit data buffer - · 8-level deep FIFO receive data buffer - · Parity, framing and buffer overrun error detection - Support for interrupt-only on address detect (ninth bit = 1) - · Separate transmit and receive interrupts - · Loopback mode for diagnostic support - · LIN Protocol support - IrDA encoder and decoder with 16x baud clock output for external IrDA encoder/decoder support Figure 22-1 illustrates a simplified block diagram of the UART module. FIGURE 22-1: UART SIMPLIFIED BLOCK DIAGRAM ### 22.1 UART Control Registers ### TABLE 22-1: UART1 AND UART2 REGISTER MAP | ess | | Φ. | | | | | | | | Bi | ts | | | | | | | | 6 | |---------------------------|-----------------------|-----------|--------|---------|----------|-------|---------|-------|-------|-------|--------|---------|-------|----------|----------|--------|---------|-------|------------| | Virtual Address<br>BF82_# | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 8000 | U1MODE <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | SLPEN | CKRDY | | _ | _ | CLKSE | L<1:0> | RUNOV | 0000 | | 8000 | O IMODE( ) | 15:0 | ON | _ | SIDL | IREN | RTSMD | _ | UEN• | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSEI | _<1:0> | STSEL | 0000 | | 8010 | U1STA <sup>(1)</sup> | 31:16 | | | | ADDRM | SK<7:0> | | | | | | | ADDF | R<7:0> | | | | 0000 | | 0010 | OTOTA | 15:0 | UTXISE | EL<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | 8020 | U1TXREG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | | 15:0 | _ | _ | _ | _ | _ | _ | _ | TX8 | | | | Transmit | Register | | | | 0000 | | 8030 | U1RXREG | 31:16 | | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | _ | _ | _ | | _ | RX8 | | | | Receive | Register | | | | 0000 | | 8040 | U1BRG <sup>(1)</sup> | 31:16 | | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | | U1BRG | <19:16> | | 0000 | | | | 15:0 | | | | | | | | U1BRG | | 1 | | | | 1 | | ı | 0000 | | 8200 | U2MODE(1) | 31:16 | | _ | | | | | | | SLPEN | CKRDY | | | | CLKSE | | RUNOV | 0000 | | | | 15:0 | ON | _ | SIDL | IREN | RTSMD | _ | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSEI | _<1:0> | STSEL | 0000 | | 8210 | U2STA <sup>(1)</sup> | 31:16 | | | · | ADDRM | | | | | | | | ADDF | | | | · | 0000 | | | | 15:0 | UTXISE | _ | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | 8220 | U2TXREG | 31:16 | | | | _ | _ | | _ | _ | _ | _ | _ | | | _ | _ | _ | 0000 | | | | 15:0 | | | _ | | _ | | | TX8 | | | | | Register | | | | 0000 | | 8230 | U2RXREG | 31:16 | | | _ | | _ | | | | _ | _ | _ | | | _ | | _ | 0000 | | | | 15:0 | | | _ | | | | | RX8 | | | | | Register | DDC :: | 10:10: | | 0000 | | 8240 | U2BRG <sup>(1)</sup> | 31:16 | | _ | _ | _ | _ | | _ | | - | _ | _ | _ | | BRG< | 19:16> | | 0000 | | Ļ | | 15:0 | | | <u> </u> | | / D /- | | | BRG< | 15:0> | | | | | | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:This register has corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. | TARI F 22-2. | UART3 THROUGH UART6 REGISTER MAP | |--------------|----------------------------------| | | | | φ. | | | | | II OAKI | <u> </u> | <u> </u> | | | Ri | its | | | | | | | | | |---------------------------|-----------------------|------------------------------------------------|--------|---------|---------|----------|----------|-------|---------------|-----------|--------|---------|-------|----------|----------|-------|--------|-------|------------| | Virtual Address<br>BF84_# | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 8400 | U3MODE <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | SLPEN | CKRDY | _ | _ | _ | CLKSE | L<1:0> | RUNOV | 0000 | | 0400 | COMODE | 15:0 | ON | _ | SIDL | IREN | RTSMD | _ | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSE | L<1:0> | STSEL | 0000 | | 8410 | U3STA <sup>(1)</sup> | 31:16 | | | | ADDRM | | | | | | | | ADDR | R<7:0> | | | | 0000 | | 0410 | 00017 | 15:0 | UTXISE | EL<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | 8420 | U3TXREG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0420 | OUTAINEO | 15:0 | _ | _ | _ | _ | _ | _ | _ | TX8 | | 11 | | Transmit | Register | | | | 0000 | | 8430 | U3RXREG | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0.100 | COLOURE | 15:0 | | _ | _ | _ | _ | _ | _ | RX8 | | | | Receive | Register | | | | 0000 | | 8440 | U3BRG <sup>(1)</sup> | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | BRG< | 19:16> | | 0000 | | 0110 | OODING | 15:0 | | | | | | | | BRG< | <15:0> | | | | | | | | 0000 | | 8600 | U4MODE <sup>(1)</sup> | 31:16 | | _ | _ | _ | _ | _ | _ | _ | SLPEN | CKRDY | _ | _ | _ | CLKSE | L<1:0> | RUNOV | 0000 | | 0000 | 04WODL | 15:0 | ON | _ | SIDL | IREN | RTSMD | _ | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSE | L<1:0> | STSEL | 0000 | | 8610 | U4STA <sup>(1)</sup> | 31:16 | | • | • | MASK | <7:0> | • | • | | | • | • | ADDR | R<7:0> | • | | • | 0000 | | 0010 | 04017 | 15:0 | UTXISE | EL<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | 8620 | U4TXREG | 31:16 | _ | _ | _ | I | I | _ | _ | _ | _ | | _ | - | _ | _ | _ | - | 0000 | | 0020 | 041XINEG | 15:0 | _ | _ | _ | _ | _ | _ | _ | TX8 | | | 3' | Transmit | Register | s' | • | • | 0000 | | 8630 | U4RXREG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0030 | U4KAREG | 15:0 | _ | _ | _ | _ | _ | _ | _ | RX8 | | | | Receive | Register | | | | 0000 | | 8640 | U4BRG <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | BRG< | 19:16> | | 0000 | | 0040 | 04BING. | 15:0 | | | | | | | | BRG< | <15:0> | | | | | | | | 0000 | | 8800 | U5MODE <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | SLPEN | CKRDY | _ | _ | _ | CLKSE | L<1:0> | RUNOV | 0000 | | 0000 | OSIVIODE | 15:0 | ON | _ | SIDL | IREN | RTSMD | _ | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSE | L<1:0> | STSEL | 0000 | | 8810 | U5STA <sup>(1)</sup> | 31:16 | | | | MASK | <7:0> | | | | | | | ADDR | R<7:0> | | | | 0000 | | 0010 | 0331A | 15:0 | UTXISE | EL<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | 8820 | U5TXREG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0020 | USTAKEG | 15:0 | _ | _ | _ | _ | _ | _ | _ | TX8 | | | | Transmit | Register | | | | 0000 | | 0020 | LIEDVDEC | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 8830 | U5RXREG | 15:0 | _ | _ | _ | _ | _ | _ | _ | RX8 | | | | Receive | Register | | | | 0000 | | 00.40 | U5BRG <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | BRG< | 19:16> | | 0000 | | 8840 | USBRG | 15:0 | | | • | | | • | • | BRG< | :15:0> | | • | • | • | | | | 0000 | | 0400 | LICMODE(1) | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | SLPEN | CKRDY | _ | _ | _ | CLKSE | L<1:0> | RUNOV | 0000 | | 8A00 | U6MODE <sup>(1)</sup> | 15:0 | ON | _ | SIDL | IREN | RTSMD | _ | UEN | <1:0> | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSE | L<1:0> | STSEL | 0000 | | 0.4.4.0 | . LICOTA (1) | 31:16 | | | • | MASK | <7:0> | | | | | • | | ADDR | R<7:0> | | | • | 0000 | | 8A10 | U6STA <sup>(1)</sup> | 15:0 | UTXISE | EL<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT | URXISI | EL<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | l egen | | <u>. </u> | | | ٠ | · | / | | ' . . . | evadecima | | | | | | | 1 | 1 | | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:This register has corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 22-2: UART3 THROUGH UART6 REGISTER MAP (CONTINUED) | ess | | 9 | | | | | | | | Bi | ts | | | | | | | | S | |---------------------------|----------------------|----------|-------|-------|-------|-------|-------|-------|------|------|--------|------|------|----------|----------|------|--------|------|-----------| | Virtual Address<br>BF84_# | Register<br>Name | Bit Rang | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | 0.4.20 | U6TXREG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 6A20 | UDIAREG | 15:0 | _ | _ | _ | _ | _ | _ | _ | TX8 | | | | Transmit | Register | | | | 0000 | | 0 4 20 | U6RXREG | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 6A30 | UURAREG | 15:0 | _ | _ | _ | _ | _ | _ | _ | RX8 | | | | Receive | Register | | | | 0000 | | 8A40 | U6BRG <sup>(1)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | BRG< | 19:16> | | 0000 | | 0A40 | UUDRG | 15:0 | | | | | | | | BRG< | :15:0> | | | | | | | | 0000 | Legend: x = x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:This register has corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PIC32MK GPK/MCM with CAN FD Family #### REGISTER 22-1: UxMODE: UARTx MODE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|----------------------|---------------------| | 24.24 | U-0 | 31:24 | _ | _ | - | _ | _ | _ | _ | _ | | 00:40 | R/W-0 | R-0, HS, HC | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | SLPEN | CLKRDY | _ | _ | _ | CLKSEL | <1:0> <sup>(1)</sup> | RUNOV | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | ON | _ | SIDL | IREN | RTSMD | _ | UEN< | 1:0> <sup>(2)</sup> | | 7.0 | R-0, HC | R/W-0 | R/W-0, HC | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | WAKE | LPBACK | ABAUD | RXINV | BRGH | PDSEL | <b>&lt;</b> 1:0> | STSEL | **Legend:** HS = Set by hardware HC = cleared by hardware R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23 SLPEN: Run During Sleep Enable bit 1 = BRG clock runs during Sleep mode 0 = BRG clock is turned off during Sleep mode Note: SLPEN = 1 only applies if CLKSEL = FRC, or in some cases REFCLK depending on the selected REFCLK input source if running while in Sleep mode. bit 22 CLKRDY: USART Clock Status bit 1 = UART clock is ready (User *should not* update the UxMODE register) 0 = UART clock is not ready (User *can* update the UxMODE register) bit 21-19 Unimplemented: Read as '0' bit 18-17 CLKSEL<1:0>: UART Baud Rate Generator Clock Selection bits(1) 11 = BRG clock is REFCLK1 10 = BRG clock is FRC 01 = BRG clock is SYSCLK (off in Sleep mode) 00 = BRG clock is PBCLKx (off in Sleep mode) bit 16 RUNOV: Run During Overflow Mode bit 1 = Shift register continues to run when Overflow (OERR) condition is detected 0 = Shift register stops accepting new data when Overflow (OERR) condition is detected bit 15 **ON:** UARTx Enable bit 1 = UARTx is enabled. UARTx pins are controlled by UARTx as defined by UEN<1:0> and UTXEN control bits 0 = UARTx is disabled. All UARTx pins are controlled by corresponding bits in the PORTx, TRISx and LATx registers; UARTx power consumption is minimal bit 14 Unimplemented: Read as '0' bit 13 SIDL: Stop in Idle Mode bit 1 = Discontinue operation when device enters Idle mode 0 = Continue operation in Idle mode bit 12 IREN: IrDA Encoder and Decoder Enable bit 1 = IrDA is enabled 0 = IrDA is disabled Note 1: These bits can be changed only when the ON bit (UxMODE<15>) is set to '0'. 2: These bits are present for legacy compatibility, and are superseded by PPS functionality on these devices (see 13.3 "Peripheral Pin Select (PPS)" for more information). ### REGISTER 22-1: UxMODE: UARTx MODE REGISTER (CONTINUED) - bit 11 RTSMD: Mode Selection for UxRTS Pin bit - $1 = \overline{\text{UxRTS}}$ pin is in Simplex mode - $0 = \overline{\text{UxRTS}}$ pin is in Flow Control mode - bit 10 Unimplemented: Read as '0' - bit 9-8 **UEN<1:0>:** UARTx Enable bits<sup>(2)</sup> - 11 = UxTX, UxRX and UxBCLK pins are enabled and used; UxCTS pin is controlled by corresponding bits in the PORTx register - 10 = UxTX, UxRX, $\overline{\text{UxCTS}}$ and $\overline{\text{UxRTS}}$ pins are enabled and used - 01 = UxTX, UxRX and UxRTS pins are enabled and used; UxCTS pin is controlled by corresponding bits in the PORTx register - 00 = UxTX and UxRX pins are enabled and used; UxCTS and UxRTS/UxBCLK pins are controlled by corresponding bits in the PORTx register - bit 7 WAKE: Enable Wake-up on Start bit Detect During Sleep Mode bit - 1 = Wake-up is enabled - 0 = Wake-up is disabled - bit 6 LPBACK: UARTx Loopback Mode Select bit - 1 = Loopback mode is enabled - 0 = Loopback mode is disabled - bit 5 ABAUD: Auto-Baud Enable bit - 1 = Enable baud rate measurement on the next reception of Sync character (0x55); cleared by hardware upon completion - 0 = Baud rate measurement disabled or completed - bit 4 RXINV: Receive Polarity Inversion bit - 1 = UxRX Idle state is '0' - 0 = UxRX Idle state is '1' - bit 3 BRGH: High Baud Rate Enable bit - 1 = High-Speed mode 4x baud clock enabled - 0 = Standard Speed mode 16x baud clock enabled - bit 2-1 PDSEL<1:0>: Parity and Data Selection bits - 11 = 9-bit data, no parity - 10 = 8-bit data, odd parity - 01 = 8-bit data, even parity - 00 = 8-bit data, no parity - bit 0 STSEL: Stop Selection bit - 1 = 2 Stop bits - 0 = 1 Stop bit - **Note 1:** These bits can be changed only when the ON bit (UxMODE<15>) is set to '0'. - 2: These bits are present for legacy compatibility, and are superseded by PPS functionality on these devices (see 13.3 "Peripheral Pin Select (PPS)" for more information). #### REGISTER 22-2: UxSTA: UARTx STATUS AND CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|----------------------|------------------|------------------|--|--|--| | 24.24 | R/W-0 | | | | 31:24 | | | | MASK< | <7:0> | | | | | | | | 22.46 | R/W-0 | | | | 23:16 | ADDR<7:0> | | | | | | | | | | | | 45.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0, HC | R/W-0 | R-0 | R-1 | | | | | 15:8 | UTXISE | L<1:0> | UTXINV | URXEN | UTXBRK | UTXEN <sup>(1)</sup> | UTXBF | TRMT | | | | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R-1 | R-0 | R-0 | R/W-0, HS | R-0 | | | | | 7:0 | URXISE | L<1:0> | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | | | | Legend:HS = Set by hardwareHC = cleared by hardwareR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown #### bit 31-24 MASK<7:0>: Address Match Mask bits These bits are used to mask the ADDR<7:0> bits. 11111111 = Corresponding matching ADDR<7:0> bits are used to detect the address match **Note:** This setting allows the user to assign individual address as well as a group broadcast address to a UART. 00000000 = Corresponding ADDRx bits are not used to detect the address match. See 22.2 "UART Broadcast Mode Example" for additional information. #### bit 23-16 ADDR<7:0>: Automatic Address Mask bits 1 = Corresponding MASKx bits are used to detect the address match. **Note:** This setting allows the user to assign individual address as well as a group broadcast address to a UART. 0 = Corresponding MASKx bits are not used to detect the address match. See 22.2 "UART Broadcast Mode Example" for additional information. #### bit 15-14 UTXISEL<1:0>: TX Interrupt Mode Selection bits - 11 = Reserved, do not use - 10 = Interrupt is generated and asserted while the transmit buffer is empty - 01 = Interrupt is generated and asserted when all characters have been transmitted - 00 =Interrupt is generated and asserted while the transmit buffer contains at least one empty space #### bit 13 UTXINV: Transmit Polarity Inversion bit If IrDA mode is disabled (i.e., IREN (UxMODE<12>) is '0'): - 1 = UxTX Idle state is '0' - 0 = UxTX Idle state is '1' ### If IrDA mode is enabled (i.e., IREN (UxMODE<12>) is '1'): - 1 = IrDA encoded UxTX Idle state is '1' - 0 = IrDA encoded UxTX Idle state is '0' #### bit 12 URXEN: Receiver Enable bit - 1 = UARTx receiver is enabled. UxRX pin is controlled by UARTx (if ON bit (UxMODE<15>) = 1) - 0 = UARTx receiver is disabled. UxRX pin is ignored by the UARTx module and released to the PORT **Note:** The event of disabling an enabled receiver will release the RX pin to the PORT function; however, the receive buffers will not be reset. Disabling the receiver has no effect on the receive status flags. Note 1: This bit should not be enabled until after the ON bit (UxMODE<15>) = 1. If TX interrupts are enabled, setting this bit will immediately cause a TX interrupt based on the value of the UTXISEL bit. ### REGISTER 22-2: UxSTA: UARTx STATUS AND CONTROL REGISTER (CONTINUED) - bit 11 UTXBRK: Transmit Break bit - 1 = Send Break on next transmission. Start bit followed by twelve '0' bits, followed by Stop bit; cleared by hardware upon completion - 0 = Break transmission is disabled or completed - bit 10 **UTXEN:** Transmit Enable bit<sup>(1)</sup> - 1 = UARTx transmitter is enabled. UxTX pin is controlled by UARTx (if ON bit (UxMODE<15>) = 1) - 0 = UARTx transmitter is disabled The event of disabling an enabled transmitter will release the TX pin to the PORT function and reset the transmit buffers to empty. Any pending transmission is aborted and data characters in the transmit buffers are lost. All transmit status flags are cleared and the TRMT bit is set. - bit 9 **UTXBF:** Transmit Buffer Full Status bit (read-only) - 1 = Transmit buffer is full - 0 = Transmit buffer is not full, at least one more character can be written - bit 8 **TRMT:** Transmit Shift Register is Empty bit (read-only) - 1 = Transmit shift register is empty and transmit buffer is empty (the last transmission has completed) - 0 = Transmit shift register is not empty, a transmission is in progress or queued in the transmit buffer - bit 7-6 URXISEL<1:0>: Receive Interrupt Mode Selection bit - 11 = Reserved - 10 = Interrupt flag bit is asserted while receive buffer is 3/4 or more full - 01 = Interrupt flag bit is asserted while receive buffer is 1/2 or more full - 00 =Interrupt flag bit is asserted while receive buffer is not empty (i.e., has at least 1 data character) - bit 5 **ADDEN:** Address Character Detect bit (bit 8 of received data = 1) - 1 = Address Detect mode is enabled. If 9-bit mode is not selected, this control bit has no effect - 0 = Address Detect mode is disabled - bit 4 RIDLE: Receiver Idle bit (read-only) - 1 = Receiver is Idle - 0 = Data is being received - bit 3 **PERR:** Parity Error Status bit (read-only) - 1 = Parity error has been detected for the current character - 0 = Parity error has not been detected - bit 2 **FERR:** Framing Error Status bit (read-only) - 1 = Framing error has been detected for the current character - 0 = Framing error has not been detected - bit 1 **OERR:** Receive Buffer Overrun Error Status bit. When RUNOV = 0, clearing a previously set OERR bit will clear and reset the receive buffer and shift register. When RUNOV = 1, Clearing a previously set OERR bit will NOT reset the receive buffer and shift register - 1 = Receive buffer has overflowed - 0 = Receive buffer has not overflowed - bit 0 **URXDA:** Receive Buffer Data Available bit (read-only) - 1 = Receive buffer has data, at least one more character can be read - 0 = Receive buffer is empty - Note 1: This bit should not be enabled until after the ON bit (UxMODE<15>) = 1. If TX interrupts are enabled, setting this bit will immediately cause a TX interrupt based on the value of the UTXISEL bit. #### REGISTER 22-3: UXRXREG: UARTX RECEIVE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | _ | _ | - | - | _ | _ | - | | | 45.0 | U-0 R-0 | | 15:8 | _ | _ | - | - | _ | _ | _ | RX<8> | | 7:0 | R-x | 7:0 | | | | RX<7 | :0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-9 Unimplemented: Read as '0' bit 8 **RX<8>:** Data bit 8 of the received character (in 9-bit mode) bit 7-0 RX<7:0>: Data bits 7-0 of the received character #### REGISTER 22-4: UXTXREG: UARTX TRANSMIT REGISTER | Bit |-------|------------|------------|------------|------------|------------|------------|-----------|-----------| | Range | 31/23/15/7 | 30/22/14/6 | 29/21/13/5 | 28/20/12/4 | 27/19/11/3 | 26/18/10/2 | 25/17/9/1 | 24/16/8/0 | | 31:24 | U-x | 31.24 | | _ | _ | _ | - | | - | _ | | 00.40 | U-x | 23:16 | - | - | - | - | | | - | _ | | 45.0 | U-x W-x | | 15:8 | _ | _ | _ | _ | _ | _ | _ | TX<8> | | 7.0 | W-0 | 7:0 | | | | TX<7 | :0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-9 Unimplemented: Read as initialized data bit 8 **TX<8>:** Data bit 8 of the transmitted character (in 9-bit mode) bit 7-0 TX<7:0>: Data bits 7-0 of the transmitted character #### REGISTER 22-5: UxBRG: UARTX BAUD RATE GENERATOR REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | | _ | - | _ | _ | _ | _ | _ | | 22.16 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | | _ | - | _ | | BRG< | 19:16> | | | 45.0 | R/W-0 | 15:8 | | | | BRG<1 | 5:8> | | | | | 7.0 | R/W-0 | 7:0 | | | | BRG< | 7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-20 Unimplemented: Read as '0' bit 19-0 BRG<19:0>: Baud Rate Generator Divisor bits Note: The UxBRG register cannot be changed while UARTx is enabled (ON bit (UxMODE<15>) = 1)). #### TABLE 22-3: UART BAUD RATE CALCULATIONS | UART Baud Rate With | UxBRG Equals | |---------------------|-------------------------------------------------------------| | BRGH = 0 | UxBRG = ((CLKSEL Frequency / (16 * Desired Baud Rate)) – 1) | | BRGH = 1 | UxBRG = ((CLKSEL Frequency / (4 * Desired Baud Rate)) – 1) | **Note:** UART1 and UART2 on PBCLK2; UART3 through UART6 on PBCLK3. ### 22.2 UART Broadcast Mode Example Any MASK register bit = 0 means the corresponding ADDR<7:0> bit is a "don't care" from a hardware address matching point of view. Using this scheme, multiple UART subnet groups could be created within a network. If not using address match with a broadcast mode, set the ADDRMSK<7:0> bits (UxSTAT<31:24) = 0x00, which is the default. To send a broadcast message to all UARTs in the group identified by bit 7=1, send UXTXREG = (0x190), address bit 9 set. All the UARTs in that group, bit 7=1, would generate an interrupt for an address match because of the bit <7:5>,<3:2> match, Logic AND of MASK and ADDR registers equal "true". User software would check if bit 4=1, and if true, the RX<7:0> bits register value is valid for all UARTS. To send a specific message to UARTy within the group, the user would send UxTXREG = (0x182), address bit 9 set. All of the UARTs in that group identified with bit 7 = 1 would still generate an interrupt for an address match because of the bit <7:5>,<3:2> address match, Logic AND of MASK and ADDR registers equal True. In this case, user software would check if bit 4 = 0, and if true, the RX<7:0> bits register value would be intended only for UARTy, with all others ignored. TABLE 22-4: PDSEL<1:0> (UxMODE<2:1>) = '0b11 AND ADM\_EN (UxSTA<24>) = 1 | IADLL ZZ | T. I DOLL | . 11.02 ( | OXIVIOL | · · · · | ) - OBITAIL | יייים א | -14 (070 | 17 7277 | - • | | |--------------------|-----------------|-----------|---------|---------|-----------------------------|---------|----------|---------|-----|-----------------------------------| | Networked<br>UARTS | Register<br>Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Individual/<br>Group<br>Addresses | | UARTx | ADDRMSK | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0xBC | | UARTw | ADDR | 1 | 0 | 0 | 1 = Group<br>0 = Individual | 0 | 0 | 0 | 0 | 0x80/0x9X | | UARTx | ADDR | 1 | 0 | 0 | 1 = Group<br>0 = Individual | 0 | 0 | 0 | 1 | 0x81/0x9X | | UARTy | ADDR | 1 | 0 | 0 | 1 = Group<br>0 = Individual | 0 | 0 | 1 | 0 | 0x82/0x9X | | UARTz | ADDR | 1 | 0 | 0 | 1 = Group<br>0 = Individual | 0 | 0 | 1 | 1 | 0x83/0x9X | ### 22.3 Module Operation #### 22.3.1 INITIALIZATION Clearing the ON bit (i.e, = 0), which disables the UART module, will do the following: - Aborts all pending transmissions and receptions and resets the module, as follows: - Reset the RX/TX buffers/FIFO to empty states (any data characters in the buffers are lost) - Resets the baud rate counter (UxBRG is not affected, only the counter) - Resets all error and status flags: URXDA, OERR, FERR, PERR, UTXBRK, UTXBF are cleared and RIDLE, TRMT are set - Stop clocks to the entire module with the exception of the SFRs, saving power - · Surrenders control of the module I/O pins Note: Once the ON bit is set, it should not be cleared until the CLKRDY bit is read to be a logic '1'. This allows proper synchronization of the status and output signals. Otherwise, glitches in the status signals or BRG clock can occur. Setting the ON bit (i.e., = 1), which enables the UART module, will do the following: - The UART module controls the I/O pins as defined by the UEN bits, overriding the port TRIS and LATCH register bit settings - UxTX is forced as an output driving the idle state defined by the UTXINV bit, when no transmissions are taking place - · UxRX is configured as an input - If CTS and RTS are enabled, CTS is forced as an input and the RTS/BCLK pin functions as RTS output - If BCLK is enabled, the RTS/BCLK output drives the 16x baud clock output Note: The ON bit should not be set (i.e., = 1) unless the CLKRDY bit is read to be a logic '0'. ### 22.4 Serial Protocols Usage ### 22.4.1 DATA TERMINAL EQUIPMENT (DTE) WITH FLOW CONTROL When connecting to the DTE (typically a PC) and flow control is desired, set the UEN bit = 10 to enable CTS and RTS, and set the RTSMD bit = 0. #### 22.4.2 IEEE-485 To use the UART module in the IEEE-485 protocol, use the address detection feature to detect message frames. Normally, set the UEN bit = '01' to drive the RTS pin and control the bus driver, and set the RTSMD bit = 1. ### 22.4.3 LIN BUS To transmit on a LIN bus, the transmitter must send a frame in 8,N,1 format consisting of a break, a synchronization character (0x55), and the message body. The module has extensive support for the LIN protocol including bus wake-up for a client node as well as autobaud detection and BREAK character transmit for host nodes. When in LIN mode, the software should program the BRGH bit = 0, which insures a 16x baud clock is used with majority detect. ### 22.5 Transmit and Receive Timing Figure 22-2 and Figure 22-3 illustrate typical receive and transmit timing for the UART module. FIGURE 22-2: UART RECEPTION ### FIGURE 22-3: TRANSMISSION (8-BIT OR 9-BIT DATA) | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 23.0 PARALLEL MASTER PORT (PMP) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 13. "Parallel Master Port (PMP)" (DS60001128), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The PMP is a parallel 8-bit/16-bit input/output module specifically designed to communicate with a wide variety of parallel devices, such as communications peripherals, LCDs, external memory devices and microcontrollers. Because the interface to parallel peripherals varies significantly, the PMP module is highly configurable. The following are key features of the PMP module: - · 8-bit or 16-bit data interface - 14/22 address lines with two Chip Selects - · 15/23 address lines with one Chip Select - · 16/24 address lines without Chip Select - · Address auto-increment/auto-decrement - Selectable address bus width for resource limited I/O - Individual read and write strobes or read/write strobe with enable strobe - Partially multiplexed address/data mode (eight bits of address) with an address latch strobe - Fully multiplexed address/data mode (16 bits of address) with address latch high and low strobes - · Programmable wait states - · Programmable polarity on selected control signals - · Interrupt on cycle end, busy flag for polling - Persistent Interrupt capability for DMA access - Little and Big-Endian Compatible addressing styles - Extended address mode with addresses up to 24 bits - Dual (4) word buffer mode with separate read and write registers. - · Operate during CPU Sleep and Idle modes - Fast bit manipulation using CLR, SET, and INV registers - · Freeze option for in-circuit debugging te: On 64-pin devices, data pins PMD<15:8> and PMA<23:16> are not available. TABLE 23-1: PMP SUPPORTED CONFIGURATIONS | CONTIGUIATIONS | | | | | | | | | | | |----------------|------------------------------------------|--------------------|---|--|--|--|--|--|--|--| | Pins | Alternate PMP Pin Functions | tions Devices Devi | | | | | | | | | | PMD<7:0> | Multiplexed<br>PMA<7:0> and<br>PMA<15:8> | Х | Х | | | | | | | | | PMD<15:8> | Multiplexed<br>PMA<7:0> and<br>PMA<15:8> | Х | _ | | | | | | | | | PMA<0> | PMALL | Х | Х | | | | | | | | | PMA<1> | PMALH | Х | Х | | | | | | | | | PMA<13:2> | _ | Х | Х | | | | | | | | | PMA<14> | PMCS1 or<br>PMCS | Х | Х | | | | | | | | | PMA<15> | PMCS2 | Х | Х | | | | | | | | | PMA<21:16> | | Х | _ | | | | | | | | | PMA<22> | PMCS1A | Х | _ | | | | | | | | | PMA<23> | PMCS2A | Х | _ | | | | | | | | | PMRD | PMWR | Х | Х | | | | | | | | | PMWR | PMENB | X | Χ | | | | | | | | #### ADRMUX<1:0> bits - 11 = All 16 bits of address are multiplexed with the 16 bits of data (PMA<15:0>/PMD<15:0>) using two phases. - 10 = All 16 bits of address are multiplexed with the lower 8 bits of data (PMA<15:8>/PMA<7:0>/ PMD<7:0>) using three phases - 01 = Lower 8 bits of address are multiplexed with lower 8 bits of data (PMA<7:0>/PMD<7:0>) - 00 = Address and data pins are not multiplexed Address Bus Data Bus Control Lines PMA<0> Parallel PMALL **Master Port** PMA<1> PMALH Flash Up to 24-bit Address **EEPROM** PMA<21:2> SRAM PMA<14/22> PMCS1 PMA<15/23> PMCS2 **PMRD** PMRD/PMWR **PMWR FIFO** LCD **PMENB** Microcontroller **Buffer** PMD<7:0> PMD<15:8><sup>(1)</sup> 8-bit/16-bit Data (with or without multiplexed addressing) On 64-pin devices, data pins PMD<15:8> and PMA<23:16> are not available. Note: **FIGURE 23-1:** PMP MODULE PINOUT AND CONNECTIONS TO EXTERNAL DEVICES ### 23.1 Control Registers ### TABLE 23-2: PARALLEL MASTER PORT REGISTER MAP | Virtual Address<br>(BF82_#)<br>Register<br>Name(†) | | • | | Bits | | | | | | | | | | | | | | | | |----------------------------------------------------|---------------------------------|--------------------|-----------------|---------|-------|------------------|---------|--------|--------|--------|---------|---------|------|-------|---------|---------|---------|--------|------------| | | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | PMCON | 31:16 | _ | _ | _ | _ | ı | _ | _ | _ | RDSTART | _ | - | _ | _ | _ | DUALBUF | EXADR | 0000 | | | FIVICUN | 15:0 | ON | _ | SIDL | ADRML | JX<1:0> | PMPTTL | PTWREN | PTRDEN | CSF | <1:0> | ALP | CS2P | CS1P | _ | WRSP | RDSP | 0000 | | E010 | PMMODE | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | L010 | | 15:0 | BUSY | IRQM | <1:0> | INCM | <1:0> | MODE16 | MODE | <1:0> | WAITE | | | WAITN | | | WAITE | E<1:0> | 0000 | | | | 31:16 | _ | _ | _ | _ | | _ | _ | _ | | PMCS1A | | I | ADDR< | 21:16> | 1 | | 0000 | | E020 | PMADDR | | _ | _ | _ | _ | _ | _ | _ | _ | ADDR23 | ADDR22 | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | CS2 | CS1 | | | | | | | ADDR: | <13:0> | | | | | | | 0000 | | | | | ADDR15 | ADDR14 | | | | | | | | | | | | 1 | | | 0000 | | E030 | PMDOUT | 31:16 | | | | | | | | | | | | | _ | | | | | | | | 15:0 | | | | | | | | DATAOL | T<15:0> | | | | | | | | 0000 | | E040 | PMDIN | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | | | | | | | | | 0000 | | | E050 | PMAEN | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | | PTEN< | :23:16> | | | | 0000 | | | | 15:0 | PTEN<15:0> 0000 | | | | | | | | | | | | | | | | | | E060 | PMSTAT | 31:16 | | _ | | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | 0000 | | | | 15:0 | IBF | IBOV | _ | _ | IB3F | IB2F | IB1F | IB0F | OBE | OBUF | _ | _ | OB3E | OB2E | OB1E | OB0E | 008F | | | | 31:16 | | | _ | _ | | _ | | | WCS2A | WCS1A | | | WADDR | | | | 0000 | | E070 | PMWADDR | | | - | | _ | | | | | WADDR23 | WADDR22 | | | | | _ | | 0000 | | | | 15:0 | WCS2 | WCS1 | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | 0000 | | | | | WADDR15 | WADDR14 | | WADDR<13:0> 0000 | | | | | | | | | | | | | | | | | 31:16 | | _ | | _ | | _ | _ | | RCS2A | RCS1A | | | RADDR | <21:16> | | | 0000 | | E080 | PMRADDR | | RCS2 | RCS1 | _ | _ | | _ | _ | _ | RADDR23 | | | | | | | | 0000 | | | | 15:0 | _ | | | | | | | | | | | | 0000 | | | | | | | | 04:40 | | KADDK14 | | | | | | | RADDF | <13:0> | | | | | | | 0000 | | E090 | PMRDIN | 31:16 | | _ | _ | | _ | | _ | | | _ | _ | | _ | _ | _ | | 0000 | | | 15:0 | 15:0 RDATAIN<15:0> | | | | | | | | | | | | 0000 | | | | | | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1:All registers in this table have corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. ### REGISTER 23-1: PMCON: PARALLEL PORT CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|---------------------------|-------------------|--------------------|---------------------|---------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | | _ | | 00.46 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 23:16 | _ | _ | _ | _ | _ | _ | DUALBUF | EXADR | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15:8 | 8 ON <sup>(1)</sup> — SIE | | SIDL | ADRMU | JX<1:0> | PMPTTL | PTWREN | PTRDEN | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | | 7:0 | CSF<1:0> <sup>(2)</sup> | | ALP <sup>(2)</sup> | CS2P <sup>(2)</sup> | CS1P <sup>(2)</sup> | _ | WRSP | RDSP | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23 RDSTART: Start Read Cycle on PMP Bus bit 1 = Start a ready cycle on the PMP bus 0 = No effect Note: This bit is cleared by hardware at the end of the read cycle when the BUSY bit (PMMODE<15>) is equal to '0'. bit 22-18 Unimplemented: Read as '0' bit 17 **DUALBUF:** Parallel Master Port Dual Read/Write Buffer Enable bit This bit is only valid in Host mode. 1 = PMP uses separate registers for reads and writes Reads: PMRADDR and PMRDIN Writes: PMRWADDR and PMDOUT 0 = PMP uses legacy registers for reads and writes Reads/Writes: PMADDR and PMRDIN bit 16 **EXADR:** Parallel Master Port Extended 24-bit Addressing bit (Host mode only) 1 = PMP 24-bit addressing is enabled 0 = PMP 24-bit addressing is disabled bit 15 **ON:** Parallel Master Port Enable bit<sup>(1)</sup> 1 = PMP is enabled 0 = PMP is disabled, no off-chip access performed bit 14 Unimplemented: Read as '0' bit 13 SIDL: Stop in Idle Mode bit - 1 = Discontinue module operation when device enters Idle mode - 0 = Continue module operation in Idle mode **Note 1:** When using 1:1 PBCLK divisor, the user software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON control bit. 2: These bits have no effect when their corresponding pins are used as address lines. ### REGISTER 23-1: PMCON: PARALLEL PORT CONTROL REGISTER (CONTINUED) - bit 12-11 ADRMUX<1:0>: Address/Data Multiplexing Selection bits - 11 = All 16-bit of address are multiplexed with the 16-bits of data (PMA<15:0> or PMD<15:0>) using two phases - 10 = All 16-bit of address are multiplexed with the lower 8-bits of data (PMA<15:8>, PMA<7:0>, or PMD<7:0>) using three phases - 01 = Lower 8-bits of address are multiplexed with lower 8-bits of data (PMA<7:0> or PMD<7:0>) - 00 = Address and data pins are not multiplexed - Note: The ADRMUX bits are independent of the MODE16 bit. Therefore, if ADDRMUX = 11 and MODE16 = 0, only the lower 8 bits of the address will be driven out. Additionally, if ADDRMUX = 10 and MODE16 = 1, the upper 8 bits of the data will be driven out on PMD<15:8>. - bit 10 PMPTTL: PMP Module TTL Input Buffer Select bit - 1 = PMP module uses TTL input buffers - 0 = PMP module uses Schmitt Trigger input buffer - bit 9 **PTWREN:** Write Enable Strobe Port Enable bit - 1 = PMWR/PMENB port is enabled - 0 = PMWR/PMENB port is disabled - bit 8 PTRDEN: Read/Write Strobe Port Enable bit - 1 = PMRD/PMWR port is enabled - 0 = PMRD/PMWR port is disabled - bit 7-6 CSF<1:0>: Chip Select Function bits<sup>(2)</sup> - 11 = Reserved - 10 = PMCS2/(a) and PMCS1/(a) used as Chip Select - 01 = PMCS2/(a) used as Chip Select, PMCS1/(a) used as address bit 14 or (22 when EXADR = 1) - 00 = PMCS2/(a) and PMCS1/(a) used as address bits (15 and 14) or (23 and 22 when EXADR = 1) Note: When the CSx bit is used as an address, it is subject to auto-increment/decrement. - bit 5 **ALP:** Address Latch Polarity bit<sup>(2)</sup> - 1 = Active-high (PMCS2) / (PMPCS2a) - 0 = Active-low (PMCS2) / (PMPCS2a) - **Note:** When the PMCS2/(a) pin is used as an address pin, the setting of the CS2P bit does not affect the polarity. - bit 4 **CS2P:** Chip Select 1 Polarity bit<sup>(2)</sup> - 1 = Active-high (PMCS2) / (PMPCS2a) - 0 = Active-low (PMCS2) / (PMPCS2a) - When the PMCS2/PMPCS2a pin is used as an address pin, the setting of the CS2P bit does not affect the polarity. - bit 3 **CS1P:** Chip Select 0 Polarity bit<sup>(2)</sup> - 1 = Active-high (PMCS1) / (PMPCS1a) - 0 = Active-low (PMCS1) / (PMPCS1a) - **Note:** When the PMCS1/PMPCS1a pin is used as an address pin, the setting of the CS1P bit does not affect the polarity. - bit 2 Unimplemented: Read as '0' - bit 1 WRSP: Write Strobe Polarity bit For Client Modes and Host mode 2 (MODE<1:0> = 00,01,10): - 1 = Write strobe active-high (PMWR) - 0 = Write strobe active-low (PMWR) For Host mode 1 (MODE<1:0> = 11): - 1 = Enable strobe active-high (PMENB) - 0 = Enable strobe active-low (PMENB) - **Note 1:** When using 1:1 PBCLK divisor, the user software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON control bit. - 2: These bits have no effect when their corresponding pins are used as address lines. ### REGISTER 23-1: PMCON: PARALLEL PORT CONTROL REGISTER (CONTINUED) bit 0 RDSP: Read Strobe Polarity bit For Client modes and Host mode 2 (MODE<1:0> = 00,01,10): - 1 = Read Strobe active-high (PMRD) - 0 = Read Strobe active-low (PMRD) For Host mode 1 (MODE<1:0> = 11): - 1 = Read/write strobe active-high (PMRD/PMWR) - 0 = Read/write strobe active-low (PMRD/PMWR) - **Note 1:** When using 1:1 PBCLK divisor, the user software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON control bit. - 2: These bits have no effect when their corresponding pins are used as address lines. ### REGISTER 23-2: PMMODE: PARALLEL PORT MODE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|----------------------|-------------------|---------------------------|-------------------|-------------------|----------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | - | - | | - | _ | _ | | 22.46 | U-0 | 23:16 | _ | _ | - | - | - | 1 | _ | _ | | 45.0 | R-0 | R/W-0 | 15:8 | BUSY | IRQM | <1:0> | INCM | <1:0> | MODE16 | MODE | E<1:0> | | 7.0 | R/W-0 | 7:0 | WAITB: | <1:0> <sup>(1)</sup> | | WAITM<3:0> <sup>(1)</sup> | | WAITE | <1:0> <sup>(1)</sup> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 BUSY: Busy bit (Host mode only) 1 = Port is busy 0 = Port is not busy bit 14-13 IRQM<1:0>: Interrupt Request Mode bits 11 = Reserved, do not use 10 = Interrupt generated when Read Buffer 3 is read or Write Buffer 3 is written (Buffered PSP mode) or on a read or write operation when PMA<1:0> = 11 (Addressable Client mode only) 01 = Interrupt generated at the end of the read/write cycle 00 = No Interrupt generated bit 12-11 INCM<1:0>: Increment Mode bits 11 = Client mode read and write buffers auto-increment (MODE<1:0> = 00 only) 10 = Decrement ADDR<15:0> by 1 every read/write cycle<sup>(2)</sup> 01 = Increment ADDR<15:0> by 1 every read/write cycle<sup>(2)</sup> 00 = No increment or decrement of address bit 10 MODE16: 8-bit/16-bit Data Mode bit 1 = 16-bit mode: a read or write to the data register invokes a single 16-bit transfer 0 = 8-bit mode: a read or write to the data register invokes a single 8-bit transfer bit 9-8 MODE<1:0>: Parallel Port Mode Select bits 11 = PMP mode, control signals (PMA<23/15:0>, PMD<23/15:0>, PMCS2(a), PMCS1(a), PMRD/PMWR, PMENB) 10 = PMP mode, control signals (PMA<23/15:0>, PMD<23/15:0>, PMCS2(a), PMCS1(a), PMRD, PMWR (byte enable)) 01 = Enhanced PSP mode, control signals (PMRD, PMWR, PMCS1, PMD<7:0>, and PMA<1:0>) 00 = Legacy Parallel Slave Port mode, control signals (PMRD, PMWR, PMCS1, and PMD<7:0>) bit 7-6 WAITB<1:0>: Data Setup to Read/Write Strobe Wait States bits(1) 11 = Data wait of 4 TPB; multiplexed address phase of 4 TPB 10 = Data wait of 3 TPB; multiplexed address phase of 3 TPB 01 = Data wait of 2 TPB; multiplexed address phase of 2 TPB 00 = Data wait of 1 TPB; multiplexed address phase of 1 TPB (default) Note 1: Whenever WAITM<3:0> = 0000, WAITB and WAITE bits are ignored and forced to 1 ΤΡΒCLΚ cycle for a write operation; WAITB = 1 ΤΡΒCLΚ cycle, WAITE = 0 ΤΡΒCLΚ cycles for a read operation. 2: Address bits, A15 and A14, are not subject to automatic increment/decrement if configured as Chip Select CS2 and CS1. 3: These pins are active when MODE16 = 1 (16-bit mode). ## REGISTER 23-2: PMMODE: PARALLEL PORT MODE REGISTER (CONTINUED) ``` bit 5-2 WAITM<3:0>: Data Read/Write Strobe Wait States bits(1) 1111 = Wait of 16 TPB 0001 = Wait of 2 TPB 00000 = Wait of 1 TPB (default) bit 1-0 WAITE<1:0>: Data Hold After Read/Write Strobe Wait States bits(1) 11 = Wait of 4 TPB 10 = Wait of 3 TPB 01 = Wait of 2 TPB 00 = Wait of 1 TPB (default) For Read operations: 11 = Wait of 3 TPB 10 = Wait of 2 TPB 01 = Wait of 2 TPB 01 = Wait of 2 TPB 01 = Wait of 1 TPB ``` - Note 1: Whenever WAITM<3:0> = 0000, WAITB and WAITE bits are ignored and forced to 1 ΤΡΒCLK cycle for a write operation; WAITB = 1 ΤΡΒCLK cycle, WAITE = 0 ΤΡΒCLK cycles for a read operation. - 2: Address bits, A15 and A14, are not subject to automatic increment/decrement if configured as Chip Select CS2 and CS1. - **3:** These pins are active when MODE16 = 1 (16-bit mode). 00 = Wait of 0 TPB (default) ### REGISTER 23-3: PMADDR: PARALLEL PORT ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 31:24 | U-0 | U-0 | U-0 | 0 U-0 U-0 | | U-0 U-0 | | U-0 | | | | | | | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | | | R/W-0 | | | | | | 23:16 | CS2a | CS1a | OS1a ADDR<21:16> | | | | | | | | | | | | | WADDR23 | WADDR22 | ADDR<21:16> | | | | | | | | | | | | | R/W-0 | | | | | | 15:8 | CS2 | CS1 | | | \ DDB | ~12·0 <b>&gt;</b> | | | | | | | | | | ADDR15 | ADDR14 | ADDR<13:8> | | | | | | | | | | | | 7:0 | R/W-0 | | | | | | | | | ADDR<7:0> | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23 CS2a: Chip Select 2a bit This bit is only valid when the CSF<1:0> bits = 10 or 01. 1 = Chip Select 2a is enabled 0 = Chip Select 2a is disabled bit 23 WADDR23: Address bits This bit is only valid when the CSF<1:0> bits = 0.0 and the EXADR bit = 1 and the DUALBUF bit = 0.0 bit 22 CS1a: Chip Select 1a bit This bit is only valid when the CSF<1:0> bits = 10. 1 = Chip Select 1a is enabled 0 = Chip Select 1a is disabled bit 22 WADDR22: Address bits This bit is only valid when the CSF<1:0> bits = 00 and the EXADR bit = 1 and the DUALBUF bit = 0. bit 21-16 ADDR<21:16>: Address bits These bits are only valid when the EXADR bit = 1 and the DUALBUF bit = 0. bit 15 CS2: Chip Select 2 bit This bit is only valid when the CSF<1:0> bits = 10 or 01 and the EXADR bit = 0. 1 = Chip Select 2 is enabled 0 = Chip Select 2 is disabled bit 15 ADDR<15>: Target Address bit 15 This bit is only valid when the CSF<1:0> bits = 10 or 01 and the EXADDR bit = 0. bit 14 CS1: Chip Select 1 bit This bit is only valid when the CSF<1:0> bits = 10 or 01 or EXADR bit = 0. 1 = Chip Select 1 is enabled 0 = Chip Select 1 is disabled bit 14 ADDR<14>: Target Address bit 14 This bit is only valid when the CSF<1:0> bits = 01 or 00 or EXADR bit = 1. bit 13-0 ADDR<13:0>: Address bits **Note:** If the DUALBUF bit (PMCON<17>) = 0, the bits in this register control both read and write target addressing. If the DUALBUF bit = 1, the bits in this register are not used. In this instance, use the PMRADDR register for Read operations and the PMWADDR register for Write operations. ### REGISTER 23-4: PMDOUT: PARALLEL PORT OUTPUT DATA REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.46 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | 15:8 | | | | DATAOUT | <15:8> | | | | | 7:0 | R/W-0 | | | | | DATAOU | Γ<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 DATAOUT<15:0>: Port Data Output bits This register is used for Read operations in the Enhanced Parallel Slave mode and Write operations for Dual Buffer Host mode. In Dual Buffer Host mode, the DUALBUF bit (PMPCON<17>) = 1, a write to the MSB triggers the transaction on the PMP port. When MODE16 = 1, MSB = DATAOUT<15:8>. When MODE16 = 0, MSB = DATAOUT<7:0>. **Note:** In Host mode, a read will return the last value written to the register. In Client mode, a read will return indeterminate results. ### REGISTER 23-5: PMDIN: PARALLEL PORT INPUT DATA REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 31:24 | U-0 | | | | | | 31.24 | _ | _ | _ | _ | _ | | _ | _ | | | | | | | 00.46 | U-0 | | | | | | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | | 45.0 | R/W-0 | | | | | | 15:8 | DATAIN<15:8> | | | | | | | | | | | | | | 7:0 | R/W-0 | | | | | | | | | | DATAIN< | <7:0> | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 DATAIN<15:0>: Port Data Input bits This register is used for both Parallel Master Port mode and Enhanced Parallel Slave mode. In Parallel Master mode, a write to the MSB triggers the write transaction on the PMP port. Similarly, a read to the MSB triggers the read transaction on the PMP port. When MODE16 = 1, MSB = DATAIN<15:8>. When MODE16 = 0, MSB = DATAIN<7:0>. Note: This register is not used in Dual Buffer Host mode (i.e., DUALBUF bit (PMPCON<17>) = 1). ### REGISTER 23-6: PMAEN: PARALLEL PORT PIN ENABLE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|----------------------|-------------------|-------------------|--------------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00:40 | R/W-0 | 23:16 | | | | | | | | | | 15:8 | R/W-0 | 13.6 | PTEN<1 | 5:14> <sup>(1)</sup> | | | PTEN• | <13:8> | | | | 7.0 | R/W-0 | 7:0 | | | PTEN | <7:2> | PTEN<1:0> <sup>(2)</sup> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Write '0'; ignore read bit 23-16 PTEN<23:16>: Port Enable bits Valid if the EXADR bit is enabled in Host mode only. PAD enables for PMPCS2a, PMPCS1a, and ADDR<21:16>. bit 15-14 PTEN<15:14>: PMCSx Address Port Enable bits 1 = PMA15 and PMA14 function as either PMA<15:14> or PMCS2 and PMCS1<sup>(1)</sup> 0 = PMA15 and PMA14 function as port I/O bit 13-2 PTEN<13:2>: PMP Address Port Enable bits 1 = PMA<13:2> function as PMP address lines 0 = PMA<13:2> function as port I/O bit 1-0 PTEN<1:0>: PMALH/PMALL Address Port Enable bits 1 = PMA1 and PMA0 function as either PMA<1:0> or PMALH and PMALL(2) 0 = PMA1 and PMA0 pads function as port I/O Note 1: The use of these pins as PMA15/PMA14 or CS2/CS1 is selected by the CSF<1:0> bits (PMCON<7:6>). 2: The use of these pins as PMA1/PMA0 or PMALH/PMALL depends on the Address/Data Multiplex mode selected by the ADRMUX<1:0> bits in the PMCON register. ### REGISTER 23-7: PMSTAT: PARALLEL PORT STATUS REGISTER (CLIENT MODES ONLY) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | 31:24 | _ | | _ | _ | _ | _ | _ | | | 00.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R-0 | R/W-0, HS, SC | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | | 15:8 | IBF | IBOV | _ | _ | IB3F | IB2F | IB1F | IB0F | | 7.0 | R-1 | R/W-0, HS, SC | U-0 | U-0 | R-1 | R-1 | R-1 | R-1 | | 7:0 | OBE | OBUF | _ | _ | OB3E | OB2E | OB1E | OB0E | Legend:HS = Hardware SetSC = Software ClearedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 IBF: Input Buffer Full Status bit 1 = All writable input buffer registers are full 0 = Some or all of the writable input buffer registers are empty bit 14 IBOV: Input Buffer Overflow Status bit 1 = A write attempt to a full input byte buffer occurred (must be cleared in software) 0 = No overflow occurred bit 13-12 Unimplemented: Read as '0' bit 11-8 IBxF: Input Buffer 'x' Status Full bits 1 = Input Buffer contains data that has not been read (reading buffer will clear this bit) 0 = Input Buffer does not contain any unread data bit 7 OBE: Output Buffer Empty Status bit 1 = All readable output buffer registers are empty 0 = Some or all of the readable output buffer registers are full bit 6 **OBUF:** Output Buffer Underflow Status bit 1 = A read occurred from an empty output byte buffer (must be cleared in software) 0 = No underflow occurred bit 5-4 Unimplemented: Read as '0' bit 3-0 OBxE: Output Buffer 'x' Status Empty bits 1 = Output buffer is empty (writing data to the buffer will clear this bit) 0 = Output buffer contains data that has not been transmitted ### REGISTER 23-8: PMWADDR: PARALLEL PORT WRITE ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--| | 24.24 | U-0 | | | | | | | 31:24 | | | _ | _ | _ | _ | _ | _ | | | | | | | | | R/W-0 | | | | | | | 23:16 | CS2a | CS1a | | WADDR<21:16> | | | | | | | | | | | | | WADDR23 | WADDR22 | | | WADDR | ·<21.10> | | | | | | | | | | | R/W-0 | | | | | | | 15:8 | WCS2 | WCS1 | | | WADDE | 242.05 | | | | | | | | | | | WADDR15 | WADDR14 | ADDR14 WADDR<13:8> | | | | | | | | | | | | | 7:0 | R/W-0 | R/W-0 | V-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 | | | | | | | | | | | | | | | R/W-0 | | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23 CS2a: Chip Select 2a bit This bit is only valid when the CSF<1:0> bits = 10 or 01. 1 = Chip Select 2a is active 0 = Chip Select 2a is inactive bit 23 WADDR<23>: Target Address bit 23 This bit is only valid when the CSF<1:0> bits = 0.0 and the EXADR bit = 1 and the DUALBUF bit = 1. bit 22 CS1a: Chip Select 1a bit This bit is only valid when the CSF<1:0> bits = 10. 1 = Chip Select 1a is active 0 = Chip Select 1a is inactive bit 22 WADDR<22>: Target Address bit 22 This bit is only valid when the CSF<1:0> bits = 00 and the EXADR bit = 1 and the DUALBUF bit = 1. bit 21-16 WADDR<21:16>: Address bits This bit is only valid when the EXADR bit = 1 and the DUALBUF bit = 1. bit 15 WCS2: Chip Select 2 bit This bit is only valid when the CSF<1:0> bits = 10 or 01. 1 = Chip Select 2 is active 0 = Chip Select 2 is inactive bit 15 WADDR<15>: Target Address bit 15 This bit is only valid when the CSF<1:0> bits = 00. bit 14 WCS1: Chip Select 1 bit This bit is only valid when the CSF<1:0> bits = 10. 1 = Chip Select 1 is active 0 = Chip Select 1 is inactive bit 14 WADDR<14>: Target Address bit 14 This bit is only valid when the CSF<1:0> bits = 00 or 01. bit 13-0 WADDR<13:0>: Address bits **Note:** This register is only used when the DUALBUF bit (PMCON<17>) is set to '1'. ### REGISTER 23-9: PMRADDR: PARALLEL PORT READ ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |--------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 24.24 | U-0 | | | | | | 31:24 | | | _ | | | _ | _ | _ | | | | | | | | R/W-0 | | | | | | 23:16 | CS2a | CS1a | RADDR<21:16> | | | | | | | | | | | | | RADDR23 | RADDR22 | | | KADDK | NZ1.102 | | | | | | | | | | R/W-0 | | | | | | 15:8 | RCS2 | RCS1 | | | DADDE | 2/12:05 | | | | | | | | | | RADDR15 | RADDR14 RADDR<13:8> | | | | | | | | | | | | | 7:0 | R/W-0 | R/W-0 | V-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 | | | | | | | | | | | | | | RW-0 R/W-0 | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23 CS2a: Chip Select 2a bit This bit is only valid when the CSF<1:0> bits = 10 or 01. 1 = Chip Select 2a is active 0 = Chip Select 2a is inactive bit 23 RADDR<23>: Target Address bit 23 This bit is only valid when the CSF<1:0> bits = 00 and the EXADR bit = 1 and the DUALBUF bit = 1. bit 22 CS1a: Chip Select 1a bit This bit is only valid when the CSF<1:0> bits = 10. 1 = Chip Select 1a is active 0 = Chip Select 1a is inactive bit 22 RADDR<22>: Target Address bit 22 This bit is only valid when the CSF<1:0> bits = 00 and the EXADR bit = 1 and the DUALBUF bit = 1. bit 21-16 RADDR<21:16>: Address bits This bit is only valid when the EXADR bit = 1 and the DUALBUF bit = 1. bit 15 RCS2: Chip Select 2 bit This bit is only valid when the CSF<1:0> bits = 10 or 01. 1 = Chip Select 2 is active 0 = Chip Select 2 is inactive (RADDR15 function is selected) bit 15 RADDR<15>: Target Address bit 15 This bit is only valid when the CSF<1:0> bits = 00. bit 14 RCS1: Chip Select 1 bit This bit is only valid when the CSF<1:0> bits = 10. 1 = Chip Select 1 is active 0 = Chip Select 1 is inactive (RADDR14 function is selected) bit 14 RADDR<14>: Target Address bit 14 This bit is only valid when the CSF<1:0> bits = 00 or 01. bit 13-0 RADDR<13:0>: Address bits **Note:** This register is only used when the DUALBUF bit (PMCON<17>) is set to '1'. ### REGISTER 23-10: PMRDIN: PARALLEL PORT READ INPUT DATA REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | U-0 U-0 | | U-0 | U-0 | | 31.24 | | | _ | _ | _ | _ | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | 15:8 | | | | RDATAIN< | 15:8> | | | | | 7:0 | R/W-0 | | | _ | | RDATAIN< | <7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-8 RDATAIN<15:8>: Port Data <15:8> Input bits Only valid when MODE16 = 1. Used for read operations in Dual Buffer Host mode only. bit 7-0 RDATAIN<7:0>: Port Data <7:0> Input bits Used for read operations in Dual Buffer Host mode only. **Note:** This register is only used when the DUALBUF bit (PMCON<17>) is set to '1' and exclusively for reads. If the DUALBUF bit is '0', the PMDIN register (Register 23-5) is used for reads instead of PMRDIN. | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 24.0 REAL-TIME CLOCK AND CALENDAR (RTCC) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 29. "Real-Time Clock and Calendar (RTCC)" (DS60001125), available from which is the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The RTCC module is intended for applications in which accurate time must be maintained for extended periods of time with minimal or no CPU intervention. Low-power optimization provides extended battery lifetime while keeping track of time. The following are key features of the RTCC module: · Time: hours, minutes and seconds - 24-hour format (military time) - · Visibility of one-half second period - · Provides calendar: Weekday, date, month and year - Alarm intervals are configurable for half of a second, one second, 10 seconds, one minute, 10 minutes, one hour, one day, one week, one month, and one year - · Alarm repeat with decrementing counter - · Alarm with indefinite repeat: Chime - · Year range: 2000 to 2099 - · Leap year correction - · BCD format for smaller firmware overhead - · Optimized for long-term battery operation - · Fractional second synchronization - User calibration of the clock crystal frequency with auto-adjust - Calibration range: ±0.66 seconds error per month - · Calibrates up to 260 ppm of crystal error - Uses external 32.768 kHz crystal or 32 kHz internal oscillator - Alarm pulse, seconds clock, or internal clock output on RTCC pin ### FIGURE 24-1: RTCC BLOCK DIAGRAM # 24.1 RTCC Control Registers # TABLE 24-1: RTCC REGISTER MAP | ess | | • | | | | | | | | | Bits | | | | | | | | | |-----------------------------|---------------------------------|-----------|--------|-------|---------|----------|-------|--------|----------|--------|----------|--------------------|---------|-------|---------|---------|---------|-------|------------| | Virtual Address<br>(BF8C_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0000 | DTCCON | 31:16 | _ | _ | _ | _ | _ | _ | | | | | CAL | <9:0> | | | | | 0000 | | 0000 | RTCCON | 15:0 | ON | _ | SIDL | _ | _ | RTCCLK | SEL<1:0> | RTCOUT | SEL<1:0> | RTCCLKON | _ | _ | RTCWREN | RTCSYNC | HALFSEC | RTCOE | 0000 | | 0010 | RTCALRM | 31:16 | _ | _ | _ | _ | _ | - | - | 1 | - | - | - | _ | _ | _ | _ | _ | 0000 | | 0010 | INTOALINI | 15:0 | ALRMEN | CHIME | PIV | ALRMSYNC | | AMAS | K<3:0> | | | | | ARP | T<7:0> | | | | 0000 | | 0020 | RTCTIME | 31:16 | | HR1 | 0<3:0> | | | HR01 | <3:0> | | | MIN10 | <3:0> | | | MIN01 | <3:0> | | xxxx | | 0020 | KICIIVIL | 15:0 | | SEC1 | 10<3:0> | | | SEC0 | 1<3:0> | | _ | _ | _ | _ | _ | _ | _ | _ | xx00 | | 0030 | RTCDATE | 31:16 | | YEAR | 10<3:0> | | | YEAR | 1<3:0> | | | MONTH <sup>2</sup> | 10<3:0> | | | MONTH | 01<3:0> | | xxxx | | 0030 | RICDAIL | 15:0 | | DAY1 | 10<3:0> | | | DAY0 | 1<3:0> | | _ | _ | _ | _ | | WDAY0 | 1<3:0> | | xx00 | | 0040 | ALRMTIME | 31:16 | | HR1 | 0<3:0> | | | HR01 | <3:0> | | | MIN10 | <3:0> | | | MIN01 | <3:0> | | xxxx | | 0040 | ALKIVITIVIE | 15:0 | | SEC1 | 10<3:0> | | | SEC0 | 1<3:0> | | | _ | | _ | _ | _ | _ | _ | xx00 | | 0050 | ALRMDATE | 31:16 | | _ | _ | _ | _ | - | | I | | MONTH' | 10<3:0> | | | MONTH | 01<3:0> | | 00xx | | 0050 | ALKIVIDATE | 15:0 | | DAY1 | 10<3:0> | | • | DAY0 | 1<3:0> | • | _ | _ | _ | _ | | WDAY | 1<3:0> | | xx0x | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. PIC32MK GPK/MCM with CAN FD Family ### REGISTER 24-1: RTCCON: REAL-TIME CLOCK AND CALENDAR CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|---------------------|-----------------------------|-------------------|-------------------|----------------------------|-------------------|------------------------|---------------------------------|--|--|--|--|--|--| | 24.24 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | | | | | | | 31:24 | _ | _ | _ | _ | _ | _ | CAL | _<9:8> | | | | | | | | 00.46 | R/W-0 | | | | | | | 23:16 | CAL<7:0> | | | | | | | | | | | | | | | | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | | 15:8 | ON <sup>(1)</sup> | _ | SIDL | | _ | RTCCLK | (SEL<1:0> | RTC<br>OUTSEL<1> <sup>(2)</sup> | | | | | | | | | R/W-0 | R-0 | U-0 | U-0 | R/W-0 | R-0 | R-0 | R/W-0 | | | | | | | | 7:0 | RTC<br>OUTSEL<0>(2) | RTC<br>CLKON <sup>(5)</sup> | _ | _ | RTC<br>WREN <sup>(3)</sup> | RTC<br>SYNC | HALFSEC <sup>(4)</sup> | RTCOE | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-26 Unimplemented: Read as '0' bit 25-16 **CAL<9:0>:** Real-Time Clock Drift Calibration bits, which contain a signed 10-bit integer value 0111111111 = Maximum positive adjustment, adds 511 real-time clock pulses every one minute • 000000001 = Minimum positive adjustment, adds 1 real-time clock pulse every one minute 0000000000 = No adjustment 1111111111 = Minimum negative adjustment, subtracts 1 real-time clock pulse every one minute . 1000000000 = Maximum negative adjustment, subtracts 512 real-time clock pulses every one minute bit 15 **ON:** RTCC On bit<sup>(1)</sup> 1 = RTCC module is enabled 0 = RTCC module is disabled bit 14 Unimplemented: Read as '0' bit 13 SIDL: Stop in Idle Mode bit 1 = Disables RTCC operation when CPU enters Idle mode 0 = Continue normal operation when CPU enters Idle mode bit 12-11 Unimplemented: Read as '0' **Note 1:** The ON bit is only writable when RTCWREN = 1. 2: Requires RTCOE = 1 (RTCCON<0>) for the output to be active. 3: The RTCWREN bit can be set only when the write sequence is enabled. 4: This bit is read-only. It is cleared to '0' on a write to the seconds bit fields (RTCTIME<14:8>). 5: This bit is undefined when RTCCLKSEL<1:0> = 00 (LPRC is the clock source). **Note:** This register is reset only on a POR. ### REGISTER 24-1: RTCCON: REAL-TIME CLOCK AND CALENDAR CONTROL REGISTER bit 10-9 RTCCLKSEL<1:0>: RTCC Clock Select bits When a new value is written to these bits, the Seconds Value register should also be written to properly reset the clock prescalers in the RTCC. - 11 = Reserved - 10 = Reserved - 01 = RTCC uses the external 32.768 kHz Secondary Oscillator (SOSC) - 00 = RTCC uses the internal 32 kHz oscillator (LPRC) - bit 8-7 RTCOUTSEL<1:0>: RTCC Output Data Select bits(2) - 11 = Reserved - 10 = RTCC Clock is presented on the RTCC pin - 01 = Seconds Clock is presented on the RTCC pin - 00 = Alarm Pulse is presented on the RTCC pin when the alarm interrupt is triggered - bit 6 RTCCLKON: RTCC Clock Enable Status bit (5) - 1 = RTCC Clock is actively running - 0 = RTCC Clock is not running - bit 5-4 Unimplemented: Read as '0' - bit 3 RTCWREN: Real-Time Clock Value Registers Write Enable bit (3) - 1 = Real-Time Clock Value registers can be written to by the user - 0 = Real-Time Clock Value registers are locked out from being written to by the user - bit 2 RTCSYNC: Real-Time Clock Value Registers Read Synchronization bit - 1 = Real-time clock value registers can change while reading (due to a rollover ripple that results in an invalid data read). If the register is read twice and results in the same data, the data can be assumed to be valid. - 0 = Real-time clock value registers can be read without concern about a rollover ripple - bit 1 HALFSEC: Half-Second Status bit<sup>(4)</sup> - 1 = Second half period of a second - 0 = First half period of a second - bit 0 RTCOE: RTCC Output Enable bit - 1 = RTCC output is enabled - 0 = RTCC output is not enabled - **Note 1:** The ON bit is only writable when RTCWREN = 1. - 2: Requires RTCOE = 1 (RTCCON<0>) for the output to be active. - 3: The RTCWREN bit can be set only when the write sequence is enabled. - 4: This bit is read-only. It is cleared to '0' on a write to the seconds bit fields (RTCTIME<14:8>). - 5: This bit is undefined when RTCCLKSEL<1:0> = 00 (LPRC is the clock source). **Note:** This register is reset only on a POR. ### REGISTER 24-2: RTCALRM: REAL-TIME CLOCK ALARM CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------------|----------------------|--------------------|-------------------|-------------------|-------------------|----------------------|------------------| | 24.24 | U-0 | 31:24 | | - | _ | | _ | - | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | R/W-0 | R/W-0 | R-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15:8 | ALRMEN <sup>(1,2)</sup> | CHIME <sup>(2)</sup> | PIV <sup>(2)</sup> | ALRMSYNC | | AMASK | <3:0> <sup>(2)</sup> | | | 7.0 | R/W-0 | 7:0 | | | | ARPT<7:0 | >(2) | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 ALRMEN: Alarm Enable bit<sup>(1,2)</sup> 1 = Alarm is enabled 0 = Alarm is disabled bit 14 **CHIME:** Chime Enable bit<sup>(2)</sup> 1 = Chime is enabled – ARPT<7:0> is allowed to rollover from 0x00 to 0xFF 0 = Chime is disabled – ARPT<7:0> stops once it reaches 0x00 bit 13 **PIV:** Alarm Pulse Initial Value bit<sup>(2)</sup> When ALRMEN = 0, PIV is writable and determines the initial value of the Alarm Pulse. When ALRMEN = 1, PIV is read-only and returns the state of the Alarm Pulse. - bit 12 **ALRMSYNC:** Alarm Sync bit - 1 = ARPT<7:0> and ALRMEN may change as a result of a half second rollover during a read. The ARPT must be read repeatedly until the same value is read twice. This must be done since multiple bits may be changing. - 0 = ARPT<7:0> and ALRMEN can be read without concerns of rollover because the prescaler is more than 32 real-time clocks away from a half-second rollover - bit 11-8 AMASK<3:0>: Alarm Mask Configuration bits<sup>(2)</sup> 0000 = Every half-second 0001 = Every second 0010 = Every 10 seconds 0011 = Every minute 0100 = Every 10 minutes 0101 = Every hour 0110 = Once a day 0111 = Once a week 1000 = Once a month 1001 = Once a year (except when configured for February 29, once every four years) 1010 = Reserved 1011 = Reserved 11xx = Reserved - **Note 1:** Hardware clears the ALRMEN bit anytime the alarm event occurs, when ARPT<7:0> = 00 and CHIME = 0. - 2: This field should not be written when the RTCC ON bit = '1' (RTCCON<15>) and ALRMSYNC = 1. Note: The RTCALRM register is reset on a MCLR or Power-on Reset (POR) ## REGISTER 24-2: RTCALRM: REAL-TIME CLOCK ALARM CONTROL REGISTER (CONTINUED) bit 7-0 ARPT<7:0>: Alarm Repeat Counter Value bits<sup>(2)</sup> 11111111 = Alarm will trigger 256 times : 00000000 =Alarm will trigger one time The counter decrements on any alarm event. The counter only rolls over from 0x00 to 0xFF if CHIME = 1. - Note 1: Hardware clears the ALRMEN bit anytime the alarm event occurs, when ARPT<7:0> = 00 and CHIME = 0. - 2: This field should not be written when the RTCC ON bit = '1' (RTCCON<15>) and ALRMSYNC = 1. Note: The RTCALRM register is reset on a MCLR or Power-on Reset (POR). ### REGISTER 24-3: RTCTIME: REAL-TIME CLOCK TIME VALUE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | R/W-x | 31.24 | | HR10 | <3:0> | | | HR01 | <3:0> | | | 00.40 | R/W-x | 23:16 | | MIN10 | <3:0> | | | MIN01 | <3:0> | | | 45.0 | R/W-x | 15:8 | | SEC10 | <3:0> | | | SEC01 | I<3:0> | | | 7.0 | U-0 | 7:0 | | _ | _ | - | _ | _ | _ | _ | ### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 **HR10<3:0>:** Binary-Coded Decimal Value of Hours bits, 10 digits; contains a value from 0 to 2 bit 27-24 HR01<3:0>: Binary-Coded Decimal Value of Hours bits, 1 digit; contains a value from 0 to 9 bit 23-20 MIN10<3:0>: Binary-Coded Decimal Value of Minutes bits, 10 digits; contains a value from 0 to 5 bit 19-16 MIN01<3:0>: Binary-Coded Decimal Value of Minutes bits, 1 digit; contains a value from 0 to 9 bit 15-12 SEC10<3:0>: Binary-Coded Decimal Value of Seconds bits, 10 digits; contains a value from 0 to 5 bit 11-8 SEC01<3:0>: Binary-Coded Decimal Value of Seconds bits, 1 digit; contains a value from 0 to 9 bit 7-0 Unimplemented: Read as '0' **Note:** This register is only writable when RTCWREN = 1 (RTCCON<3>). ### REGISTER 24-4: RTCDATE: REAL-TIME CLOCK DATE VALUE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|--------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | R/W-x | 31:24 | | YEAR1 | 0<3:0> | • | | YEAR0 | 1<3:0> | • | | 00.40 | R/W-x | 23:16 | | MONTH <sup>2</sup> | 10<3:0> | | | MONTH | 01<3:0> | | | 45.0 | R/W-x | 15:8 | | DAY10 | <3:0> | | | DAY01 | <3:0> | | | 7.0 | U-0 | U-0 | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | | 7:0 | _ | _ | _ | _ | | WDAY0 | 1<3:0> | | ### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 YEAR10<3:0>: Binary-Coded Decimal Value of Years bits, 10 digits bit 27-24 YEAR01<3:0>: Binary-Coded Decimal Value of Years bits, 1 digit bit 23-20 MONTH10<3:0>: Binary-Coded Decimal Value of Months bits, 10 digits; contains a value from 0 to 1 bit 19-16 MONTH01<3:0>: Binary-Coded Decimal Value of Months bits, 1 digit; contains a value from 0 to 9 bit 15-12 DAY10<3:0>: Binary-Coded Decimal Value of Days bits, 10 digits; contains a value from 0 to 3 bit 11-8 DAY01<3:0>: Binary-Coded Decimal Value of Days bits, 1 digit; contains a value from 0 to 9 bit 7-4 Unimplemented: Read as '0' bit 3-0 WDAY01<3:0>: Binary-Coded Decimal Value of Weekdays bits,1 digit; contains a value from 0 to 6 **Note:** This register is only writable when RTCWREN = 1 (RTCCON<3>). ### REGISTER 24-5: ALRMTIME: ALARM TIME VALUE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | R/W-x | 31:24 | | HR10 | <3:0> | | | HR01 | <3:0> | | | 00:40 | R/W-x | 23:16 | | MIN10 | <3:0> | | | MIN01 | <3:0> | | | 45.0 | R/W-x | 15:8 | | SEC10 | <3:0> | | | SEC01 | I<3:0> | | | 7.0 | U-0 | 7:0 | _ | _ | _ | _ | _ | _ | _ | _ | ### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 **HR10<3:0>:** Binary Coded Decimal value of hours bits, 10 digits; contains a value from 0 to 2 bit 27-24 **HR01<3:0>:** Binary Coded Decimal value of hours bits, 1 digit; contains a value from 0 to 9 bit 23-20 **MIN10<3:0>:** Binary Coded Decimal value of minutes bits, 10 digits; contains a value from 0 to 5 bit 19-16 MIN01<3:0>: Binary Coded Decimal value of minutes bits, 1 digit; contains a value from 0 to 9 bit 15-12 **SEC10<3:0>:** Binary Coded Decimal value of seconds bits, 10 digits; contains a value from 0 to 5 bit 11-8 **SEC01<3:0>:** Binary Coded Decimal value of seconds bits, 1 digit; contains a value from 0 to 9 bit 7-0 **Unimplemented:** Read as '0' ### REGISTER 24-6: ALRMDATE: ALARM DATE VALUE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | U-0 | 31:24 | _ | _ | _ | - | _ | - | _ | _ | | 00.46 | R/W-x | 23:16 | | MONT | H10<3:0> | | | MONTH | 01<3:0> | | | 45.0 | R/W-x | 15:8 | | DAY <sup>2</sup> | 10<1:0> | | | DAY01 | l<3:0> | | | 7.0 | U-0 | U-0 | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | | 7:0 | _ | _ | _ | _ | | WDAY0 | 1<3:0> | | | 10 | ae | n | a | | |----|----|---|---|---| | Le | ye | n | u | • | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23-20 MONTH10<3:0>: Binary Coded Decimal value of months bits, 10 digits; contains a value from 0 to 1 bit 19-16 MONTH01<3:0>: Binary Coded Decimal value of months bits, 1 digit; contains a value from 0 to 9 bit 15-12 DAY10<3:0>: Binary Coded Decimal value of days bits, 10 digits; contains a value from 0 to 3 bit 11-8 DAY01<3:0>: Binary Coded Decimal value of days bits, 1 digit; contains a value from 0 to 9 bit 7-4 Unimplemented: Read as '0' bit 3-0 WDAY01<3:0>: Binary Coded Decimal value of weekdays bits, 1 digit; contains a value from 0 to 6 # 25.0 12-BIT HIGH-SPEED SUCCESSIVE APPROXIMATION REGISTER (SAR) ANALOG-TODIGITAL CONVERTER (ADC) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 22. "12-bit High-Speed Successive Approximation Register (SAR) Analog-to-Digital Converter (ADC)" (DS60001344) in the "PIC32 Family Reference Manual", which is available from the Microchip web site (www.microchip.com/PIC32). The 12-bit High-Speed Successive Approximation Register (SAR) analog-to-digital converter (ADC) includes the following features: - · 12-bit resolution - Seven ADC modules with dedicated Sample and Hold (S&H) circuits - Up to 6 dedicated class1 ADC modules can be combined using an interleave technique to provide conversion rates up to 20msps. (See application note: "AN2785\_World's Fastest Embedded Interleaved 12- bit ADC Using PIC32MZ and PIC32MK Families" - Up to 45 analog input sources, in addition to the internal CTMU, internal voltage reference and internal temperature sensor - · Single-ended and/or differential inputs - · Supports touch sense applications - · Four digital comparators - · Four digital filters supporting two modes: - Oversampling mode - Averaging mode - Early interrupt generation resulting in faster processing of converted data - Designed for power conversion and general purpose applications - · Operation during Sleep and Idle modes A simplified block diagram of the ADC module is illustrated in Figure 25-1. The 12-bit HS SAR ADC has up to six dedicated ADC modules (ADC0-ADC5) and one shared ADC module (ADC7). The dedicated ADC modules use a single input (or its alternate) and are intended for high-speed and precise sampling of time-sensitive or transient inputs. The shared ADC module incorporates a multiplexer on the input to facilitate a larger group of inputs, with slower sampling, and provides flexible automated scanning option through the input scan logic. For each ADC module, the analog inputs are connected to the S&H capacitor. The clock, sampling time, and output data resolution for each ADC module can be set independently. The ADC module performs the conversion of the input analog signal based on the configurations set in the registers. When conversion is complete, the final result is stored in the result buffer for the specific analog input and is passed to the digital filter and digital comparator if configured to use data from this particular sample. Input to ADCx mapping is illustrated in Figure 25-2. ### 25.1 Activation Sequence The following ADCx activation sequence is to be followed at all times: **Step 1:** Initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 0xBF887D00, respectively. Then, configure the AICPMPEN bit (ADCCON1<12> and the IOANCPEN bit (CFGCON<7>) = 1 if and only if VDD is less than 2.5V. The default is '0', which assumes VDD is greater than or equal to 2.5V. **Step 2:** The user writes all the essential ADC configuration SFRs including the ADC control clock and all ADC core clocks setup: - ADCCON1, keeping the ON bit = 0 - ADCCON2, especially paying attention to ADCDIV<6:0> and SAMC<9:0> - ADCANCON, keeping all analog enables ANENx bit = 0, WKUPCLKCNT bit = 0xA - ADCCON3, keeping all DIGEN5x = 0, especially paying attention to ADCSEL<1:0>, CONCLKDIV <5:0>, and VREFSEL<2:0> - ADCxTIME, ADCDIVx<6:0>, and SAMCx<9:0> - ADCTRGMODE, ADCIMCONX, ADCTRGSNS, ADCCSSX, ADCGIRQENX, ADCTRGX, ADCBASE - · Comparators, Filters, etc. **Step 3:** The user sets the ANENx bit to '1' for the ADC SAR Cores needed (which internally in the ADC module enables the control clock to generate by division the core clocks for the desired ADC SAR Cores, which in turn enables the bias circuitry for these ADC SAR Cores). **Step 4:** The user sets the ON bit to '1', which enables the ADC control clock. **Step 5:** The user waits for the interrupt/polls the BGVRRDY bit (ADCCON2<31>) and the WKRDYx bit (ADCANCON<15,13:8>) = 1, which signals that the device analog environment (band gap and VREF) is ready. **Step 6:** Set the DIGENx bit (ADCCON3<15,13:8>) to '1', which enables the digital circuitry to immediately begin processing incoming triggers to perform data conversions. Never activate ADC triggers sources Note: For the best optimized CPU and ISR performance the user should refer to Table 81. The CPU interrupt latency is ~43 SYSCLK cycles if no other interrupts are pending. If not using ADC DMA and the ADC combined sum throughput rate of all the ADC modules in use is greater than (SYSCLK / 43) = 2.8 Msps, it is recommended to use the ADC CPU early interrupt generation, defined in the ADCxTIME and ADCEIENx registers. This will reduce the probability of the ADC results being overwritten by the next conversion before the CPU can read the previous ADC Do not use the early interrupts if using the ADC in the DMA module. **Note:** If using ADC DMA, ADC source clock MUST be SYSCLK only. Non-interleaved Dedicated Class\_1 ADCx Throughput rate - = 1/((Sample time + Conversion time)(TAD)) - = 1 / ((SAMC+# bit resolution+1)(TAD)) ### Example: SAMC = 3 TAD, 12-bit mode, TAD = 16.667 ns = 60 MHz Throughput rate: - = 1 / ((3+12+1)(16.667 ns)) - = 1/(16 \* 16.667 ns) - = 3.75msps until after ADC has been completely initialized, enabled and warm up time complete. result(s). TABLE 25-1: PIC32MKXXX BASED ON 60 MHZ TAD CLOCK (16.667 ns) | Number of<br>Interleaved ADCs<br>Used | 12-bit (Max) Msps | 10-bit (Max) Msps | 8-bit (Max) Msps | 6-bit (Max) Msps | |---------------------------------------|-------------------|-------------------|------------------|------------------| | 1 | 3.75 | 4.286 | 5.0 | 6.0 | | 2 | 7.50 | 8.571 | 10.00 | 12.00 | | 3 | 10.00 | 12.00 | 15.00 | 15.00 | | 4 | 15.00 | 17.1429 | 20.00 | 24.00 | | 5 | 15.00 | 20.00 | 20.00 | 30.00 | | 6 <sup>(2)</sup> | 20.00 | 24.00 | 30.00 | 30.00 | - **Note 1:** Interleaved ADCs in this context means connecting the same analog source signal to multiple dedicated Class\_1 ADCs (i.e., ADC0-ADC5), and using independent staggered trigger sources accordingly for each interleaved ADC. - 2: Only available in the Motor Control Variant, i.e., PIC32MKXXMCXX. FIGURE 25-1: ADC BLOCK DIAGRAM FIGURE 25-2: S&H BLOCK DIAGRAM # 25.2 ADC Control Registers # TABLE 25-2: ADC REGISTER MAP | | | Bits gg | | | | | | | | | | | | | | | | | | |--------------------|------------------|-----------|------------------------|------------------------|------------------------|-----------------------|-----------------------|-----------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------| | Virtual<br>Address | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 7000 | ADCCON1 | 31:16 | | _ | _ | | | _ | _ | _ | FRACT | SELRE | S<1:0> | | ST | RGSRC<4:0 | > | | 0600 | | | | 15:0 | ON | _ | SIDL | AICPMPEN | CVDEN | FSSCLKEN | FSPBCLKEN | _ | _ | | IRQVS<2:0> | | STRGLVL | _ | _ | _ | 0000 | | 7010 | ADCCON2 | 31:16 | BGVRRDY | REFFLT | EOSRDY | ( | CVDCPL<2:0 | > | | | | | SAMC | <9:0> | | | | | 0000 | | | | 15:0 | BGVRIEN | REFFLTIEN | EOSIEN | ADCEIOVR | _ | | ADCEIS<2:0> | | _ | | | Α | ADCDIV<6:0> | | | | 0000 | | 7020 | ADCCON3 | 31:16 | ADCSE | EL<1:0> | | | CONCLK | (DIV<5:0> | | | DIGEN7 | _ | DIGEN5 | DIGEN4 | DIGEN3 | DIGEN2 | DIGEN1 | DIGEN0 | 0000 | | | | 15:0 | \ | /REFSEL<2:0 | )> | TRGSUSP | UPDIEN | UPDRDY | SAMP | RQCNVRT | GLSWTRG | GSWTRG | | | ADINSE | L<5:0> | | | 0000 | | 7030 | ADCTRGMODE | 31:16 | I | _ | _ | _ | SH5AL | .T<1:0> | SH4AL | T<1:0> | SH3AI | LT<1:0> | SH2AL | T<1:0> | SH1AL | T<1:0> | SH0AL | .T<1:0> | 0000 | | | | 15:0 | 1 | _ | STRGEN5 | STRGEN4 | STRGEN3 | STRGEN2 | STRGEN1 | STRGEN0 | _ | _ | SSAMPEN5 | SSAMPEN4 | SSAMPEN3 | SSAMPEN2 | SSAMPEN1 | SSAMPEN | 0000 | | 7040 | ADCIMCON1 | 31:16 | DIFF15 | SIGN15 | DIFF14 | SIGN14 | DIFF13 | SIGN13 | DIFF12 | SIGN12 | DIFF11 | SIGN11 | DIFF10 | SIGN10 | DIFF9 | SIGN9 | DIFF8 | SIGN8 | 0000 | | | | 15:0 | DIFF7 | SIGN7 | DIFF6 | SIGN6 | DIFF5 | SIGN5 | DIFF4 | SIGN4 | DIFF3 | SIGN3 | DIFF2 | SIGN2 | DIFF1 | SIGN1 | DIFF0 | SIGN0 | 0000 | | 7050 | ADCIMCON2 | 31:16 | - | _ | _ | _ | - | _ | _ | _ | DIFF27 | SIGN27 | DIFF26 | SIGN26 | DIFF25 | SIGN25 | DIFF24 | SIGN24 | 0000 | | | | 15:0 | DIFF23 <sup>(1)</sup> | SIGN23 <sup>(1)</sup> | DIFF22 <sup>(1)</sup> | SIGN22 <sup>(1)</sup> | DIFF21 <sup>(1)</sup> | SIGN21 <sup>(1)</sup> | DIFF20 <sup>(1)</sup> | SIGN20 <sup>(1)</sup> | DIFF19 | SIGN19 | DIFF18 | SIGN18 | DIFF17 | SIGN17 | DIFF16 | SIGN16 | 0000 | | 7060 | ADCIMCON3 | 31:16 | DIFF47 <sup>(1)</sup> | SIGN47 <sup>(1)</sup> | DIFF46 <sup>(1)</sup> | SIGN46 <sup>(1)</sup> | DIFF45 <sup>(1)</sup> | SIGN45 <sup>(1)</sup> | _ | _ | _ | _ | _ | l | DIFF41 <sup>(1)</sup> | SIGN41 <sup>(1)</sup> | DIFF40 <sup>(1)</sup> | SIGN40 <sup>(1)</sup> | 0000 | | | | 15:0 | DIFF39 <sup>(1)</sup> | SIGN39 <sup>(1)</sup> | DIFF38 <sup>(1)</sup> | SIGN38 <sup>(1)</sup> | DIFF37 <sup>(1)</sup> | SIGN37 <sup>(1)</sup> | DIFF36 <sup>(1)</sup> | SIGN36 <sup>(1)</sup> | DIFF35 <sup>(1)</sup> | SIGN35 <sup>(1)</sup> | DIFF34 <sup>(1)</sup> | SIGN34 <sup>(1)</sup> | DIFF33 <sup>(1)</sup> | SIGN33 <sup>(1)</sup> | _ | _ | 0000 | | 7070 | ADCIMCON4 | 31:16 | - | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | 0000 | | | | 15:0 | - | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | - | DIFF49 | SIGN49 | DIFF48 | SIGN48 | 0000 | | 7080 | ADCGIRQEN1 | 31:16 | - | _ | _ | _ | AGIEN27 | AGIEN26 | AGIEN25 | AGIEN24 | AGIEN23 <sup>(1)</sup> | AGIEN22 <sup>(1)</sup> | AGIEN21 <sup>(1)</sup> | AGIEN20 <sup>(1)</sup> | AGIEN19 | AGIEN18 | AGIEN17 | AGIEN16 | 0000 | | | | 15:0 | AGIEN15 | AGIEN14 | AGIEN13 | AGIEN12 | AGIEN11 | AGIEN10 | AGIEN9 | AGIEN8 | AGIEN7 | AGIEN6 | AGIEN5 | AGIEN4 | AGIEN3 | AGIEN2 | AGIEN1 | AGIEN0 | 0000 | | 7090 | ADCGIRQEN2 | 31:16 | - | _ | _ | _ | - | _ | _ | _ | _ | _ | AGIEN53 <sup>(2)</sup> | l | _ | AGIEN50 <sup>(2)</sup> | AGIEN49 | AGIEN48 | 0000 | | | | 15:0 | AGIEN47 <sup>(1)</sup> | AGIEN46 <sup>(1)</sup> | AGIEN45 <sup>(1)</sup> | _ | - | _ | AGIEN41 <sup>(1)</sup> | AGIEN40 <sup>(1)</sup> | AGIEN39 <sup>(1)</sup> | AGIEN38 <sup>(1)</sup> | AGIEN37 <sup>(1)</sup> | AGIEN36 <sup>(1)</sup> | AGIEN35 <sup>(1)</sup> | AGIEN34 <sup>(1)</sup> | AGIEN33 <sup>(1)</sup> | AGIEN32 <sup>(1)</sup> | 0000 | | 70A0 | ADCCSS1 | 31:16 | _ | _ | _ | _ | CSS27 | CSS26 | CSS25 | CSS24 | CSS23 <sup>(1)</sup> | CSS22 <sup>(1)</sup> | CSS21 <sup>(1)</sup> | CSS20 <sup>(1)</sup> | CSS19 | CSS18 | CSS17 | CSS16 | 0000 | | | | 15:0 | CSS15 | CSS14 | CSS13 | CSS12 | CSS11 | CSS10 | CSS9 | CSS8 | CSS7 | CSS6 | CSS5 | CSS4 | CSS3 | CSS2 | CSS1 | CSS0 | 0000 | | 70B0 | ADCCSS2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CSS53 | _ | _ | CSS50 | CSS49 | CSS48 | 0000 | | | | 15:0 | CSS47 <sup>(1)</sup> | CSS46 <sup>(1)</sup> | CSS45 <sup>(1)</sup> | _ | _ | _ | CSS41 <sup>(1)</sup> | CSS40 <sup>(1)</sup> | CSS39 <sup>(1)</sup> | CSS38 <sup>(1)</sup> | CSS37 <sup>(1)</sup> | CSS36 <sup>(1)</sup> | CSS35 <sup>(1)</sup> | CSS34 <sup>(1)</sup> | CSS33 <sup>(1)</sup> | _ | 0000 | | 70C0 | ADCDSTAT1 | 31:16 | - | _ | _ | _ | ARDY27 | ARDY26 | ARDY25 | ARDY24 | ARDY23 <sup>(1)</sup> | ARDY22 <sup>(1)</sup> | ARDY21 <sup>(1)</sup> | ARDY20 <sup>(1)</sup> | ARDY19 | ARDY18 | ARDY17 | ARDY16 | 0000 | | | | 15:0 | ARDY15 | ARDY14 | ARDY13 | ARDY12 | ARDY11 | ARDY10 | ARDY9 | ARDY8 | ARDY7 | ARDY6 | ARDY5 | ARDY4 | ARDY3 | ARDY2 | ARDY1 | ARDY0 | 0000 | | 70D0 | ADCDSTAT2 | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | ARDY53 | - | _ | ARDY50 | ARDY49 | ARDY48 | 0000 | | | | 15:0 | ARDY47 <sup>(1)</sup> | ARDY46 <sup>(1)</sup> | ARDY45 <sup>(1)</sup> | _ | 1 | _ | ARDY41 <sup>(1)</sup> | ARDY40 <sup>(1)</sup> | ARDY39 <sup>(1)</sup> | ARDY38 <sup>(1)</sup> | ARDY37 <sup>(1)</sup> | ARDY36 <sup>(1)</sup> | ARDY35 <sup>(1)</sup> | ARDY34 <sup>(1)</sup> | ARDY33 <sup>(1)</sup> | _ | 0000 | | 70E0 | ADCCMPEN1 | 31:16 | _ | _ | _ | _ | CMPE27 | CMPE26 | CMPE25 | CMPE24 | CMPE23 <sup>(1)</sup> | CMPE22 <sup>(1)</sup> | CMPE21 <sup>(1)</sup> | CMPE20 <sup>(1)</sup> | CMPE19 | CMPE18 | CMPE17 | CMPE16 | 0000 | | | | 15:0 | CMPE15 | CMPE14 | CMPE13 | CMPE12 | CMPE11 | CMPE10 | CMPE9 | CMPE8 | CMPE7 | CMPE6 | CMPE5 | CMPE4 | CMPE3 | CMPE2 | CMPE1 | CMPE0 | 0000 | | 70F0 | ADCCMP1 | 31:16 | | | | | | | | DCMPHI | <15:0> | | | | | | | | 0000 | | | | 15:0 | | DCMPLO<15:0> 0000 | | | | | | | | | | | | | | | | PIC32MK GPK/MCM with CAN FD Family Note This register is for internal ADC input sources (i.e., IVREF and CTMU Temperature Sensor. Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 0xBF887D00, respectively. 1: 2: 3: TABLE 25-2: ADC REGISTER MAP (CONTINUED) | " | | ø. | | | | | | | | Bit | s | | | | | | | | छ | |--------------------|------------------------|-----------|--------|----------|--------|---------------|----------------|------------|--------|---------|-----------------------|-----------------------|-----------------------|-----------------------|--------|-------------|----------|--------|------------| | Virtual<br>Address | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 7100 | ADCCMPEN2 | 31:16 | _ | _ | _ | _ | CMPE27 | CMPE26 | CMPE25 | CMPE24 | CMPE23 <sup>(1)</sup> | CMPE22 <sup>(1)</sup> | CMPE21 <sup>(1)</sup> | CMPE20 <sup>(1)</sup> | CMPE19 | CMPE18 | CMPE17 | CMPE16 | 000 | | | | 15:0 | CMPE15 | CMPE14 | CMPE13 | CMPE12 | CMPE11 | CMPE10 | CMPE9 | CMPE8 | CMPE7 | CMPE6 | CMPE5 | CMPE4 | CMPE3 | CMPE2 | CMPE1 | CMPE0 | 000 | | 7110 | ADCCMP2 | 31:16 | | | • | • | • | • | • | DCMPHI | <15:0> | • | | • | | | • | • | 000 | | | | 15:0 | | | | | | | | DCMPLC | <15:0> | | | | | | | | 000 | | 7120 | ADCCMPEN3 | 31:16 | _ | _ | _ | _ | CMPE27 | CMPE26 | CMPE25 | CMPE24 | CMPE23 <sup>(1)</sup> | CMPE22 <sup>(1)</sup> | CMPE21 <sup>(1)</sup> | CMPE20 <sup>(1)</sup> | CMPE19 | CMPE18 | CMPE17 | CMPE16 | 000 | | | | 15:0 | CMPE15 | CMPE14 | CMPE13 | CMPE12 | CMPE11 | CMPE10 | CMPE9 | CMPE8 | CMPE7 | CMPE6 | CMPE5 | CMPE4 | CMPE3 | CMPE2 | CMPE1 | CMPE0 | 000 | | 7130 | ADCCMP3 | 31:16 | | | | DCMPHI<15:0> | | | | | | | | | 000 | | | | | | | | 15:0 | | | | | | | | DCMPLC | <15:0> | | | | | | | | 000 | | 7140 | ADCCMPEN4 | 31:16 | _ | _ | _ | _ | CMPE27 | CMPE26 | CMPE25 | CMPE24 | CMPE23 <sup>(1)</sup> | CMPE22 <sup>(1)</sup> | CMPE21 <sup>(1)</sup> | CMPE20 <sup>(1)</sup> | CMPE19 | CMPE18 | CMPE17 | CMPE16 | 000 | | | | 15:0 | CMPE15 | CMPE14 | CMPE13 | CMPE12 | CMPE11 | CMPE10 | CMPE9 | CMPE8 | CMPE7 | CMPE6 | CMPE5 | CMPE4 | CMPE3 | CMPE2 | CMPE1 | CMPE0 | 0000 | | 7150 | ADCCMP4 | 31:16 | | • | • | • | • | • | • | DCMPHI | <15:0> | • | • | • | | • | <u>-</u> | • | 000 | | | | 15:0 | | | | | | | | DCMPLC | <15:0> | | | | | | | | 000 | | 71A0 | ADCFLTR1 | 31:16 | AFEN | DATA16EN | DFMODE | ( | OVRSAM<2:0 | > | AFGIEN | AFRDY | _ | _ | _ | | C | HNLID<4:0> | | | 000 | | | | 15:0 | | | | | FLTRDATA<15:0> | | | | | | | | | | | | 000 | | 71B0 | ADCFLTR2 | 31:16 | AFEN | DATA16EN | DFMODE | ( | OVRSAM<2:0 | > | AFGIEN | AFRDY | _ | _ | _ | | C | CHNLID<4:0> | | | 0000 | | | | 15:0 | | | | | | | | FLTRDAT | A<15:0> | | | | | | | | 0000 | | 71C0 | ADCFLTR3 | 31:16 | AFEN | DATA16EN | DFMODE | ( | OVRSAM<2:0 | > | AFGIEN | AFRDY | _ | _ | _ | CHNLID<4:0> | | | | | | | | | 15:0 | | | | | | | | FLTRDAT | A<15:0> | | | | | | | | 0000 | | 71D0 | ADCFLTR4 | 31:16 | AFEN | DATA16EN | DFMODE | ( | OVRSAM<2:0 | > | AFGIEN | AFRDY | _ | _ | _ | | C | HNLID<4:0> | | | 0000 | | | | 15:0 | | | | | | | | FLTRDAT | A<15:0> | | | | | | | | 0000 | | 7200 | ADCTRG1 | 31:16 | _ | _ | _ | | Т | RGSRC3<4: | 0> | | _ | _ | _ | | TF | RGSRC2<4:0 | > | | 0000 | | | | 15:0 | _ | _ | _ | | T | RGSRC1<4: | 0> | | _ | _ | _ | | TF | RGSRC0<4:0 | > | | 0000 | | 7210 | ADCTRG2 | 31:16 | _ | _ | _ | | Т | RGSRC7<4: | 0> | | _ | _ | _ | | TF | RGSRC6<4:0 | > | | 0000 | | | | 15:0 | _ | _ | _ | | T | RGSRC5<4: | 0> | | _ | _ | _ | | TF | RGSRC4<4:0 | > | | 0000 | | 7220 | ADCTRG3 | 31:16 | _ | _ | _ | | Т | RGSRC11<4: | 0> | | _ | _ | _ | | TR | GSRC10<4:0 | )> | | 0000 | | | | 15:0 | _ | _ | _ | | Т | RGSRC9<4: | 0> | | _ | _ | _ | | TF | RGSRC8<4:0 | > | | 0000 | | 7230 | ADCTRG4 | 31:16 | _ | _ | _ | | Т | RGSRC15<4 | :0> | | _ | _ | _ | | TR | GSRC14<4:0 | )> | | 0000 | | | | 15:0 | _ | _ | _ | | Т | RGSRC13<4 | :0> | | _ | _ | _ | | TR | GSRC12<4:0 | )> | | 0000 | | 7240 | ADCTRG5 | 31:16 | _ | _ | _ | | TR | GSRC19<4:0 | )>(1) | | _ | _ | _ | | TR | GSRC18<4:0 | )> | | 0000 | | | | 15:0 | _ | _ | _ | | TRGSRC17<4:0> | | | | | _ | _ | | TR | GSRC16<4:0 | )> | | 0000 | | 7250 | ADCTRG6 <sup>(1)</sup> | 31:16 | _ | _ | _ | | TRGSRC23<4:0> | | | | | _ | _ | | TR | GSRC22<4:0 | )> | | 0000 | | | | 15:0 | _ | _ | _ | TRGSRC21<4:0> | | | | | _ | _ | _ | — TRGSRC20<4:0> | | | | 0000 | | | 7260 | ADCTRG7 | 31:16 | _ | _ | _ | TRGSRC27<4:0> | | | | | _ | _ | _ | TRGSRC26<4:0> | | | 0000 | | | | | | 15:0 | | _ | _ | | TRGSRC25<4:0> | | | | | _ | _ | | TR | GSRC24<4:0 | )> | | 0000 | This bit or register is not available on 64-pin devices. This register is for internal ADC input sources (i.e., IVREF and CTMU Temperature Sensor. Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 0xBF887D00, respectively. ADC REGISTER MAP (CONTINUED) **TABLE 25-2:** | | | ө | Bits 99 | | | | | | | | | | | | S. | | | | | |--------------------|------------------|-----------|-----------|------------------------|---------------|---------|-------------|-------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---------|------------| | Virtual<br>Address | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 7280 | ADCCMPCON1 | 31:16 | | | | | | | | CVDDATA | N<15:0> | | | | | | | | 0000 | | | | 15:0 | _ | 1 | | | AINI | 0<5:0> | | | ENDCMP | DCMPGIEN | DCMPED | IEBTWN | IEHIHI | IEHILO | IELOHI | IELOLO | 0000 | | 7290 | ADCCMPCON2 | 31:16 | _ | - | _ | - | - | _ | _ | - | _ | _ | - | - | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | | | AINID<4:0> | | | ENDCMP | DCMPGIEN | DCMPED | IEBTWN | IEHIHI | IEHILO | IELOHI | IELOLO | 0000 | | 72A0 | ADCCMPCON3 | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | | | AINID<4:0> | | | ENDCMP | DCMPGIEN | DCMPED | IEBTWN | IEHIHI | IEHILO | IELOHI | IELOLO | 0000 | | 72B0 | ADCCMPCON4 | 31:16 | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | | | AINID<4:0> | | | ENDCMP | DCMPGIEN | DCMPED | IEBTWN | IEHIHI | IEHILO | IELOHI | IELOLO | 0000 | | 7300 | ADCBASE | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | ADCBASE | E<15:0> | | | | | | | | 0000 | | 7310 | ADCDSTAT | 31:16 | DMAEN | _ | RBFIEN5 | RBFIEN4 | RBFIEN3 | RBFIEN2 | RBFIEN1 | RBFIEN0 | WOVERR | _ | RBF5 | RBF4 | RBF3 | RBF2 | RBF1 | RBF0 | 0000 | | | | 15:0 | DMACEN | _ | RAFIEN5 | RAFIEN4 | RAFIEN3 | RAFIEN2 | RAFIEN1 | RAFIEN0 | _ | _ | RAF5 | RAF4 | RAF3 | RAF2 | RAF1 | RAF0 | 0000 | | 7320 | ADCCNTB | 31:16 | | | | | | | | ADCCNTB | <31:16> | | | | | | | | 0000 | | | | 15:0 | | ADCCNTB<15:0> 0000 | | | | | | | | | 0000 | | | | | | | | 7330 | ADCDMAB | 31:16 | | | | | | | ADCDMAB<31:16> | | | | | | | | | | 0000 | | | | 15:0 | | | 1 | | | 1 | ı | ADCDMA | | 1 | | | 1 | 1 | 1 | 1 | 0000 | | 7340 | ADCTRGSNS | 31:16 | _ | - | _ | _ | LVL27 | LVL26 | LVL25 | LVL24 | LVL23 <sup>(1)</sup> | LVL22 <sup>(1)</sup> | LVL21 <sup>(1)</sup> | LVL20 <sup>(1)</sup> | LVL19 | LVL18 | LVL17 | LVL16 | 0000 | | | | 15:0 | LVL15 | LVL14 | LVL13 | LVL12 | LVL11 | LVL10 | LVL9 | LVL8 | LVL7 | LVL6 | LVL5 | LVL4 | LVL3 | LVL2 | LVL1 | LVL0 | 0000 | | 7350 | ADC0TIME | 31:16 | _ | | _ | , | ADCEIS<2:0 | > | SELRE | S<1:0> | BCHEN | | | A | DCDIV<6:0> | | | | 0300 | | | | 15:0 | _ | _ | _ | _ | _ | _ | | | 1 | 1 | SAMC | <9:0> | | | | | 0000 | | 7360 | ADC1TIME | 31:16 | _ | - | _ | , | ADCEIS<2:0 | > | SELRE | S<1:0> | BCHEN | | | А | DCDIV<6:0> | | | | 0300 | | | | 15:0 | _ | | _ | _ | _ | _ | | | 1 | 1 | SAMC | <9:0> | | | | | 0000 | | 7370 | ADC2TIME | 31:16 | _ | | _ | , | ADCEIS<2:0 | > | SELRE | S<1:0> | BCHEN | | | | DCDIV<6:0> | | | | 0300 | | | | 15:0 | _ | | _ | _ | _ | _ | | | 1 | 1 | SAMC | | | | | | 0000 | | 7380 | ADC3TIME | 31:16 | _ | _ | _ | , | ADCEIS<2:0: | > | SELRE | S<1:0> | BCHEN | | | А | DCDIV<6:0> | | | | 0300 | | | | 15:0 | SAMC<9:0> | | | | | | | 0000 | | | | | | | | | | | 7390 | ADC4TIME | 31:16 | _ | | _ | | ADCEIS<2:0: | > | SELRE | S<1:0> | BCHEN | | | А | DCDIV<6:0> | | | | 0300 | | | | 15:0 | _ | _ | _ | _ | _ | — SAMC<9:0> | | | | | | 0000 | | | | | | | 73A0 | ADC5TIME | 31:16 | _ | | _ | , | ADCEIS<2:0 | | | | | | | 0300 | | | | | | | | | 15:0 | _ | _ | _ | | _ | _ | | 1 | 1 | 1 | SAMC | | 1 | T | 1 | T | 0000 | | 73C0 | ADCEIEN1 | 31:16 | _ | _ | _ | _ | EIEN27 | EIEN26 | EIEN25 | EIEN24 | EIEN23 <sup>(1)</sup> | EIEN22 <sup>(1)</sup> | EIEN21 <sup>(1)</sup> | EIEN20 <sup>(1)</sup> | EIEN19 | EIEN18 | EIEN17 | EIEN16 | 0000 | | | | 15:0 | EIEN15 | EIEN14 | EIEN13 | EIEN12 | EIEN11 | EIEN10 | EIEN9 | EIEN8 | EIEN7 | EIEN6 | EIEN5 | EIEN4 | EIEN3 | EIEN2 | EIEN1 | EIEN0 | 0000 | | 73D0 | ADCEIEN2 | 31:16 | | | - 40 | _ | _ | _ | - 40 | - 40 | - | - 40 | EIRDY53 | - 40 | - 40 | EIRDY50 | EIRDY49 | EIRDY48 | 0000 | | | | 15:0 | | EIRDY46 <sup>(1)</sup> | -pin devices. | _ | _ | _ | EIEN41 <sup>(1)</sup> | EIEN40 <sup>(1)</sup> | EIEN39 <sup>(1)</sup> | EIEN38 <sup>(1)</sup> | EIEN37 <sup>(1)</sup> | EIEN36 <sup>(1)</sup> | EIEN35 <sup>(1)</sup> | EIEN34 <sup>(1)</sup> | EIEN33 <sup>(1)</sup> | _ | 0000 | This bit or register is not available on 64-pin devices. This register is for internal ADC input sources (i.e., IVREF and CTMU Temperature Sensor. Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 1: 2: 3: 0xBF887D00, respectively. TABLE 25-2: ADC REGISTER MAP (CONTINUED) | • | | е | Bits 9 | | | | | | | | | | | | S. | | | | | |--------------------|------------------|---------------|-------------------------------------------|------------------------|-------------------------------------------|-------------|---------|---------|------------------------|------------------------|-------------------------------------------|------------------------|------------------------|-------------------------------------------|-------------------------------------------|------------------------|------------------------|-----------------|------------| | Virtual<br>Address | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 73E0 | ADCEISTAT1 | 31:16 | _ | _ | _ | _ | EIRDY27 | EIRDY26 | EIRDY25 | EIRDY24 | | EIRDY22 <sup>(1)</sup> | EIRDY21 <sup>(1)</sup> | | EIRDY19 | EIRDY18 | EIRDY17 | EIRDY16 | + | | | | 15:0 | EIRDY15 | EIRDY14 | EIRDY13 | EIRDY12 | EIRDY11 | EIRDY10 | EIRDY9 | EIRDY8 | EIRDY7 | EIRDY6 | EIRDY5 | EIRDY4 | EIRDY3 | EIRDY2 | EIRDY1 | EIRDY0 | 0000 | | 73F0 | ADCEISTAT2 | 31:16 | —<br>———————————————————————————————————— | | —<br>———————————————————————————————————— | _ | _ | | - | | —<br>———————————————————————————————————— | (1) | EIRDY53 | —<br>———————————————————————————————————— | —<br>———————————————————————————————————— | EIRDY50 | EIRDY49 | EIRDY48 | | | 7400 | ADCANCON | _ | | EIRDY46 <sup>(1)</sup> | EIRDY45 <sup>(1)</sup> | _ | _ | —<br>- | EIRDY41 <sup>(1)</sup> | EIRDY40 <sup>(1)</sup> | EIRDY39 <sup>(1)</sup> | | EIRDY37 <sup>(1)</sup> | EIRDY36 <sup>(1)</sup> | EIRDY35 <sup>(1)</sup> | EIRDY34 <sup>(1)</sup> | EIRDY33 <sup>(1)</sup> | — | 0000 | | 7400 | ADCANCON | 31:16<br>15:0 | —<br>WKRDY7 | _ | WKRDY5 | —<br>WKRDY4 | WKRDY3 | WKRDY2 | CNT<3:0><br>WKRDY1 | WKRDY0 | WKIEN7<br>ANEN7 | _ | WKIEN5<br>ANEN5 | WKIEN4<br>ANEN4 | WKIEN3<br>ANEN3 | WKIEN2<br>ANEN2 | WKIEN1<br>ANEN1 | WKIEN0<br>ANEN0 | 0000 | | 7600 | ADCDATA0 | 31:16 | WKKD17 | _ | WKKD15 | WKKD14 | WKKD13 | WKKD12 | WKKUTI | DATA<3 | l . | _ | AINEINS | ANEN4 | ANENS | ANEINZ | ANENI | ANEINU | 0000 | | 7000 | ADCDATAU | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | 7610 | ADCDATA1 | 31:16 | | | | | | | | DATA< | | | | | | | | | 0000 | | 7010 | ADODAIAI | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | 7620 | ADCDATA2 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | . 020 | 1.505/ | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | 7630 | ADCDATA3 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | DATA< | 15:0> | | | | | | | | 0000 | | 7640 | ADCDATA4 | 31:16 | | DATA<31:16> 0000 | | | | | | | | | | | | 0000 | | | | | | | 15:0 | | DATA<15:0> 0000 | | | | | | | | | | | | 0000 | | | | | 7650 | ADCDATA5 | 31:16 | | | | | | | | DATA<3 | 1:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | DATA< | 15:0> | | | | | | | | 0000 | | 7660 | ADCDATA6 | 31:16 | | | | | | | | DATA<3 | 1:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | DATA< | 15:0> | | | | | | | | 0000 | | 7670 | ADCDATA7 | 31:16 | | | | | | | | DATA<3 | 1:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | DATA< | 15:0> | | | | | | | | 0000 | | 7680 | ADCDATA8 | 31:16 | | | | | | | | DATA<3 | 1:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | 7690 | ADCDATA9 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | 76A0 | ADCDATA10 | 31:16 | DATA<31:16> 0000 | | | | | | | | | | + | | | | | | | | | | 15:0 | | | | | | | | | | | 0000 | | | | | | | | 76B0 | ADCDATA11 | 31:16 | | | | | | | | | | | | | | | | | 0000 | | 7000 | A DODATA 4C | 15:0 | | | | | | | | DATA = | | | | | | | | | 0000 | | 76C0 | ADCDATA12 | 31:16 | | | | | | | | DATA< | | | | | | | | | 0000 | | 7600 | ADCDATA13 | 15:0 | | | | | | | | | | | 0000 | | | | | | | | טעס <i>ז</i> | AUCDAIAIS | 31:16<br>15:0 | | | | | | | | | | | | | | | | | | | | <u> </u> | | | DATA<15:0> 0000 | | | | | | | | | | | | | | | | 1: 2: 3: This bit or register is not available on 64-pin devices. This register is for internal ADC input sources (i.e., IVREF and CTMU Temperature Sensor. Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 0xBF887D00, respectively. ADC REGISTER MAP (CONTINUED) **TABLE 25-2:** | | | е | | | | | | | | Bit | 3 | | | | | | | | S | | | |--------------------|--------------------------|-----------|-------|-----------------|-------|-------|-------|-------|------|---------|-------|------|------|------|------|------|------|------|------------|--|--| | Virtual<br>Address | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | | 76E0 | ADCDATA14 | 31:16 | | DATA<31:16> 000 | | | | | | | | | | | 0000 | | | | | | | | | | 15:0 | | DATA<15:0> 0000 | | | | | | | | | | | | | | | | | | | 76F0 | ADCDATA15 | 31:16 | | DATA<31:16> 000 | | | | | | | | | | | 0000 | | | | | | | | | | 15:0 | | DATA<15:0> 00 | | | | | | | | | | | | 0000 | | | | | | | 7700 | ADCDATA16 | 31:16 | | | | | | | | DATA<3 | 1:16> | | | | | | | | 0000 | | | | | | 15:0 | | | | | | | | DATA< | 5:0> | | | | | | | | 0000 | | | | 7710 | ADCDATA17 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 7720 | ADCDATA18 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 7730 | ADCDATA19 | 31:16 | | | | | | | | DATA<3 | | | | | | | | 0 | | | | | | | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 7740 | ADCDATA20 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | | 15:0 | | | | | | | | | | | | | | 0000 | | | | | | | 7750 | ADCDATA21 <sup>(1)</sup> | 31:16 | | | | | | | | | | | | 0000 | | | | | | | | | | 40 | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 7760 | ADCDATA22 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | 40 | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 7770 | ADCDATA23 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 7780 | ADCDATA24 | 31:16 | | | | | | | | | | | 0000 | | | | | | | | | | | | 15:0 | | | | | | | | | | | 0000 | | | | | | | | | | 7790 | ADCDATA25 | 31:16 | | | | | | | | | | | 0000 | | | | | | | | | | 77.40 | A DOD 47400 | 15:0 | | | | | | | | DATA - | | | | | | | | | 0000 | | | | 77A0 | ADCDATA26 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | 7700 | 4 D O D 4 T 4 O T | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 77B0 | ADCDATA27 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | (1) | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | 7810 | ADCDATA33 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | 7000 | A DOD ATA 0 ((1) | 15:0 | | | | | | | | DATA 40 | | | | | | | | | 0000 | | | | /820 | ADCDATA34 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | 7000 | ADOD AT 4 0 5 (4) | 15:0 | | | | | | | | DATA 40 | | | | | | | | | 0000 | | | | 7830 | ADCDATA35 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | 1. This bit | 15:0 | | | | | | | | DATA< | 5:0> | | | | | | | | 0000 | | | Note - This bit or register is not available on 64-pin devices. This register is for internal ADC input sources (i.e., IVREF and CTMU Temperature Sensor. Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 1: 2: 3: 0xBF887D00, respectively. TABLE 25-2: ADC REGISTER MAP (CONTINUED) | Bits | | | | | | | | | | | | ts | | | | | | | | | | | |--------------------|--------------------------|---------------|---------------------|--------------------------------|---------------------|-------|-------|-------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|------|------------|--|--|--| | Virtual<br>Address | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | | | 7840 | ADCDATA36 <sup>(1)</sup> | 31:16 | | DATA<31:16> 0000 | | | | | | | | | | | | | | | | | | | | | | 15:0 | | DATA<15:0> 0000 | | | | | | | | | | | | | | | | | | | | 7850 | ADCDATA37 <sup>(1)</sup> | 31:16 | | | | | | | | | | | | | | 0000 | | | | | | | | | | 15:0 | | | | | | | | | | | | | | 0000 | | | | | | | | 7860 | ADCDATA38 <sup>(1)</sup> | 31:16 | | | | | | | | | | | | | 0000 | | | | | | | | | | (1) | 15:0 | | | | | | | | | | | | | 0000 | | | | | | | | | 7870 | ADCDATA39 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | | | 15:0 | DATA<15:0> 0000 | | | | | | | | | | | | | | | | | | | | | 7880 | ADCDATA40 <sup>(1)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | 7000 | A D O D A T A 44(1) | 15:0 | | | | | | | | DATA < | | | | | | | | | 0000 | | | | | 7890 | ADCDATA41 <sup>(1)</sup> | 31:16 | DATA<31:16> 0000 | | | | | | | | | | | | _ | | | | | | | | | 7000 | ADCDATA45 <sup>(1)</sup> | 15:0 | | | | | | | | DATA : | | | | | | | | | 0000 | | | | | 7800 | ADCDATA45(*/ | 31:16 | | DATA<31:16> 0000 | | | | | | | | | | | | _ | | | | | | | | 7050 | ADCDATA46 <sup>(1)</sup> | 15:0 | | | | | | | | | | | | | 0000 | | | | | | | | | /8EU | ADCDATA4600 | 31:16 | | | | | | | | | | | | | 0000 | | | | | | | | | 7050 | ADCDATA47 <sup>(1)</sup> | 15:0 | | DATA<15:0> 000 DATA<31:16> 000 | | | | | | | | | | | | _ | | | | | | | | / OF U | ADCDATA4/\ | 31:16<br>15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | | 7000 | ADCDATA48 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | 7900 | ADCDATA46 | 15:0 | | | | | | | | DATA< | | | | | | | | | | | | | | 7010 | ADCDATA49 | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | 7910 | ADCDATA49 | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | | 7020 | ADCDATA50 <sup>(2)</sup> | 31:16 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | | 1 320 | ADODATASO | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | | 7950 | ADCDATA53 <sup>(2)</sup> | 31:16 | | | | | | | | DATA<3 | | | | | | | | | 0000 | | | | | 7000 | 7.0007.17.00 | 15:0 | | | | | | | | DATA< | | | | | | | | | 0000 | | | | | 7F00 | ADCSYSCFG0 | 31:16 | _ | _ | _ | _ | AN27 | AN26 | AN25 | AN24 | AN23 <sup>(1)</sup> | AN22 <sup>(1)</sup> | AN21 <sup>(1)</sup> | AN20 <sup>(1)</sup> | AN19 | AN18 | AN17 | AN16 | 0FxF | | | | | 7 200 | 7.000100100 | 15:0 | AN15 | AN14 | AN13 | AN12 | AN11 | AN10 | AN9 | AN8 | AN7 | AN6 | AN5 | AN4 | AN3 | AN2 | AN1 | AN0 | FFFF | | | | | 7E10 | ADCSYSCFG1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | AN53 <sup>(1)</sup> | _ | _ | AN50 <sup>(1)</sup> | AN49 | AN48 | 00xx | | | | | | 35 . 55 . 61 | 15:0 | AN47 <sup>(1)</sup> | AN46 <sup>(1)</sup> | AN45 <sup>(1)</sup> | | _ | _ | AN41 <sup>(1)</sup> | AN40 <sup>(1)</sup> | AN39 <sup>(1)</sup> | AN38 <sup>(1)</sup> | AN37 <sup>(1)</sup> | AN36 <sup>(1)</sup> | AN35 <sup>(1)</sup> | AN34 <sup>(1)</sup> | AN33 <sup>(1)</sup> | _ | XXXX | | | | | 7D00 | ADC0CFG <sup>(3)</sup> | 31:16 | | | | | | | | ADCCFG- | | | | | | 1 | | | 0000 | | | | | | | 15:0 | | | | | | | | | | | | | | 0000 | | | | | | | | 7D10 | ADC1CFG <sup>(3)</sup> | 31:16 | | | | | | | | ADCCFG- | | | | | | | | | | | | | | | | 15:0 | | | | | | | | ADCCFG | | | | | | | | | 0000 | | | | | | 15.0 ADCCFG<15.0> | | | | | | | | | | | | | | | | | | | | | | 1: 2: 3: This bit or register is not available on 64-pin devices. This register is for internal ADC input sources (i.e., IVREF and CTMU Temperature Sensor. Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 0xBF887D00, respectively. # TABLE 25-2: ADC REGISTER MAP (CONTINUED) | | Bits | | | | | | | s | | | | | | | | | | | | | | |--------------------|-------------------------------------------------|-------------------|---------------|-------------------|-------|-------|-------|-------|------|---------|---------|------|------|------|------|------|------|------|-----------|--|--| | Virtual<br>Address | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | | | 7D20 | ADC2CFG <sup>(3)</sup> | 31:16 | | ADCCFG<31:16> 000 | | | | | | | | | | | 0000 | | | | | | | | | | 15:0 | | ADCCFG<15:0> 000 | | | | | | | | | | | | 0000 | | | | | | | 7D30 | ADC3CFG <sup>(3)</sup> | 31:16 | ADCCFG<31:16> | | | | | | | | | | | 0000 | | | | | | | | | | | 15:0 | | | | | | | | ADCCFG | <15:0> | | | | | | | | 0000 | | | | 7D40 | 7D40 ADC4CFG <sup>(3)</sup> 31:16 ADCCFG<31:16> | | | | | | | | | | | 0000 | | | | | | | | | | | | | 15:0 | | | | | | | | ADCCFG | <15:0> | | | | | | | | | | | | 7D50 | ADC5CFG <sup>(3)</sup> | 31:16 | | | | | | | | ADCCFG- | <31:16> | | | | | | | | 0000 | | | | | | 15:0 | ADCCFG<15:0> | | | | | | | | | | | 0000 | | | | | | | | | 7D70 | ADC7CFG <sup>(3)</sup> | 31:16 | • | | | | | | | ADCCFG- | <31:16> | • | | | • | | | • | 0000 | | | | | | 15:0 ADCCFG<15:0> | | | | | | | | | | | | 0000 | | | | | | | | Note - This bit or register is not available on 64-pin devices. This register is for internal ADC input sources (i.e., IVREF and CTMU Temperature Sensor. Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 0xBF887D00, respectively. ### REGISTER 25-1: ADCCON1: ADC CONTROL REGISTER 1 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | | 31.24 | _ | | _ | _ | _ | _ | _ | _ | | | 00.40 | R/W-0 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | FRACT | SELRES | S<1:0> | | - | STRGSRC<4 | :0> | | | | 15:8 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | | | 13.6 | ON | | SIDL | AICPMPEN | CVDEN | FSSCLKEN | FSPBCLKEN | _ | | | 7.0 | U-0 | R/W-0 | | 7:0 | _ | | IRQVS<2:0> | • | STRGLVL | DMABL<2:0> | | | | Legend:HC = Hardware SetHS = Hardware ClearedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-24 Unimplemented: Read/Write as '0' bit 23 FRACT: Fractional Data Output Format bit 1 = Fractional 0 = Integer bit 22-21 SELRES<1:0>: Shared ADC7 (i.e., AN6-AN53) Resolution bits 11 = 12 bits (default) 10 = 10 bits 01 **= 8 bits** 00 = 6 bits **Note 1:** The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices, otherwise these bits are reserved. ### REGISTER 25-1: ADCCON1: ADC CONTROL REGISTER 1 (CONTINUED) ``` bit 20-16 STRGSRC<4:0>: Scan Trigger Source Select bits ``` - 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit((1)1) 11001 = PWM Generator 2 Current-Limit 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = CTMU trip 10011 = Output Compare 4 period end 10010 = Output Compare 3 period end 10001 = Output Compare 2 period end 10000 = Output Compare 1 period end 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary PWM time base<sup>(1)</sup> 01000 = Primary PWM time base<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 **= INTO** 00011 = Scan trigger 00010 = Software level trigger 00001 = Software edge trigger 00000 **= No Trigger** - **Note:** These triggers only apply to implemented analog inputs AN32-AN53. For AN0-AN27 refer to ADCTRG1-ADCTRG7. - bit 15 ON: ADC Module Enable bit - 1 = ADC module is enabled - 0 = ADC module is disabled - Note: The ON bit should be set only after the ADC module has been configured. - bit 14 Unimplemented: Read as '0' - bit 13 SIDL: Stop in Idle Mode bit - 1 = Discontinue module operation when device enters Idle mode - 0 = Continue module operation in Idle mode - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices, otherwise these bits are reserved. #### REGISTER 25-1: ADCCON1: ADC CONTROL REGISTER 1 (CONTINUED) - bit 12 AICPMPEN: Analog Input Charge Pump Enable bit - 1 = Analog input charge pump is enabled - 0 = Analog input charge pump is disabled (default) - **Note 1:** For proper analog operation at VDD less than 2.5V, the AICPMPEN bit must be = 1, and the IOANCPEN bit in the CFGCON register must be set to '1'. This bit must not be set if VDD is greater than 2.5V. - 2: ADC throughput rate performance is reduced, as defined in the following table, if AICPMPEN = 1 or IOANCPEN (CFGCON<7) = 1. | ADC0 | ADC1 | ADC2 | ADC3 | ADC4 | ADC5 | ADC7 | Maximum Sum of Total ADC Throughputs | |------|------|------|------|------|------|------|--------------------------------------| | ON | OFF | OFF | OFF | OFF | OFF | OFF | 2 Msps | | ON | ON | OFF | OFF | OFF | OFF | OFF | 4 Msps | | ON | ON | ON | OFF | OFF | OFF | OFF | 5 Msps | | OFF | OFF | OFF | ON | OFF | OFF | OFF | 2 Msps | | OFF | OFF | OFF | ON | ON | OFF | OFF | 4 Msps | | OFF | OFF | OFF | ON | ON | ON | OFF | 5 Msps | | OFF | OFF | OFF | ON | ON | ON | ON | 5 Msps | | ON | ON | ON | ON | OFF | OFF | OFF | 7 Msps | | ON | ON | ON | ON | ON | OFF | OFF | 9 Msps | | ON | ON | ON | ON | ON | ON | OFF | 10 Msps | | ON | OFF | OFF | ON | ON | ON | ON | 7 Msps | | ON | ON | OFF | ON | ON | ON | ON | 9 Msps | | ON 10 Msps | - bit 11 CVDEN: Capacitive Voltage Division Enable bit - 1 = CVD operation is enabled - 0 = CVD operation is disabled - bit 10 FSSCLKEN: Bypass Fast Synchronous DMA System Clock to ADC Control Clock - 1 = Bypass synchronizer logic for DMA system clock to ADC control clocks - 0 = Enable clock synchronizers for non-synchronized DMA to ADC clock sources **Note:** Synchronizers required if ADCCON3<ADCSEL> = REFCLK3, or ADCCON3<ADCSEL> = FRC and FRC is not SYSCLK source otherwise this bit is not applicable. - bit 9 FSPBCLKEN: Bypass Fast Synchronous Peripheral Bus Clock to ADC Control Clock - 1 = Bypass synchronizer logic for peripheral clock to ADC control clocks - 0 = Enable clock synchronizers for non-synchronized peripheral clock to ADC control clocks **Note:** Synchronizers required if ADCCON3<ADCSEL> = REFCLK3, or ADCCON3<ADCSEL> = FRC and FRC is not SYSCLK source otherwise this bit is not applicable. - bit 8-7 Unimplemented: Read as '0' - **Note 1:** The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices, otherwise these bits are reserved. #### REGISTER 25-1: ADCCON1: ADC CONTROL REGISTER 1 (CONTINUED) bit 6-4 IRQVS<2:0>: Interrupt Vector Shift bits To determine interrupt vector address, this bit specifies the amount of left shift done to the AIRDYx status bits in the ADCDSTAT1 and ADCDSTAT2 registers, prior to adding with the ADCBASE register. Interrupt Vector Address = Read Value of ADCBASE and Read Value of ADCBASE = Value written to ADCBASE + x << IRQVS<2:0>, where 'x' is the smallest active input ID from the ADCDSTAT1 or ADCDSTAT2 registers (which has highest priority). - 111 = Shift x left 7 bit position - 110 = Shift x left 6 bit position - 101 = Shift x left 5 bit position - 100 = Shift x left 4 bit position - 011 = Shift x left 3 bit position - 010 = Shift x left 2 bit position - 001 = Shift x left 1 bit position - 000 = Shift x left 0 bit position - bit 3 STRGLVL: Scan Trigger High Level/Positive Edge Sensitivity bit - 1 = Scan trigger is high level sensitive. Once STRIG mode is selected (TRGSRCx<4:0> in the ADCTRGx register), the scan trigger will continue for all selected analog inputs, until the STRIG option is removed. - 0 = Scan trigger is positive edge sensitive. Once STRIG mode is selected (TRGSRCx<4:0> in the ADCTRGx register), only a single scan trigger will be generated, which will complete the scan of all selected analog inputs. - bit 2-0 DMABL<2:0>: DMA to System RAM Buffer Length Size bits These bits define the number of locations in system memory allocated per analog input for DMA interface use. Because each output data is 16-bit wide, one location consists of 2 bytes. Therefore the actual size reserved in the System RAM follows the formula: RAM Buffer Length in bytes = 2(DMABL+1). The DMABL field can also be thought of as a "Left Shift Amount +1" needed for the channel ID to create the DMA byte address offset to be added to the contents of ADDMAB in order to obtain the byte address of the beginning of the System RAM buffer area allocated for the given channel. - 111 = Allocates 128 locations in system memory to each analog input, actually 256 bytes - 110 = Allocates 64 locations in system memory to each analog input, actually 128 bytes - 101 = Allocates 32 locations in system memory to each analog input, actually 64 bytes - 100 = Allocates 16 locations in system memory to each analog input, actually 32 bytes - 011 = Allocates 8 locations in system memory to each analog input, actually 16 bytes - 010 = Allocates 4 locations in system memory to each analog input, actually 8 bytes - 001 = Allocates 2 locations in system memory to each analog input, actually 4 bytes - 000 = Allocates 1 location in system memory to each analog input, actually 2 bytes - **Note 1:** The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices, otherwise these bits are reserved. #### REGISTER 25-2: ADCCON2: ADC CONTROL REGISTER 2 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |-----------|-------------------|-------------------|-------------------|-------------------|-----------------------|-------------------|------------------|------------------|--|--|--| | 31:24 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | BGVRRDY | REFFLT | EOSRDY | C | CVDCPL<2:0> SAMC<9:8> | | | | | | | | 23:16 | R/W-0 | | | | 23.10 | SAMC<7:0> | | | | | | | | | | | | 15:8 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 13.0 | BGVRIEN | REFFLTIEN | EOSIEN | ADCEIOVR | _ | А | ADCEIS<2:0> | | | | | | 7.0 | U-0 | R/W-0 | | | | 7:0 | _ | | | AD | CDIV<6:0> | | | | | | | Legend:HC = Hardware SetHS = Hardware Clearedr = ReservedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown - bit 31 BGVRRDY: Band Gap Voltage/ADC Reference Voltage Status bit - 1 = Both band gap voltage and ADC reference voltages (VREF) are ready - 0 = Either or both band gap voltage and ADC reference voltages (VREF) are not ready Data processing is valid only after BGVRRDY is set by hardware, so the application code must check that the BGVRRDY bit is set to ensure data validity. This bit set to '0' when ON (ADCCON1<15>) = 0. - bit 30 REFFLT: Band Gap/VREF/AVDD BOR Fault Status bit - 1 = Fault in band gap or the VREF voltage while the ON bit (ADCCON1<15>) was set. Most likely, a band gap or VREF fault will be caused by a BOR of the analog VDD supply. - 0 = Band gap and VREF voltage are working properly This bit is cleared when the ON bit (ADCCON1<15>) = 0 and the BGVRRDY bit = 1. - bit 29 **EOSRDY:** End of Scan Interrupt Status bit - 1 = All analog inputs are considered for scanning through the scan trigger (all analog inputs specified in the ADCCSS1 and ADCCSS2 registers) have completed scanning - 0 = Scanning has not completed This bit is cleared when ADCCON2<31:24> are read in software. bit 28-26 CVDCPL<2:0>: Capacitor Voltage Divider (CVD) Setting bits 111 = 7 \* 2.5 pF = 17.5 pF 110 = 6 \* 2.5 pF = 15 pF 101 = 5 \* 2.5 pF = 12.5 pF 100 = 4 \* 2.5 pF = 10 pF 011 = 3 \* 2.5 pF = 7.5 pF 010 = 2 \* 2.5 pF = 5 pF 001 = 1 \* 2.5 pF = 2.5 pF 000 = 0 \* 2.5 pF = 0 pF Note: These bits are available only on shared ADC7 inputs AN6-AN49. Once enabled (CVD-CPL<2:0>) > 000), the internal capacitors are internally connected to all ADC7 inputs. To determine user ADC sampling time requirements (SAMC<9:0> bits (ADCCON2<25:16>)) with CVDCPL selection, refer to TABLE 37-43: "ADC Sample Times with CVD Enabled". #### REGISTER 25-2: ADCCON2: ADC CONTROL REGISTER 2 (CONTINUED) ``` bit 25-16 SAMC<9:0>: Sample Time for the Shared ADC (ADC7) bits 1111111111 = 1025 TAD 0000000001 = 3 TAD 0000000000 = 2 TAD Where TAD = period of the ADC conversion clock for the Shared ADC (ADC7) controlled by the ADCDIV<6:0> bits. Shared ADC7 Throughput rate: = ((1/((Sample time + Conversion time)(TAD))) / #of ADC inputs used in scan list) = ((1 / ((SAMC + # bit resolution+1)(TAD))) / #of ADC inputs used in scan list) SCAN mode enabled with (2) ANx inputs in scan list, (i.e. ADCCSSx<CSSy>), SAMC = 4 TAD, 12-bit mode, TAD = 16.667ns = 60 MHz: Throughput rate = ((1 / ((4+12+1)(16.667 \text{ ns}))) / 2) = ((1/(17 * 16.667 ns)) / 2) = 1.764706 \text{ msps} Unlike the High-Speed Class 1 ADC modules, the trigger event for the shared Class 3 ADC7 Note: module initiates the SAMC sampling sequence, rather than the convert sequence. bit 15 BGVRIEN: Band Gap/VREF Voltage Ready Interrupt Enable bit 1 = Interrupt will be generated when the BGVRDDY bit is set 0 = No interrupt is generated when the BGVRRDY bit is set bit 14 REFFLTIEN: Band Gap/VREF Voltage Fault Interrupt Enable bit 1 = Interrupt will be generated when the REFFLT bit is set 0 = No interrupt is generated when the REFFLT bit is set bit 13 EOSIEN: End of Scan Interrupt Enable bit 1 = Interrupt will be generated when EOSRDY bit is set 0 = No interrupt is generated when the EOSRDY bit is set bit 12 ADCEIOVR: Early Interrupt Request Override bit 1 = Early interrupt generation is overridden and interrupt generation is controlled by the ADCGIRQEN1 and ADCGIRQEN2 registers 0 = Early interrupt generation is not overridden and interrupt generation is controlled by the ADCEIEN1 and ADCEIEN2 registers bit 11 Unimplemented: Read as '0' bit 10-8 ADCEIS<2:0>: Shared ADC (ADC7) Early Interrupt Select bits These bits select the number of clocks (TAD7) prior to the arrival of valid data that the associated interrupt is generated. 111 = The data ready interrupt is generated 8 ADC clocks prior to end of conversion 110 = The data ready interrupt is generated 7 ADC clocks prior to end of conversion 001 = The data ready interrupt is generated 2 ADC module clocks prior to end of conversion 000 = The data ready interrupt is generated 1 ADC module clock prior to end of conversion Note: All options are available when the selected resolution, set by the SELRES<1:0> bits (ADCCON1<22:21>), is 12-bit or 10-bit. For a selected resolution of 8-bit, options from '000' to '101' are valid. For a selected resolution of 6-bit, options from '000' to '011' are valid. bit 7 Unimplemented: Read as '0' ``` #### REGISTER 25-2: ADCCON2: ADC CONTROL REGISTER 2 (CONTINUED) The ADCDIV<6:0> bits divide the ADC control clock (TQ) to generate the clock for the Shared ADC, ADC7 (TAD7). #### REGISTER 25-3: ADCCON3: ADC CONTROL REGISTER 3 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|---------------------------|------------------|--|--| | 31:24 | R/W-0 | | | 31.24 | ADCSE | L<1:0> | | CONCLKDIV<5:0> | | | | | | | | 23:16 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23.10 | DIGEN7 | _ | DIGEN5 | DIGEN4 | DIGEN3 | DIGEN2 | DIGEN1 | DIGEN0 | | | | 15:8 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0, HS, HC | R/W-0 | R-0, HS, HC | | | | 15.6 | VREFSEL<2:0> | | | TRGSUSP | UPDIEN | UPDRDY | SAMP <sup>(1,2,3,4)</sup> | RQCNVRT | | | | 7.0 | R/W-0 | R-0, HS, HC | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | GLSWTRG | GSWTRG | | | ADIN | SEL<5:0> | | | | | Legend:HC = Hardware SetHS = Hardware ClearedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown ``` bit 31-30 ADCSEL<1:0>: Analog-to-Digital Clock Source (TCLK) bits ``` 11 = SYSCLK (Required if using DMA for ADC) 10 = REFCLK3 01 = FRC 00 = SYSCLK bit 29-24 CONCLKDIV<5:0>: Analog-to-Digital Control Clock (TQ) Divider bits 111111 = 126 \* TCLK = TQ • 000011 = 6 \* TCLK = TQ 000010 = 4 \* TCLK = TQ 000001 = 2 \* TCLK = TQ 000000 = Tclk = TQ bit 23 DIGEN7: Shared ADC (ADC7) Digital Enable bit 1 = ADC7 is digital enabled 0 = ADC7 is digital disabled bit 22 Unimplemented: Read as '0' bit 21 DIGEN5: ADC5 Digital Enable bit 1 = ADC5 is digital enabled (required for active operation) 0 = ADC5 is digital disabled (power-saving mode) bit 20 DIGEN4: ADC4 Digital Enable bit 1 = ADC4 is digital enabled (required for active operation) 0 = ADC4 is digital disabled (power-saving mode) - **Note 1:** The SAMP bit has the highest priority and setting this bit will keep the S&H circuit in Sample mode until the bit is cleared. Also, usage of the SAMP bit will cause settings of SAMC<9:0> bits (ADCCON2<25:16>) to be ignored. - 2: The SAMP bit only connects analog inputs to the shared ADC, ADC7. All Class 1 analog inputs are not affected by the SAMP bit. - **3:** The SAMP bit is not a self-clearing bit and it is the responsibility of application software to first clear this bit and only after setting the RQCNVRT bit to start the analog-to-digital conversion. - **4:** Normally, when the SAMP and RQCNVRT bits are used by software routines, all TRGSRCx<4:0> bits and STRGSRC<4:0> bits should be set to '00000' to disable all external hardware triggers and prevent them from interfering with the software-controlled sampling command signal SAMP and with the software-controlled trigger RQCNVRT. #### REGISTER 25-3: ADCCON3: ADC CONTROL REGISTER 3 (CONTINUED) bit 19 **DIGEN3:** ADC3 Digital Enable bit 1 = ADC3 is digital enabled (required for active operation) 0 = ADC3 is digital disabled (power-saving mode) bit 18 **DIGEN2:** ADC2 Digital Enable bit 1 = ADC2 is digital enabled (required for active operation) 0 = ADC2 is digital disabled (power-saving mode) bit 17 **DIGEN1:** ADC1 Digital Enable bit 1 = ADC1 is digital enabled (required for active operation) 0 = ADC1 is digital disabled (power-saving mode) bit 16 **DIGENO:** ADC0 Digital Enable bit 1 = ADC0 is digital enabled (required for active operation) 0 = ADC0 is digital disabled (power-saving mode) bit 15-13 VREFSEL<2:0>: Voltage Reference (VREF) Input Selection bits | VREFSEL<2:0> | ADC VREFH | ADC VREFL | | | |--------------|-----------|-----------|--|--| | 1xx | Reserved | Reserved | | | | 011 | VREF+ | VREF- | | | | 010 | AVDD | VREF- | | | | 001 | VREF+ | AVss | | | | 000 | AVDD | AVss | | | #### bit 12 TRGSUSP: Trigger Suspend bit - 1 = Triggers are blocked from starting a new analog-to-digital conversion, but the ADC module is not disabled - 0 = Triggers are not blocked - bit 11 **UPDIEN:** Update Ready Interrupt Enable bit - 1 = Interrupt will be generated when the UPDRDY bit is set by hardware - 0 = No interrupt is generated - bit 10 **UPDRDY:** ADC Update Ready Status bit - 1 = ADC SFRs can be updated - 0 = ADC SFRs cannot be updated **Note:** This bit is only active while the TRGSUSP bit is set and there are no more running conversions of any ADC modules. - bit 9 **SAMP:** Shared ADC7 Analog Input Sampling Enable bit<sup>(1,2,3,4)</sup> - 1 = The ADC S&H amplifier is sampling - 0 = The ADC S&H amplifier is holding #### bit 8 RQCNVRT: Individual ADC Input Conversion Request bit This bit and its associated ADINSEL<5:0> bits enable the user to individually request an analog-to-digital conversion of an analog input through software. - 1 = Trigger the conversion of the selected ADC input as specified by the ADINSEL<5:0> bits - 0 = Do not trigger the conversion Note: This bit is automatically cleared in the next ADC clock cycle. - Note 1: The SAMP bit has the highest priority and setting this bit will keep the S&H circuit in Sample mode until the bit is cleared. Also, usage of the SAMP bit will cause settings of SAMC<9:0> bits (ADCCON2<25:16>) to be ignored. - 2: The SAMP bit only connects analog inputs to the shared ADC, ADC7. All Class 1 analog inputs are not affected by the SAMP bit. - 3: The SAMP bit is not a self-clearing bit and it is the responsibility of application software to first clear this bit and only after setting the RQCNVRT bit to start the analog-to-digital conversion. - 4: Normally, when the SAMP and RQCNVRT bits are used by software routines, all TRGSRCx<4:0> bits and STRGSRC<4:0> bits should be set to '00000' to disable all external hardware triggers and prevent them from interfering with the software-controlled sampling command signal SAMP and with the software-controlled trigger RQCNVRT. #### REGISTER 25-3: ADCCON3: ADC CONTROL REGISTER 3 (CONTINUED) - bit 7 GLSWTRG: Global Level Software Trigger bit - 1 = Trigger conversion for ADC inputs that have selected the GLSWTRG bit as the trigger signal, either through the associated TRGSRC<4:0> bits in the ADCTRGx registers or through the STRGSRC<4:0> bits in the ADCCON1 register - 0 = Do not trigger an analog-to-digital conversion - bit 6 **GSWTRG:** Global Software Trigger bit - 1 = Trigger conversion for ADC inputs that have selected the GSWTRG bit as the trigger signal, either through the associated TRGSRC<4:0> bits in the ADCTRGx registers or through the STRGSRC<4:0> bits in the ADCCON1 register - 0 = Do not trigger an analog-to-digital conversion Note: This bit is automatically cleared in the next ADC clock cycle. - Note 1: The SAMP bit has the highest priority and setting this bit will keep the S&H circuit in Sample mode until the bit is cleared. Also, usage of the SAMP bit will cause settings of SAMC<9:0> bits (ADCCON2<25:16>) to be ignored. - 2: The SAMP bit only connects analog inputs to the shared ADC, ADC7. All Class 1 analog inputs are not affected by the SAMP bit. - 3: The SAMP bit is not a self-clearing bit and it is the responsibility of application software to first clear this bit and only after setting the RQCNVRT bit to start the analog-to-digital conversion. - 4: Normally, when the SAMP and RQCNVRT bits are used by software routines, all TRGSRCx<4:0> bits and STRGSRC<4:0> bits should be set to '00000' to disable all external hardware triggers and prevent them from interfering with the software-controlled sampling command signal SAMP and with the software-controlled trigger RQCNVRT. #### REGISTER 25-3: ADCCON3: ADC CONTROL REGISTER 3 (CONTINUED) bit 5-0 ADINSEL<5:0>: Analog Input Select bits These bits select the analog input to be converted when the RQCNVRT bit is set. ``` 111111 = Reserved 110110 = Reserved 110101 = CTMU Temperature Sensor (internal AN53) 110100 = Reserved 110011 = Reserved 110010 = IVREF 1.2V (internal AN50) 110001 = AN49 101101 = AN45 101100 = Reserved 101010 = Reserved 101001 = AN41 100001 = AN33 100000 = Reserved 011100 = Reserved 011011 = AN27 000000 = AN0 ``` Note: AN20-AN23, AN33-AN41, and AN45-AN47 are not available on 64-pin devices. Refer to TABLE 1-1: "ADC1 Pinout I/O Descriptions" for details. - **Note 1:** The SAMP bit has the highest priority and setting this bit will keep the S&H circuit in Sample mode until the bit is cleared. Also, usage of the SAMP bit will cause settings of SAMC<9:0> bits (ADCCON2<25:16>) to be ignored. - 2: The SAMP bit only connects analog inputs to the shared ADC, ADC7. All Class 1 analog inputs are not affected by the SAMP bit. - **3:** The SAMP bit is not a self-clearing bit and it is the responsibility of application software to first clear this bit and only after setting the RQCNVRT bit to start the analog-to-digital conversion. - 4: Normally, when the SAMP and RQCNVRT bits are used by software routines, all TRGSRCx<4:0> bits and STRGSRC<4:0> bits should be set to '00000' to disable all external hardware triggers and prevent them from interfering with the software-controlled sampling command signal SAMP and with the software-controlled trigger RQCNVRT. #### REGISTER 25-4: ADCTRGMODE: ADC TRIGGERING MODE FOR DEDICATED ADC REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | _ | _ | _ | _ | SH5ALT<1:0> | | SH4AL | SH4ALT<1:0> | | 23:16 | R/W-0 | 23.10 | SH3ALT<1:0> | | SH2ALT<1:0> | | SH1ALT<1:0> | | SH0ALT<1:0> | | | 15:8 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15.6 | _ | _ | STRGEN5 | STRGEN4 | STRGEN3 | STRGEN2 | STRGEN1 | STRGEN0 | | 7:0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | _ | SSAMPEN5 | SSAMPEN4 | SSAMPEN3 | SSAMPEN2 | SSAMPEN1 | SSAMPEN0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-26 SH5ALT<1:0>: ADC5 Analog Input Select bit $11 = AN25^{(1)}$ $10 = AN6^{(1)}$ $01 = AN2^{(1)}$ 00 **= AN5** bit 25-24 SH4ALT<1:0>: ADC4 Analog Input Select bit $11 = AN0^{(1)}$ $10 = AN9^{(1)}$ $01 = AN1^{(1)}$ 00 **= AN4** bit 23-22 SH3ALT<1:0>: ADC3 Analog Input Select bit $11 = AN26^{(1)}$ $10 = AN8^{(1)}$ $01 = AN0^{(1)}$ 00 **= AN3** bit 21-20 SH2ALT<1:0>: ADC2 Analog Input Select bit $11 = AN25^{(1)}$ $10 = AN6^{(1)}$ $01 = AN5^{(1)}$ 00 **= AN2** bit 19-18 SH1ALT<1:0>: ADC1 Analog Input Select bit $11 = AN0^{(1)}$ $10 = AN7^{(1)}$ $01 = AN4^{(1)}$ 00 **= AN1** bit 17-16 SH0ALT<1:0>: ADC0 Analog Input Select bit $11 = AN24^{(1)}$ $10 = AN5^{(1)}$ $01 = AN3^{(1)}$ 00 **= ANO** bit 15-14 Unimplemented: Read as '0' Note 1: Regardless of what alternate input is selected by SHxALT, only for ADC0-ADC5, all control and results are handled by the native SHxALT = '0b00 input. For example, SH0ALT = '0b11 = AN24. However, from a software and silicon hardware control and results register perspective, the user application must initialize the ADC0 module as if AN24 were actually AN0. #### REGISTER 25-4: ADCTRGMODE: ADC TRIGGERING MODE FOR DEDICATED ADC REGISTER - bit 13 STRGEN5: ADC5 Presynchronized Triggers bit - 1 = ADC5 uses presynchronized triggers - 0 = ADC5 does not use presynchronized triggers - bit 12 STRGEN4: ADC4 Presynchronized Triggers bit - 1 = ADC4 uses presynchronized triggers - 0 = ADC4 does not use presynchronized triggers - bit 11 STRGEN3: ADC3 Presynchronized Triggers bit - 1 = ADC3 uses presynchronized triggers - 0 = ADC3 does not use presynchronized triggers - bit 10 STRGEN2: ADC2 Presynchronized Triggers bit - 1 = ADC2 uses presynchronized triggers - 0 = ADC2 does not use presynchronized triggers - bit 9 **STRGEN1:** ADC1 Presynchronized Triggers bit - 1 = ADC1 uses presynchronized triggers - 0 = ADC1 does not use presynchronized triggers - bit 8 STRGEN0: ADC0 Presynchronized Triggers bit - 1 = ADC0 uses presynchronized triggers - 0 = ADC0 does not use presynchronized triggers - bit 7-6 **Unimplemented:** Read as '0' - bit 5 SSAMPEN5: ADC5 Synchronous Sampling bit - 1 = ADC5 uses synchronous sampling for the first sample after being idle or disabled - 0 = ADC5 does not use synchronous sampling - bit 4 SSAMPEN4: ADC4 Synchronous Sampling bit - 1 = ADC4 uses synchronous sampling for the first sample after being idle or disabled - 0 = ADC4 does not use synchronous sampling - bit 3 SSAMPEN3: ADC3 Synchronous Sampling bit - 1 = ADC3 uses synchronous sampling for the first sample after being idle or disabled - 0 = ADC3 does not use synchronous sampling - bit 2 SSAMPEN2: ADC2Synchronous Sampling bit - 1 = ADC2 uses synchronous sampling for the first sample after being idle or disabled - 0 = ADC2 does not use synchronous sampling - bit 1 SSAMPEN1: ADC1 Synchronous Sampling bit - 1 = ADC1 uses synchronous sampling for the first sample after being idle or disabled - 0 = ADC1 does not use synchronous sampling - bit 0 **SSAMPEN0:** ADC0 Synchronous Sampling bit - 1 = ADC0 uses synchronous sampling for the first sample after being idle or disabled - 0 = ADC0 does not use synchronous sampling - Note 1: Regardless of what alternate input is selected by SHxALT, only for ADC0-ADC5, all control and results are handled by the native SHxALT = `0b00 input. For example, SH0ALT = `0b11 = AN24. However, from a software and silicon hardware control and results register perspective, the user application must initialize the ADC0 module as if AN24 were actually AN0. #### REGISTER 25-5: ADCIMCON1: ADC INPUT MODE CONTROL REGISTER 1 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R/W-0 | 31:24 | DIFF15 | SIGN15 | DIFF14 | SIGN14 | DIFF13 | SIGN13 | DIFF12 | SIGN12 | | 22,46 | R/W-0 | 23:16 | DIFF11 | SIGN11 | DIFF10 | SIGN10 | DIFF9 | SIGN9 | DIFF8 | SIGN8 | | 15:8 | R/W-0 | 13.0 | DIFF7 | SIGN7 | DIFF6 | SIGN6 | DIFF5 | SIGN5 | DIFF4 | SIGN4 | | 7:0 | R/W-0 | 7.0 | DIFF3 | SIGN3 | DIFF2 | SIGN2 | DIFF1 | SIGN1 | DIFF0 | SIGN0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 31 DIFF15: AN15 Mode bit 1 = Selects AN15 differential input pair as AN15+ and AN1- 0 = AN15 is using Single-ended mode bit 30 SIGN:15 AN15 Signed Data Mode bit 1 = AN15 is using Signed Data mode 0 = AN15 is using Unsigned Data mode bit 29 DIFF14: AN14 Mode bit 1 = Selects AN14 differential input pair as AN14+ and AN1- 0 = AN14 is using Single-ended mode bit 28 SIGN14: AN14 Signed Data Mode bit 1 = AN14 is using Signed Data mode 0 = AN14 is using Unsigned Data mode bit 27 DIFF13: AN13 Mode bit 1 = Selects AN13 differential input pair as AN13+ and AN1- 0 = AN13 is using Single-ended mode bit 26 SIGN13: AN13 Signed Data Mode bit 1 = AN13 is using Signed Data mode 0 = AN13 is using Unsigned Data mode bit 25 **DIFF12:** AN12 Mode bit 1 = Selects AN12 differential input pair as AN12+ and AN1- 0 = AN12 is using Single-ended mode bit 24 SIGN12: AN12 Signed Data Mode bit 1 = AN12 is using Signed Data mode 0 = AN12 is using Unsigned Data mode bit 23 **DIFF11:** AN11 Mode bit 1 = Selects AN11 differential input pair as AN11+ and AN1- 0 = AN11 is using Single-ended mode bit 22 SIGN11: AN11 Signed Data Mode bit 1 = AN11 is using Signed Data mode 0 = AN11 is using Unsigned Data mode bit 21 DIFF10: AN10 Mode bit 1 = Selects AN10 differential input pair as AN10+ and AN1- 0 = AN10 is using Single-ended mode | REGISTER | R 25-5: | ADCIMCON1: ADC INPUT MODE CONTROL REGISTER 1 (CONTINUED) | |----------|----------------|------------------------------------------------------------------------------------| | bit 20 | SIGN10 | : AN10 Signed Data Mode bit | | | | 0 is using Signed Data mode 0 is using Unsigned Data mode | | bit 19 | DIFF9: | AN9 Mode bit | | | | ects AN9 differential input pair as AN9+ and AN1-<br>) is using Single-ended mode | | bit 18 | SIGN9: | AN9 Signed Data Mode bit | | | | is using Signed Data mode<br>is using Unsigned Data mode | | bit 17 | _ | AN 8 Mode bit | | | 0 <b>= AN8</b> | ects AN8 differential input pair as AN8+ and AN1-<br>B is using Single-ended mode | | bit 16 | | AN8 Signed Data Mode bit | | | 0 <b>= AN8</b> | B is using Signed Data mode<br>B is using Unsigned Data mode | | bit 15 | | AN7 Mode bit | | | 0 <b>= AN7</b> | ects AN7 differential input pair as AN7+ and AN1-<br>7 is using Single-ended mode | | bit 14 | | AN7 Signed Data Mode bit | | | | ' is using Signed Data mode<br>' is using Unsigned Data mode | | bit 13 | | AN6 Mode bit | | | | ects AN6 differential input pair as AN6+ and AN1-<br>is using Single-ended mode | | bit 12 | | AN6 Signed Data Mode bit | | | | is using Signed Data mode<br>is using Unsigned Data mode | | bit 11 | _ | AN5 Mode bit | | | 0 <b>= AN5</b> | ects AN5 differential input pair as AN5+ and AN11-<br>b is using Single-ended mode | | bit 10 | | AN5 Signed Data Mode bit | | | 0 <b>= AN5</b> | 5 is using Signed Data mode<br>5 is using Unsigned Data mode | | bit 9 | | AN4 Mode bit | | | 0 <b>= AN4</b> | ects AN4 differential input pair as AN4+ and AN10-<br>I is using Single-ended mode | | bit 8 | | AN4 Signed Data Mode bit | | | 0 <b>= AN4</b> | l is using Signed Data mode<br>I is using Unsigned Data mode | | bit 7 | | AN3 Mode bit | | | 0 <b>= AN3</b> | ects AN3 differential input pair as AN3+ and AN27-<br>B is using Single-ended mode | | bit 6 | | AN3 Signed Data Mode bit | | | | B is using Signed Data mode<br>B is using Unsigned Data mode | | bit 5 | | AN2 Mode bit | | | | ects AN2 differential input pair as AN2+ and AN8- | | | | 2 is using Single-ended mode | | bit 4 | | AN2 Signed Data Mode bit | | | | 2 is using Signed Data mode | | | ∪ <b>= AN2</b> | is using Unsigned Data mode | #### REGISTER 25-5: ADCIMCON1: ADC INPUT MODE CONTROL REGISTER 1 (CONTINUED) bit 3 **DIFF1:** AN1 Mode bit 1 = Selects AN1 differential input pair as AN1+ and AN7- 0 = AN1 is using Single-ended mode bit 2 SIGN1: AN1 Signed Data Mode bit 1 = AN1 is using Signed Data mode 0 = AN1 is using Unsigned Data mode bit 1 **DIFF0:** AN0 Mode bit 1 = Selects AN0 differential input pair as AN0+ and AN6- 0 = AN0 is using Single-ended mode bit 0 SIGN0: AN0 Signed Data Mode bit 1 = AN0 is using Signed Data mode 0 = AN0 is using Unsigned Data mode #### REGISTER 25-6: ADCIMCON2: ADC INPUT MODE CONTROL REGISTER 2 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------| | 31:24 | U-0 | 31.24 | | - | _ | _ | _ | 1 | _ | - | | 22.46 | R/W-0 | 23:16 | DIFF27 | SIGN27 | DIFF26 | SIGN26 | DIFF25 | SIGN25 | DIFF24 | SIGN24 | | 15.0 | R/W-0 | 15:8 | DIFF23 <sup>(1)</sup> | SIGN23 <sup>(1)</sup> | DIFF22 <sup>(1)</sup> | SIGN22 <sup>(1)</sup> | DIFF21 <sup>(1)</sup> | SIGN21 <sup>(1)</sup> | DIFF20 <sup>(1)</sup> | SIGN20 <sup>(1)</sup> | | 7:0 | R/W-0 | 7.0 | DIFF19 | SIGN19 | DIFF18 | SIGN18 | DIFF17 | SIGN17 | DIFF16 | SIGN16 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 23 DIFF27: AN27 Mode bit 1 = Selects AN27 differential pair input as AN27+ and AN1- 0 = AN27 is using Single-ended mode bit 22 SIGN27: AN27 Signed Data Mode bit 1 = AN27 is using Signed Data mode 0 = AN27 is using Unsigned Data mode bit 21 DIFF26: AN26 Mode bit 1 = Selects AN26 differential pair input as AN26+ and AN1- 0 = AN26 is using Single-ended mode bit 20 SIGN26: AN26 Signed Data Mode bit 1 = AN26 is using Signed Data mode 0 = AN26 is using Unsigned Data mode bit 19 **DIFF25:** AN25 Mode bit 1 = Selects AN25 differential pair input as AN25+ and AN1- 0 = AN25 is using Single-ended mode bit 18 SIGN25: AN25 Signed Data Mode bit 1 = AN25 is using Signed Data mode 0 = AN25 is using Unsigned Data mode bit 17 DIFF24: AN24 Mode bit 1 = Selects AN24 differential pair input as AN24+ and AN1- 0 = AN24 is using Single-ended mode bit 16 SIGN24: AN24 Signed Data Mode bit 1 = AN24 is using Signed Data mode 0 = AN24 is using Unsigned Data mode bit 15 **DIFF23:** AN23 Mode bit<sup>(1)</sup> 1 = Selects AN23 differential pair input as AN23+ and AN1- 0 = AN23 is using Single-ended mode bit 14 SIGN23: AN23 Signed Data Mode bit<sup>(1)</sup> 1 = AN23 is using Signed Data mode 0 = AN23 is using Unsigned Data mode | REGISTER | 25-6: | ADCIMCON2: ADC INPUT MODE CONTROL REGISTER 2 (CONTINUED) | |----------|-----------------|------------------------------------------------------------------------------------| | bit 13 | DIFF22: | AN22 Mode bit <sup>(1)</sup> | | | | cts AN22 differential pair input as AN22+ and AN1-<br>2 is using Single-ended mode | | bit 12 | SIGN22: | AN22 Signed Data Mode bit <sup>(1)</sup> | | | 0 = AN22 | 2 is using Signed Data mode<br>2 is using Unsigned Data mode | | bit 11 | | AN21 Mode bit <sup>(1)</sup> | | | | cts AN21 differential pair input as AN21+ and AN1-<br>1 is using Single-ended mode | | bit 10 | | AN21 Signed Data Mode bit <sup>(1)</sup> | | | 0 <b>= AN2</b> | 1 is using Signed Data mode<br>1 is using Unsigned Data mode | | bit 9 | | AN20 Mode bit <sup>(1)</sup> | | | 0 = AN20 | cts AN20 differential pair input as AN20+ and AN1-<br>) is using Single-ended mode | | bit 8 | | AN20 Signed Data Mode bit <sup>(1)</sup> | | | | ) is using Signed Data mode<br>) is using Unsigned Data mode | | bit 7 | DIFF19: | AN19 Mode bit | | | | cts AN19 differential pair input as AN19+ and AN1-<br>9 is using Single-ended mode | | bit 6 | | AN19 Signed Data Mode bit | | | | 9 is using Signed Data mode<br>9 is using Unsigned Data mode | | bit 5 | _ | AN18 Mode bit | | | | cts AN18 differential pair input as AN18+ and AN1-<br>3 is using Single-ended mode | | bit 4 | SIGN18: | AN18 Signed Data Mode bit | | | | 3 is using Signed Data mode<br>3 is using Unsigned Data mode | | bit 3 | | AN17 Mode bit | | | | cts AN17 differential pair input as AN17+ and AN1-<br>7 is using Single-ended mode | | bit 2 | | AN17 Signed Data Mode bit | | | | 7 is using Signed Data mode<br>7 is using Unsigned Data mode | | bit 1 | | AN16 Mode bit | | | 0 <b>= AN16</b> | cts AN16 differential pair input as AN16+ and AN1-<br>6 is using Single-ended mode | | bit 0 | | AN16 Signed Data Mode bit | | | | 6 is using Signed Data mode<br>6 is using Unsigned Data mode | | | | | #### REGISTER 25-7: ADCIMCON3: ADC INPUT MODE CONTROL REGISTER 3 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------| | 24.24 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | | 31:24 | DIFF47 <sup>(1)</sup> | SIGN47 <sup>(1)</sup> | DIFF46 <sup>(1)</sup> | SIGN46 <sup>(1)</sup> | DIFF45 <sup>(1)</sup> | SIGN45 <sup>(1)</sup> | _ | | | 22:46 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | | - | | - | DIFF41 <sup>(1)</sup> | SIGN41 <sup>(1)</sup> | DIFF40 <sup>(1)</sup> | SIGN40 <sup>(1)</sup> | | 45.0 | R/W-0 | 15:8 | DIFF39 <sup>(1)</sup> | SIGN39 <sup>(1)</sup> | DIFF38 <sup>(1)</sup> | SIGN38 <sup>(1)</sup> | DIFF37 <sup>(1)</sup> | SIGN37 <sup>(1)</sup> | DIFF36 <sup>(1)</sup> | SIGN36 <sup>(1)</sup> | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | | 7:0 | DIFF35 <sup>(1)</sup> | SIGN35 <sup>(1)</sup> | DIFF34 <sup>(1)</sup> | SIGN34 <sup>(1)</sup> | DIFF33 <sup>(1)</sup> | SIGN33 <sup>(1)</sup> | _ | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 **DIFF47:** AN47 Mode bit<sup>(1)</sup> 1 = Selects AN47 differential input pair as AN47+ and AN1- 0 = AN47 is using Single-ended mode bit 30 SIGN47: AN47 Signed Data Mode bit<sup>(1)</sup> 1 = AN41 is using Signed Data mode 0 = AN41 is using Unsigned Data mode bit 29 **DIFF46:** AN46 Mode bit<sup>(1)</sup> 1 = Selects AN46 differential input pair as AN46+ and AN1- 0 = AN41 is using Single-ended mode bit 28 SIGN46: AN46 Signed Data Mode bit<sup>(1)</sup> 1 = AN46 is using Signed Data mode 0 = AN46 is using Unsigned Data mode bit 27 **DIFF45:** AN45 Mode bit<sup>(1)</sup> 1 = Selects AN45 differential input pair as AN45+ and AN1- 0 = AN45 is using Single-ended mode bit 26 SIGN46: AN45 Signed Data Mode bit<sup>(1)</sup> 1 = AN45 is using Signed Data mode 0 = AN45 is using Unsigned Data mode bit 25-20 Unimplemented: Read as '0' bit 19 **DIFF41:** AN41 Mode bit<sup>(1)</sup> 1 = Selects AN41 differential input pair as AN41+ and AN1- 0 = AN41 is using Single-ended mode bit 18 SIGN41: AN41 Signed Data Mode bit (1) 1 = AN41 is using Signed Data mode 0 = AN41 is using Unsigned Data mode bit 17 **DIFF40:** AN40 Mode bit<sup>(1)</sup> 1 = Selects AN40 differential input pair as AN40+ and AN1- 0 = AN40 is using Single-ended mode bit 16 SIGN40: AN40 Signed Data Mode bit<sup>(1)</sup> 1 = AN40 is using Signed Data mode 0 = AN40 is using Unsigned Data mode | REGISTER | 25-7: ADCIMCON3: ADC INPUT MODE CONTROL REGISTER 3 (CONTINU | ED) | |----------|---------------------------------------------------------------------------------------------------|-----| | bit 15 | DIFF39: AN39 Mode bit <sup>(1)</sup> | | | | L = Selects AN39 differential input pair as AN39+ and AN1-<br>D = AN39 is using Single-ended mode | | | bit 14 | SIGN39: AN39 Signed Data Mode bit <sup>(1)</sup> | | | | L = AN39 is using Signed Data mode<br>D = AN39 is using Unsigned Data mode | | | bit 13 | DIFF38: AN38 Mode bit <sup>(1)</sup> | | | | L = Selects AN38 differential input pair as AN38+ and AN1-<br>D = AN38 is using Single-ended mode | | | bit 12 | SIGN38: AN38 Signed Data Mode bit <sup>(1)</sup> | | | | L = AN38 is using Signed Data mode D = AN38 is using Unsigned Data mode | | | bit 11 | DIFF37: AN37 Mode bit <sup>(1)</sup> | | | | L = Selects AN37 differential input pair as AN37+ and AN1-<br>D = AN37 is using Single-ended mode | | | bit 10 | SIGN37: AN37 Signed Data Mode bit <sup>(1)</sup> | | | | L = AN37 is using Signed Data mode<br>D = AN37 is using Unsigned Data mode | | | bit 9 | DIFF36: AN36 Mode bit <sup>(1)</sup> | | | | L = Selects AN36 differential input pair as AN36+ and AN1-<br>D = AN36 is using Single-ended mode | | | bit 8 | SIGN36: AN36 Signed Data Mode bit <sup>(1)</sup> | | | | L = AN36 is using Signed Data mode<br>D = AN36 is using Unsigned Data mode | | | bit 7 | DIFF35: AN35 Mode bit <sup>(1)</sup> | | | | L = Selects AN35 differential input pair as AN35+ and AN1-<br>D = AN35 is using Single-ended mode | | | bit 6 | SIGN35: AN35 Signed Data Mode bit <sup>(1)</sup> | | | | L = AN35 is using Signed Data mode<br>D = AN35 is using Unsigned Data mode | | | bit 5 | DIFF34: AN34 Mode bit <sup>(1)</sup> | | | | L = Selects AN34 differential input pair as AN34+ and AN1-<br>D = AN34 is using Single-ended mode | | | bit 4 | SIGN34: AN34 Signed Data Mode bit <sup>(1)</sup> | | | | L = AN34 is using Signed Data mode D = AN34 is using Unsigned Data mode | | | bit 3 | DIFF33: AN33 Mode bit <sup>(1)</sup> | | | | L = Selects AN33 differential input pair as AN33+ and AN1-<br>D = AN33 is using Single-ended mode | | | bit 2 | SIGN33: AN33 Signed Data Mode bit <sup>(1)</sup> | | | | L = AN33 is using Signed Data mode<br>D = AN33 is using Unsigned Data mode | | | bit 1-0 | Jnimplemented: Read as '0' | | | DIL I-U | minplemented. Itead as o | | #### REGISTER 25-8: ADCIMCON4: ADC INPUT MODE CONTROL REGISTER 4 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | - | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | - | _ | | | 7.0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | _ | _ | _ | DIFF49 | SIGN49 | DIFF48 | SIGN48 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-4 Unimplemented: Read as '0' bit 3 DIFF49: AN49 Mode bit 1 = Selects AN49 differential input pair as AN49+ and AN1- 0 = AN49 is using Single-ended mode bit 2 SIGN49: AN41 Signed Data Mode bit 1 = AN49 is using Signed Data mode 0 = AN49 is using Unsigned Data mode bit 1 DIFF48: AN48 Mode bit 1 = Selects AN40 differential input pair as AN48+ and AN1- 0 = AN48 is using Single-ended mode bit 0 SIGN48: AN48 Signed Data Mode bit 1 = AN48 is using Signed Data mode0 = AN48 is using Unsigned Data mode © 2017-2021 Microchip Technology Inc. REGISTER 25-9: ADCGIRQEN1: ADC GLOBAL INTERRUPT ENABLE REGISTER 1 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|------------------------|------------------------|------------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31.24 | _ | _ | _ | _ | AGIEN27 | AGIEN26 | AGIEN25 | AGIEN24 | | 00.40 | R/W-0 | 23:16 | AGIEN23 <sup>(1)</sup> | AGIEN22 <sup>(1)</sup> | AGIEN21 <sup>(1)</sup> | AGIEN20 <sup>(1)</sup> | AGIEN19 | AGIEN18 | AGIEN17 | AGIEN16 | | 15.0 | R/W-0 | 15:8 | AGIEN15 | AGIEN14 | AGIEN13 | AGIEN12 | AGIEN11 | AGIEN10 | AGIEN9 | AGIEN8 | | 7.0 | R/W-0 | 7:0 | AGIEN7 | AGIEN6 | AGIEN5 | AGIEN4 | AGIEN3 | AGIEN2 | AGIEN1 | AGIEN0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-0 AGIEN27:AGIEN0: ADC Global Interrupt Enable bits 1 = Interrupts are enabled for the selected analog input. The interrupt is generated after the converted data is ready (indicated by the AIRDYx bit of the ADCDSTAT1 register) 0 = Interrupts are disabled #### REGISTER 25-10: ADCGIRQEN2: ADC GLOBAL INTERRUPT ENABLE REGISTER 2 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | - | 1 | - | - | _ | | 23:16 | U-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 23.10 | _ | _ | AGIEN53 | - | 1 | AGIEN50 | AGIEN49 | AGIEN48 | | 45.0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | AGIEN47 <sup>(1)</sup> | AGIEN46 <sup>(1)</sup> | AGIEN45 <sup>(1)</sup> | _ | _ | _ | AGIEN41 <sup>(1)</sup> | AGIEN40 <sup>(1)</sup> | | 7.0 | R/W-0 U-0 | | 7:0 | AGIEN39 <sup>(1)</sup> | AGIEN38 <sup>(1)</sup> | AGIEN37 <sup>(1)</sup> | AGIEN36 <sup>(1)</sup> | AGIEN35 <sup>(1)</sup> | AGIEN34 <sup>(1)</sup> | AGIEN33 <sup>(1)</sup> | _ | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-22 Unimplemented: Read as '0' bit 21 AGIEN53:ADC Global Interrupt Enable bits 1 = Interrupts are enabled for the selected analog input. The interrupt is generated after the converted data is ready (indicated by the AIRDYx bit of the ADCDSTAT2 register) 0 = Interrupts are disabled bit 20-19 Unimplemented: Read as '0' bit 18-13 AGIEN50: AGIEN45: ADC Global Interrupt Enable bits 1 = Interrupts are enabled for the selected analog input. The interrupt is generated after the converted data is ready (indicated by the AIRDYx bit of the ADCDSTAT2 register) 0 = Interrupts are disabled bit 12-10 Unimplemented: Read as '0' bit 9-1 AGIEN41:AGIEN33 ADC Global Interrupt Enable bits 1 = Interrupts are enabled for the selected analog input. The interrupt is generated after the converted data is ready (indicated by the AIRDYx bit of the ADCDSTAT2 register) 0 = Interrupts are disabled bit 0 **Unimplemented:** Read as '0' REGISTER 25-11: ADCCSS1: ADC COMMON SCAN SELECT REGISTER 1 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|----------------------|----------------------|----------------------|----------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31.24 | _ | _ | _ | _ | CSS27 | CSS26 | CSS25 | CSS24 | | 22,46 | R/W-0 | 23:16 | CSS23 <sup>(1)</sup> | CSS22 <sup>(1)</sup> | CSS21 <sup>(1)</sup> | CSS20 <sup>(1)</sup> | CSS19 | CSS18 | CSS17 | CSS16 | | 15:8 | R/W-0 | 13.0 | CSS15 | CSS14 | CSS13 | CSS12 | CSS11 | CSS10 | CSS9 | CSS8 | | 7:0 | R/W-0 | 7:0 | CSS7 | CSS6 | CSS5 | CSS4 | CSS3 | CSS2 | CSS1 | CSS0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 31-28 Unimplemented: Read as '0' bit 27-0 CSS27:CSS0: Analog Common Scan Select bits Analog inputs AN27-AN6 are always Class 3 shared ADC7. - 1 = Select ANx for input scan (i.e., ANx = CSSx and scan is sequential starting with the lowest to highest enabled CSSx analog input pin) - 0 = Skip ANx for input scan - **Note 1:** In addition to setting the appropriate bits in this register, Class 1 and Class 2 analog inputs must select the STRIG input as the trigger source if they are to be scanned through the CSS*x* bits. Refer to the bit descriptions in the ADCTRGx registers for selecting the STRIG option. - 2: If a Class 1 or Class 2 input is included in the scan by setting the CSSx bit to '1' and by setting the TRGSRCx<4:0> bits to STRIG mode ('0b11), the user application must ensure that no other triggers are generated for that input using the RQCNVRT bit in the ADCCON3 register or the hardware input or any digital filter. Otherwise, the scan behavior is unpredictable. #### REGISTER 25-12: ADCCSS2: ADC COMMON SCAN SELECT REGISTER 2 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------| | 31:24 | U-0 | 31.24 | - | - | - | _ | _ | 1 | - | _ | | 22.46 | U-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | _ | _ | CSS53 <sup>(2)</sup> | _ | _ | CSS50 <sup>(2)</sup> | CSS49 | CSS48 | | 45.0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | CSS47 <sup>(1)</sup> | CSS46 <sup>(1)</sup> | CSS45 <sup>(1)</sup> | _ | _ | _ | CSS41 <sup>(1)</sup> | CSS40 <sup>(1)</sup> | | 7.0 | R/W-0 U-0 | | 7:0 | CSS39 <sup>(1)</sup> | CSS38 <sup>(1)</sup> | CSS37 <sup>(1)</sup> | CSS36 <sup>(1)</sup> | CSS35 <sup>(1)</sup> | CSS34 <sup>(1)</sup> | CSS33 <sup>(1)</sup> | | Legend: bit 12-10 bit 0 R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-22 Unimplemented: Read as '0' bit 21 CSS53:Analog Common Scan Select bits 1 = Select ANx for input scan0 = Skip ANx for input scan bit 20-19 **Unimplemented:** Read as '0' bit 18-13 CSS50:CSS45: Analog Common Scan Select bits 1 = Select ANx for input scan 0 = Skip ANx for input scan **Unimplemented:** Read as '0' bit 9-1 CSS41:CSS33: Analog Common Scan Select bits 1 = Select ANx for input scan 0 = Skip ANx for input scan **Unimplemented:** Read as '0' Note 1: This bit is not available on 64-pin devices. 2: CSS50 and CSS53 are internal analog inputs with respect to internal (IVREF and CTMU Temperature sensor). #### REGISTER 25-13: ADCDSTAT1: ADC DATA READY STATUS REGISTER 1 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|------------------------|------------------------|------------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 31.24 | _ | _ | _ | _ | AIRDY27 | AIRDY26 | AIRDY25 | AIRDY24 | | 23:16 | R-0, HS, HC | 23.10 | AIRDY23 <sup>(1)</sup> | AIRDY22 <sup>(1)</sup> | AIRDY21 <sup>(1)</sup> | AIRDY20 <sup>(1)</sup> | AIRDY19 | AIRDY18 | AIRDY17 | AIRDY16 | | 15:8 | R-0, HS, HC | 13.6 | AIRDY15 | AIRDY14 | AIRDY13 | AIRDY12 | AIRDY11 | AIRDY10 | AIRDY9 | AIRDY8 | | 7:0 | R-0, HS, HC | 7:0 | AIRDY7 | AIRDY6 | AIRDY5 | AIRDY4 | AIRDY3 | AIRDY2 | AIRDY1 | AIRDY0 | **Legend:** HS = Hardware Set HC = Hardware Cleared R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-0 AIRDY27:AIRDY0: Conversion Data Ready for Corresponding Analog Input Ready bits 1 = This bit is set when converted data is ready in the data register 0 = This bit is cleared when the associated data register is read Note 1: This bit is not available on 64-pin devices. #### REGISTER 25-14: ADCDSTAT2: ADC DATA READY STATUS REGISTER 2 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | U-0 | R-0, HS, HC | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 23.10 | _ | _ | AIRDY53 | _ | _ | AIRDY50 | AIRDY49 | AIRDY48 | | 15:8 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | U-0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | | 13.6 | AIRDY47 <sup>(1)</sup> | AIRDY46 <sup>(1)</sup> | AIRDY45 <sup>(1)</sup> | _ | _ | _ | AIRDY41 <sup>(1)</sup> | AIRDY40 <sup>(1)</sup> | | 7:0 | R-0, HS, HC U-0 | | 7.0 | AIRDY39 <sup>(1)</sup> | AIRDY38 <sup>(1)</sup> | AIRDY37 <sup>(1)</sup> | AIRDY36 <sup>(1)</sup> | AIRDY35 <sup>(1)</sup> | AIRDY34 <sup>(1)</sup> | AIRDY33 <sup>(1)</sup> | _ | **Legend:** HS = Hardware Set HC = Hardware Cleared R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-22 Unimplemented: Read as '0' bit 21 **AIRDY53**: 1 = This bit is set when converted data is ready in the data register 0 = This bit is cleared when the associated data register is read bit 20-19 Unimplemented: Read as '0' bit 18-13 AIRDY50:AIRDY45: Conversion Data Ready for Corresponding Analog Input Ready bits 1 = This bit is set when converted data is ready in the data register 0 = This bit is cleared when the associated data register is read bit 12-10 Unimplemented: Read as '0' #### REGISTER 25-14: ADCDSTAT2: ADC DATA READY STATUS REGISTER 2 (CONTINUED) bit 9-1 AIRDY41:AIRDY33: Conversion Data Ready for Corresponding Analog Input Ready bits 1 = This bit is set when converted data is ready in the data register $\ensuremath{\text{0}}$ = This bit is cleared when the associated data register is read bit 0 Unimplemented: Read as '0' # REGISTER 25-15: ADCCMPENx: ADC DIGITAL COMPARATOR 'x' ENABLE REGISTER ('x' = 1 THROUGH 4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-----------------------|-----------------------|-----------------------|-----------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31.24 | _ | _ | _ | _ | CMPE27 | CMPE26 | CMPE25 | CMPE24 | | 23:16 | R/W-0 | 23.10 | CMPE23 <sup>(1)</sup> | CMPE22 <sup>(1)</sup> | CMPE21 <sup>(1)</sup> | CMPE20 <sup>(1)</sup> | CMPE19 | CMPE18 | CMPE17 | CMPE16 | | 15:8 | R/W-0 | 15.6 | CMPE15 | CMPE14 | CMPE13 | CMPE12 | CMPE11 | CMPE10 | CMPE9 | CMPE8 | | 7:0 | R/W-0 | 7:0 | CMPE7 | CMPE6 | CMPE5 | CMPE4 | CMPE3 | CMPE2 | CMPE1 | CMPE0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-0 CMPE27:CMPE0: ADC Digital Comparator 'x' Enable bits These bits enable conversion results corresponding to the Analog Input to be processed by the Digital Comparator. CMPE0 enables AN0, CMPE1 enables AN1, and so on. Note 1: This bit is not available on 64-pin devices. **Note 1:** CMPEx = ANx, where 'x' = 0-31 (Digital Comparator inputs are limited to AN0 through AN31). 2: Changing the bits in this register while the Digital Comparator is enabled (ENDCMP = 1) can result in unpredictable behavior. # REGISTER 25-16: ADCCMPx: ADC DIGITAL COMPARATOR 'x' LIMIT VALUE REGISTER ('x' = 1 THROUGH 4) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|--------------------|---------------------------------|-------------------|-------------------|-------------------------|-------------------|------------------|------------------|--|--| | 31:24 | R/W-0 | | | 31.24 | | DCMPHI<15:8> <sup>(1,2,3)</sup> | | | | | | | | | | 23:16 | R/W-0 | | | 23.10 | DCMPHI<7:0>(1,2,3) | | | | | | | | | | | 15:8 | R/W-0 | | | 15.6 | | DCMPLO<15:8>(1,2,3) | | | | | | | | | | 7:0 | R/W-0 | | | 7.0 | | | | DCMPLO< | 7:0> <sup>(1,2,3)</sup> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 **DCMPHI<15:0>:** Digital Comparator 'x' High Limit Value bits<sup>(1,2,3)</sup> These bits store the high limit value, which is used by digital comparator for comparisons with ADC converted data. bit 15-0 **DCMPLO<15:0>:** Digital Comparator 'x' Low Limit Value bits<sup>(1,2,3)</sup> These bits store the low limit value, which is used by digital comparator for comparisons with ADC converted data. - **Note 1:** Changing theses bits while the Digital Comparator is enabled (ENDCMP = 1) can result in unpredictable behavior. - 2: The format of the limit values should match the format of the ADC converted value in terms of sign and fractional settings. - **3:** For Digital Comparator 0 used in CVD mode, the DCMPHI<15:0> and DCMPLO<15:0> bits must always be specified in signed format, as the CVD output data is differential and is always signed. # REGISTER 25-17: ADCFLTRx: ADC DIGITAL FILTER 'x' REGISTER ('x' = 1 THROUGH 6) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | R/W-0 R-0, HS, HC | | | 31.24 | AFEN | DATA16EN | DFMODE | C | VRSAM<2:0 | AFGIEN | AFRDY | | | | 23:16 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23.10 | _ | _ | _ | CHNLID<4:0> | | | | | | | 15:8 | R-0, HS, HC | | 13.6 | FLTRDATA<15:8> | | | | | | | | | | 7:0 | R-0, HS, HC | | 7:0 | | | | FLTRDAT | A<7:0> | | | | | Legend:HS = Hardware SetHC = Hardware ClearedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown - bit 31 AFEN: Digital Filter 'x' Enable bit - 1 = Digital filter is enabled - 0 = Digital filter is disabled and the AFRDY status bit is cleared Note: If ADCFLTRx<AFEN> = 1 then ADCxTIME<SAMC> min must be ≥ to 0x004 or equivalent to ≥ 6 TAD. This will correspondingly reduce the max sampling rate. - bit 30 DATA16EN: Filter Significant Data Length bit - 1 = All 16 bits of the filter output data are significant - 0 = Only the first 12 bits are significant, followed by four zeros Note: This bit is significant only if DFMODE = 1 (Averaging Mode) and FRACT (ADCCON1<23>) = 1 (Fractional Output Mode). - bit 29 **DFMODE:** ADC Filter Mode bit - 1 = Filter 'x' works in Averaging mode - 0 = Filter 'x' works in Oversampling Filter mode (default) - bit 28-26 OVRSAM<2:0>: Oversampling Filter Ratio bits #### If DFMODE is '0': - 111 = 128 samples (shift sum 3 bits to right, output data is in 15.1 format) - 110 = 32 samples (shift sum 2 bits to right, output data is in 14.1 format) - 101 = 8 samples (shift sum 1 bit to right, output data is in 13.1 format) - 100 = 2 samples (shift sum 0 bits to right, output data is in 12.1 format) - 011 = 256 samples (shift sum 4 bits to right, output data is 16 bits) - 010 = 64 samples (shift sum 3 bits to right, output data is 15 bits) - 001 = 16 samples (shift sum 2 bits to right, output data is 14 bits) - 000 = 4 samples (shift sum 1 bit to right, output data is 13 bits) #### If DFMODE is '1': - 111 = 256 samples (256 samples to be averaged) - 110 = 128 samples (128 samples to be averaged) - 101 = 64 samples (64 samples to be averaged) - 100 = 32 samples (32 samples to be averaged) - 011 = 16 samples (16 samples to be averaged) - 010 = 8 samples (8 samples to be averaged) - 001 = 4 samples (4 samples to be averaged) 000 = 2 samples (2 samples to be averaged) - Note 1: This selection is not available on 64-pin devices. # REGISTER 25-17: ADCFLTRx: ADC DIGITAL FILTER 'x' REGISTER ('x' = 1 THROUGH 6) (CONTINUED) - bit 25 AFGIEN: Digital Filter 'x' Interrupt Enable bit - 1 = Digital filter interrupt is enabled and is generated by the AFRDY status bit - 0 = Digital filter is disabled - bit 24 AFRDY: Digital Filter 'x' Data Ready Status bit - 1 = Data is ready in the FLTRDATA<15:0> bits - 0 = Data is not ready Note: This bit is cleared by reading the FLTRDATA<15:0> bits or by disabling the Digital Filter module (by setting AFEN to '0'). - bit 23-21 Unimplemented: Read as '0' - bit 20-16 CHNLID<4:0>: Digital Filter Analog Input Selection bits These bits specify the analog input to be used as the oversampling filter data source. ``` 11111 = Reserved 11100 = Reserved 11011 = AN27 input 11010 = AN26 input 11001 = AN25 input 11000 = AN24 input 10111 = AN23<sup>(1)</sup> input 10110 = AN22<sup>(1)</sup> input 10101 = AN21<sup>(1)</sup> input 10100 = AN20^{(1)} input 10011 = AN19 input 10110 = AN6 input 00101 = ADC5 Module 00100 = ADC4 Module 00011 = ADC3 Module 00010 = ADC2 Module ``` 00001 = ADC1 Module 00000 = ADC0 Module Note: Only the first 32 analog inputs (Class 1 and Class 2) can use a digital filter. bit 15-0 FLTRDATA<15:0>: Digital Filter 'x' Data Output Value bits The filter output data is as per the fractional format set in the FRACT (ADCCON1<23>) bit. The FRACT bit should not be changed while the filter is enabled. Changing the state of the FRACT bit after the operation of the filter ended will not update the value of FLTRDATA<15:0> to reflect the new format. #### REGISTER 25-18: ADCTRG1: ADC TRIGGER SOURCE 1 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 31:24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 31.24 | _ | _ | _ | | TRGSRC3<4:0> | | | | | | | | 22:16 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 23:16 | _ | _ | _ | TRGSRC2<4:0> | | | | | | | | | 15:8 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 13.0 | _ | _ | _ | TRGSRC1<4:0> | | | | | | | | | 7:0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 7:0 | 1 | | 1 | | Т | RGSRC0<4:0 | )> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' bit 28-24 TRGSRC3<4:0>: Trigger Source for Conversion of ADC3 Module Select bits 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit(1) 11001 = PWM Generator 2 Current-Limit<sup>(1)</sup> 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = Reserved 10011 = Output Compare 4 rising edge 10010 = Output Compare 3 rising edge 10001 = Output Compare 2 rising edge 10000 = Output Compare 1 rising edge 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary Special Event Trigger<sup>(1)</sup> 01000 = Primary Special Event Trigger<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 = INT0 00011 = Scan trigger<sup>(2)</sup> 00010 = Software level trigger (must also configure the ADCTRGNS register) 00001 = Software edge trigger 00000 **= No Trigger** Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-18: ADCTRG1: ADC TRIGGER SOURCE 1 REGISTER - bit 23-21 Unimplemented: Read as '0' - bit 20-16 **TRGSRC2<4:0>:** Trigger Source for Conversion of ADC2 Module Select bits See bits 28-24 for bit value definitions. - bit 15-13 Unimplemented: Read as '0' - bit 12-8 **TRGSRC1<4:0>:** Trigger Source for Conversion of ADC1 Module Select bits See bits 28-24 for bit value definitions. - bit 7-5 Unimplemented: Read as '0' - bit 4-0 **TRGSRC0<4:0>:** Trigger Source for Conversion of ADC0 Module Select bits See bits 28-24 for bit value definitions. - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-19: ADCTRG2: ADC TRIGGER SOURCE 2 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | _ | _ | - | TRGSRC7<4:0> | | | | | | | | 22,46 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | _ | _ | _ | TRGSRC6<4:0> | | | | | | | | 45.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | _ | _ | - | | T | RGSRC5<4:0 | )> | | | | | 7.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | _ | _ | _ | | TRGSRC4<4:0> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' ``` bit 28-24 TRGSRC7<4:0>: Trigger Source for Conversion of Analog Input AN7 Select bits ``` 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit(1) 11001 = PWM Generator 2 Current-Limit<sup>(1)</sup> 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = CTMU trip 10011 = Output Compare 4 rising edge 10010 = Output Compare 3 rising edge 10001 = Output Compare 2 rising edge 10000 = Output Compare 1 rising edge 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary Special Event Trigger<sup>(1)</sup> 01000 = Primary Special Event Trigger<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 = INT0 00011 = Scan trigger<sup>(2)</sup> 00010 = Software level trigger (must also configure the ADCTRGNS register) 00001 = Software edge trigger 00000 = No trigger Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-19: ADCTRG2: ADC TRIGGER SOURCE 2 REGISTER - bit 23-21 Unimplemented: Read as '0' - bit 20-16 **TRGSRC6<4:0>:** Trigger Source for Conversion of Analog Input AN6 Select bits See bits 28-24 for bit value definitions. - bit 15-13 Unimplemented: Read as '0' - bit 12-8 **TRGSRC5<4:0>:** Trigger Source for Conversion of ADC5 Module Select bits See bits 28-24 for bit value definitions. - bit 7-5 **Unimplemented:** Read as '0' - bit 4-0 **TRGSRC4<4:0>:** Trigger Source for Conversion of ADC4 Module Select bits See bits 28-24 for bit value definitions. - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-20: ADCTRG3: ADC TRIGGER SOURCE 3 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 24.24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 31:24 | _ | _ | - | | TRGSRC11<4:0> | | | | | | | | 22,16 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 23:16 | _ | _ | | TRGSRC10<4:0> | | | | | | | | | 45.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 15:8 | _ | _ | | | Т | RGSRC9<4:0 | )> | | | | | | 7.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | 7:0 | | 1 | 1 | | T | RGSRC8<4:0 | )> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' ``` bit 28-24 TRGSRC11<4:0>: Trigger Source for Conversion of Analog Input AN11 Select bits ``` 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit<sup>(1)</sup> 11001 = PWM Generator 2 Current-Limit<sup>(1)</sup> 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = CTMU trip 10011 = Output Compare 4 rising edge 10010 = Output Compare 3 rising edge 10001 = Output Compare 2 rising edge 10000 = Output Compare 1 rising edge 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary Special Event Trigger<sup>(1)</sup> 01000 = Primary Special Event Trigger<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 **= INTO** 00011 = Scan trigger<sup>(2)</sup> 00010 = Software level trigger (must also configure the ADCTRGNS register) 00001 = Software edge trigger 00000 = No trigger Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-20: ADCTRG3: ADC TRIGGER SOURCE 3 REGISTER - bit 23-21 Unimplemented: Read as '0' - bit 20-16 **TRGSRC10<4:0>:** Trigger Source for Conversion of Analog Input AN10 Select bits See bits 28-24 for bit value definitions. - bit 15-13 Unimplemented: Read as '0' - bit 12-8 **TRGSRC9<4:0>:** Trigger Source for Conversion of Analog Input AN9 Select bits See bits 28-24 for bit value definitions. - bit 7-5 Unimplemented: Read as '0' - bit 4-0 **TRGSRC8<4:0>:** Trigger Source for Conversion of Analog Input AN8 Select bits See bits 28-24 for bit value definitions. - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-21: ADCTRG4: ADC TRIGGER SOURCE 4 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | _ | | - | TRGSRC15<4:0> | | | | | | 23:16 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | _ | - | - | TRGSRC14<4:0> | | | | | | 15:8 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | _ | _ | _ | TRGSRC13<4:0> | | | | | | 7:0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | _ | | | TRGSRC12<4:0> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' bit 28-24 TRGSRC15<4:0>: Trigger Source for Conversion of Analog Input AN15 Select bits 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit<sup>(1)</sup> 11001 = PWM Generator 2 Current-Limit(1) 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = CTMU trip 10011 = Output Compare 4 rising edge 10010 = Output Compare 3 rising edge 10001 = Output Compare 2 rising edge 10000 = Output Compare 1 rising edge 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary Special Event Trigger<sup>(1)</sup> 01000 = Primary Special Event Trigger<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 **= INTO** 00011 = Scan trigger<sup>(2)</sup> 00010 = Software level trigger (must also configure the ADCTRGNS register) 00001 = Software edge trigger 00000 = No trigger Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-21: ADCTRG4: ADC TRIGGER SOURCE 4 REGISTER - bit 23-21 Unimplemented: Read as '0' - bit 20-16 **TRGSRC14<4:0>:** Trigger Source for Conversion of Analog Input AN14 Select bits See bits 28-24 for bit value definitions. - bit 15-13 Unimplemented: Read as '0' - bit 12-8 **TRGSRC13<4:0>:** Trigger Source for Conversion of Analog Input AN13 Select bits See bits 28-24 for bit value definitions. - bit 7-5 Unimplemented: Read as '0' - bit 4-0 **TRGSRC12<4:0>:** Trigger Source for Conversion of Analog Input AN12 Select bits See bits 28-24 for bit value definitions. - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-22: ADCTRG5: ADC TRIGGER SOURCE 5 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|------------------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 31.24 | _ | _ | _ | TRGSRC19<4:0> <sup>(3)</sup> | | | | | | | 22,46 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | _ | _ | _ | TRGSRC18<4:0> | | | | | | | 15:8 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 15.8 | _ | _ | _ | TRGSRC17<4:0> | | | | | | | 7.0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 7:0 | _ | _ | _ | | TF | RGSRC16<4: | 0> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 31-29 Unimplemented: Read as '0' bit 28-24 TRGSRC19<4:0>: Trigger Source for Conversion of Analog Input AN19 Select bits<sup>(3)</sup> 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit(1) 11001 = PWM Generator 2 Current-Limit<sup>(1)</sup> 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = CTMU trip 10011 = Output Compare 4 rising edge 10010 = Output Compare 3 rising edge 10001 = Output Compare 2 rising edge 10000 = Output Compare 1 rising edge 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary Special Event Trigger<sup>(1)</sup> 01000 = Primary Special Event Trigger<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 = INTO 00011 = Scan trigger<sup>(2)</sup> 00010 = Software level trigger (must also configure the ADCTRGNS register) 00001 = Software edge trigger 00000 **= No trigger** Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. - 3: These bits are not available on 64-pin devices. #### REGISTER 25-22: ADCTRG5: ADC TRIGGER SOURCE 5 REGISTER - bit 23-21 Unimplemented: Read as '0' - bit 20-16 **TRGSRC18<4:0>:** Trigger Source for Conversion of Analog Input AN18 Select bits See bits 28-24 for bit value definitions. - bit 15-13 Unimplemented: Read as '0' - bit 12-8 **TRGSRC17<4:0>:** Trigger Source for Conversion of Analog Input AN17 Select bits See bits 28-24 for bit value definitions. - bit 7-5 Unimplemented: Read as '0' - bit 4-0 **TRGSRC16<4:0>:** Trigger Source for Conversion of Analog Input AN16 Select bits See bits 28-24 for bit value definitions. - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. - 3: These bits are not available on 64-pin devices. #### REGISTER 25-23: ADCTRG6: ADC TRIGGER SOURCE 6 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 31.24 | _ | _ | _ | TRGSRC23<4:0> | | | | | | | 22.46 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | _ | _ | _ | TRGSRC22<4:0> | | | | | | | 15:8 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 15.6 | _ | _ | _ | TRGSRC21<4:0> | | | | | | | 7:0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 7.0 | _ | _ | _ | | TF | RGSRC20<4: | 0> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' bit 28-24 TRGSRC23<4:0>: Trigger Source for Conversion of Analog Input AN23 Select bits 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit<sup>(1)</sup> 11001 = PWM Generator 2 Current-Limit<sup>(1)</sup> 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = CTMU trip 10011 = Output Compare 4 rising edge 10010 = Output Compare 3 rising edge 10001 = Output Compare 2 rising edge 10000 = Output Compare 1 rising edge 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary Special Event Trigger<sup>(1)</sup> 01000 = Primary Special Event Trigger<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 = INTO 00011 = Scan trigger<sup>(2)</sup> 00010 = Software level trigger (must also configure the ADCTRGNS register) 00001 = Software edge trigger 00000 = **No trigger** Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-23: ADCTRG6: ADC TRIGGER SOURCE 6 REGISTER - bit 23-21 Unimplemented: Read as '0' - bit 20-16 **TRGSRC22<4:0>:** Trigger Source for Conversion of Analog Input AN22 Select bits See bits 28-24 for bit value definitions. - bit 15-13 Unimplemented: Read as '0' - bit 12-8 **TRGSRC21<4:0>:** Trigger Source for Conversion of Analog Input AN21 Select bits See bits 28-24 for bit value definitions. - bit 7-5 Unimplemented: Read as '0' - bit 4-0 **TRGSRC20<4:0>:** Trigger Source for Conversion of Analog Input AN20 Select bits See bits 28-24 for bit value definitions. - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-24: ADCTRG7: ADC TRIGGER SOURCE 7 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 31.24 | _ | _ | _ | TRGSRC27<4:0> | | | | | | | 22,46 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | _ | _ | _ | TRGSRC26<4:0> | | | | | | | 15:8 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 15.6 | _ | _ | _ | TRGSRC25<4:0> | | | | | | | 7:0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 7.0 | _ | _ | _ | | TF | RGSRC24<4: | 0> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' bit 28-24 TRGSRC27<4:0>: Trigger Source for Conversion of Analog Input AN27 Select bits 11111 = Reserved 11110 = PWM Generator 12 trigger<sup>(1)</sup> 11101 = PWM Generator 11 trigger<sup>(1)</sup> 11100 = PWM Generator 10 trigger<sup>(1)</sup> 11011 = PWM Generator 4 Current-Limit<sup>(1)</sup> 11010 = PWM Generator 3 Current-Limit(1) 11001 = PWM Generator 2 Current-Limit<sup>(1)</sup> 11000 = PWM Generator 1 Current-Limit<sup>(1)</sup> 10111 = PWM Generator 9 trigger<sup>(1)</sup> 10110 = PWM Generator 8 trigger<sup>(1)</sup> 10101 = PWM Generator 7 trigger<sup>(1)</sup> 10100 = CTMU trip 10011 = Output Compare 4 rising edge 10010 = Output Compare 3 rising edge 10001 = Output Compare 2 rising edge 10000 = Output Compare 1 rising edge 01111 = PWM Generator 6 trigger<sup>(1)</sup> 01110 = PWM Generator 5 trigger<sup>(1)</sup> 01101 = PWM Generator 4 trigger<sup>(1)</sup> 01100 = PWM Generator 3 trigger<sup>(1)</sup> 01011 = PWM Generator 2 trigger<sup>(1)</sup> 01010 = PWM Generator 1 trigger<sup>(1)</sup> 01001 = Secondary Special Event Trigger<sup>(1)</sup> 01000 = Primary Special Event Trigger<sup>(1)</sup> 00111 = General Purpose Timer5 00110 = General Purpose Timer3 00101 = General Purpose Timer1 00100 = INTO 00011 = Scan trigger<sup>(2)</sup> 00010 = Software level trigger (must also configure the ADCTRGNS register) 00001 = Software edge trigger 00000 = **No trigger** Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. #### REGISTER 25-24: ADCTRG7: ADC TRIGGER SOURCE 7 REGISTER - bit 23-21 Unimplemented: Read as '0' - bit 20-16 **TRGSRC26<4:0>:** Trigger Source for Conversion of Analog Input AN26 Select bits See bits 28-24 for bit value definitions. - bit 15-13 Unimplemented: Read as '0' - bit 12-8 **TRGSRC25<4:0>:** Trigger Source for Conversion of Analog Input AN25 Select bits See bits 28-24 for bit value definitions. - bit 7-5 Unimplemented: Read as '0' - bit 4-0 **TRGSRC24<4:0>:** Trigger Source for Conversion of Analog Input AN24 Select bits See bits 28-24 for bit value definitions. - Note 1: The PWM bit definitions are only applicable to PIC32MKXXXMCMXX Motor Control devices. - 2: For Scan Trigger, in addition to setting the trigger, it also requires programming of the STRGSRC<4:0> bits (ADCCON1<20:16>) to select the trigger source, and requires the appropriate CSS bits to be set in the ADCCSSx registers. ### REGISTER 25-25: ADCCMPCON1: ADC DIGITAL COMPARATOR 1 CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 31:24 | R-0, HS, HC | | | 31.24 | CVDDATA<15:8> | | | | | | | | | | | 23:16 | R-0, HS, HC | | | 23.10 | CVDDATA<7:0> | | | | | | | | | | | 15:8 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | | | 13.0 | — — AINID<5:0> | | | | | | | | | | | 7:0 | R/W-0 | R/W-0 | R-0, HS, HC | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | ENDCMP | DCMPGIEN | DCMPED | IEBTWN | IEHIHI | IEHILO | IELOHI | IELOLO | | | | Legend: | HS = Hardware Set | HC = Hardware Cleared | | |-------------------|-------------------|---------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, re | ead as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | #### bit 31-16 CVDDATA<15:0>: CVD Data Status bits In CVD mode, these bits obtain the CVD differential output data (subtraction of CVD positive and negative measurement), whenever a Digital Comparator interrupt is generated. The value in these bits is compliant with the FRACT bit (ADCCON1<23>) and is always signed. bit 15-14 Unimplemented: Read as '0' # REGISTER 25-25: ADCCMPCON1: ADC DIGITAL COMPARATOR 1 CONTROL REGISTER (CONTINUED) bit 13-8 AINID<5:0>: Digital Comparator 1 Analog Input Identification (ID) bits When a digital comparator event occurs (DCMPED = 1), these bits identify the analog input being monitored by Digital Comparator 1. **Note:** In normal ADC mode, only analog inputs <31:0> can be processed by the Digital Comparator 1. The Digital Comparator 1 also supports the CVD mode, in which all Class 2 and Class 3 analog inputs may be stored in the AINID<5:0> bits. ``` 111111 = Reserved 110110 = Reserved 110101 = Internal AN53 (CTMU temperature sensor) 110101 = Reserved 110101 = Reserved 110010 = Internal AN50 (IVREF 1.2V) 110001 = AN49 is being monitored 101101 = AN45 is being monitored 101100 = Reserved 101010 = Reserved 101001 = AN41 is being monitored 100001 = AN33 is being monitored 111100 = Reserved 111000 = Reserved 111011 = AN27 is being monitored 000000 = AN0 is being monitored For 64 pin devices AN20-AN23 and AN33-AN47 inputs above are not implemented. ENDCMP: Digital Comparator 1 Enable bit 1 = Digital Comparator 1 is enabled 0 = Digital Comparator 1 is not enabled, and the DCMPED status bit (ADCCMP0CON<5>) is cleared DCMPGIEN: Digital Comparator 1 Global Interrupt Enable bit 1 = A Digital Comparator 1 interrupt is generated when the DCMPED status bit (ADCCMP0CON<5>) is set 0 = A Digital Comparator 1 interrupt is disabled DCMPED: Digital Comparator 1 "Output True" Event Status bit The logical conditions under which the digital comparator gets "True" are defined by the IEBTWN, IEHIHI, IEHILO, IELOHI, and IELOLO bits. This bit is cleared by reading the AINID<5:0> bits or by disabling the Digital Comparator module (by setting ENDCMP to '0'). 1 = Digital Comparator 1 output true event has occurred (output of Comparator is '1') 0 = Digital Comparator 1 output is false (output of comparator is '0') IEBTWN: Between Low/High Digital Comparator 1 Event bit 1 = Generate a digital comparator event when DCMPLO<15:0> ≤ DATA<31:0> < DCMPHI<15:0> 0 = Do not generate a digital comparator event ``` bit 7 bit 6 bit 5 bit 4 # REGISTER 25-25: ADCCMPCON1: ADC DIGITAL COMPARATOR 1 CONTROL REGISTER (CONTINUED) - bit 3 IEHIHI: High/High Digital Comparator 0 Event bit 1 = Generate a Digital Comparator 0 Event when DCMPHI<15:0> ≤ DATA<31:0> 0 = Do not generate an event bit 2 IEHILO: High/Low Digital Comparator 0 Event bit 1 = Generate a Digital Comparator 0 Event when DATA<31:0> < DCMPHI<15:0> 0 = Do not generate an event bit 1 IELOHI: Low/High Digital Comparator 0 Event bit - 1 = Generate a Digital Comparator 0 Event when DCMPLO<15:0> ≤ DATA<31:0> 0 = Do not generate an event - bit 0 IELOLO: Low/Low Digital Comparator 0 Event bit 1 = Generate a Digital Comparator 0 Event when DATA<31:0> < DCMPLO<15:0> 0 = Do not generate an event # REGISTER 25-26: ADCCMPCONx: ADC DIGITAL COMPARATOR 'x' CONTROL REGISTER ('x' = 2 THROUGH 4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 13.0 | _ | _ | _ | | | AINID<4:0> | | | | 7:0 | R/W-0 | R/W-0 | R-0, HS, HC | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | ENDCMP | DCMPGIEN | DCMPED | IEBTWN | IEHIHI | IEHILO | IELOHI | IELOLO | Legend:HS = Hardware SetHC = Hardware ClearedR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown #### bit 31-13 Unimplemented: Read as '0' bit 12-8 AINID<4:0>: Digital Comparator 'x' Analog Input Identification (ID) bits When a digital comparator event occurs (DCMPED = 1), these bits identify the analog input being monitored by the Digital Comparator. Note: Only analog inputs <27:0> can be processed by the Digital Comparator module 'x' ('x' = 2-4). 11111 = Reserved . 11100 = Reserved 11011 = AN27 11010 = AN26 11001 = AN25 11000 = AN24 10111 = AN23(1) 10110 = AN22(1) 10101 = AN21(1) 10100 = AN20(1) 10011 = AN19 . . 00001 = AN1 00000 = AN0bit 7 ENDCMP: Digital Comparator 'x' Enable bit 1 = Digital Comparator 'x' is enabled 0 = Digital Comparator 'x' is not enabled, and the DCMPED status bit (ADCCMPxCON<5>) is cleared bit 6 **DCMPGIEN:** Digital Comparator 'x' Global Interrupt Enable bit 1 = A Digital Comparator 'x' interrupt is generated when the DCMPED status bit (ADCCMPxCON<5>) is set 0 = A Digital Comparator 'x' interrupt is disabled # REGISTER 25-26: ADCCMPCONx: ADC DIGITAL COMPARATOR 'x' CONTROL REGISTER ('x' = 2 THROUGH 4) (CONTINUED) bit 5 DCMPED: Digital Comparator 'x' "Output True" Event Status bit The logical conditions under which the digital comparator gets "True" are defined by the IEBTWN, IEHIHI, IEHILO, IELOHI and IELOLO bits. This bit is cleared by reading the AINID<5:0> bits (ADCCMPCONx<13:8>) or by disabling the Digital Comparator module (by setting ENDCMP to '0'). - 1 = Digital Comparator 'x' output true event has occurred (output of Comparator is '1') - 0 = Digital Comparator 'x' output is false (output of Comparator is '0') - bit 4 **IEBTWN:** Between Low/High Digital Comparator 'x' Event bit - 1 = Generate a digital comparator event when the DCMPLO<15:0> bits ≤ DATA<31:0> bits < DCMPHI<15:0> bits - 0 = Do not generate a digital comparator event - bit 3 **IEHIHI:** High/High Digital Comparator 'x' Event bit - 1 = Generate a Digital Comparator 'x' Event when the DCMPHI<15:0> bits ≤ DATA<31:0> bits - 0 = Do not generate an event - bit 2 **IEHILO:** High/Low Digital Comparator 'x' Event bit - 1 = Generate a Digital Comparator 'x' Event when the DATA<31:0> bits < DCMPHI<15:0> bits - 0 = Do not generate an event - bit 1 IELOHI: Low/High Digital Comparator 'x' Event bit - 1 = Generate a Digital Comparator 'x' Event when the DCMPLO<15:0> bits ≤ DATA<31:0> bits - 0 = Do not generate an event - bit 0 IELOLO: Low/Low Digital Comparator 'x' Event bit - 1 = Generate a Digital Comparator 'x' Event when the DATA<31:0> bits < DCMPLO<15:0> bits - 0 = Do not generate an event - **Note 1:** This setting is not available on 64-pin devices. #### REGISTER 25-27: ADCBASE: ADC BASE REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | - | _ | - | | - | _ | | 23:16 | U-0 | 23.10 | - | | - | - | - | _ | - | - | | 15:8 | R/W-0 | 15.6 | ADCBASE<15:8> | | | | | | | | | 7:0 | R/W-0 | 7.0 | | | | ADCBAS | SE<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 Unimplemented: Read as '0' bit 15-0 ADCBASE<15:0>: ADC ISR Base Address bits This register, when read, contains the base address of the user's ADC ISR jump table. The interrupt vector address is determined by the IRQVS<2:0> bits of the ADCCON1 register specifying the amount of left shift done to the AIRDYx status bits in the ADCDSTAT1 and ADCDSTAT2 registers, prior to adding with ADCBASE register. Interrupt Vector Address = Read Value of ADCBASE and Read Value of ADCBASE = Value written to ADCBASE + x << IRQVS<2:0>, where 'x' is the smallest active analog input ID from the ADCDSTAT1 or ADCDSTAT2 registers (which has highest priority). #### REGISTER 25-28: ADCDSTAT: ADC DMA STATUS REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31.24 | DMAEN | | RBFIE5 | RBFIE4 | RBFIE3 | RBFIE2 | RBFIE1 | RBFIE0 | | 23:16 | R-0, HS, HC | 23.10 | WOVERR | | RBF5 | RBF4 | RBF3 | RBF2 | RBF1 | RBF0 | | 15:8 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15.6 | DMACEN | | RAFIE5 | RAFIE4 | RAFIE3 | RAFIE2 | RAFIE1 | RAFIE0 | | 7:0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 7.0 | | | RAF5 | RAF4 | RAF3 | RAF2 | RAF1 | RAF0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 DMAEN: Global ADC DMA Enable bit 1 = DMA interface is enabled0 = DMA interface is disabled When DMAEN = 0, no data is being saved into internal SRAM, no SRAM Writes occur and the DMA interface logic is being kept in reset state. Note: Before setting the DMAEN bit to '1', the user application must ensure that the BCHEN bit (ADCxTIME<23>) is configured as needed. bit 30 Unimplemented: Read as '0' bit 29-24 RBFIE5:RBFIE0: RAM DMA Buffer B Full Interrupt Enable bits for ADC5-ADC0 1 = Enable ping-pong DMA Buffer B interrupt requests for ADC5-ADC0 0 = Disable ping-pong DMA Buffer B interrupt requests for ADC5-ADC0 bit 23 WOVERR: DMA Transfer Error This bit is set by hardware and cleared by hardware after a software read of the ADCDSTAT register. If this bit is set, the ADC conversion results transferred by DMA are erroneous. Discarding the entire ADC ram buffer data is recommended. bit 22 Unimplemented: Read as '0' bit 21-16 RBF5:RBF0: RAM DMA Buffer B Full Status bits for ADC5-ADC0 1 = RAM DMA ping-pong Buffer B is full 0 = RAM DMA pin-pong Buffer B is not full When RBFIEx = 1 and the RBFx bit status is set, the individual ADCx DMA interrupt request is generated. **Note:** All of these bits will self-clear upon any read by software of this register. It is recommended therefore that the user logically OR the register contents to a user defined variable to be used for testing the DMA status in the user's code. The user software would therefore need to clear the corresponding variable bit after the buffer full status was processed. bit 15 DMACEN: ADC DMA Buffer Sample Count Enable bit The DMA interface will save the current sample count for each buffer in the table starting at the ADCCNTB address after each sample write into the corresponding buffer in the SRAM. bit 14 Unimplemented: Read as '0' bit 13-8 RAFIE5: RAFIE0: RAM DMA Buffer A Full Interrupt Enable bits for ADC5-ADC0 1 = Enable ping-pong DMA Buffer A interrupt requests for ADC5-ADC0 0 = Disable ping-pong DMA Buffer A interrupt requests for ADC5-ADC0 bit 7-6 Unimplemented: Read as '0' **Note:** The individual Class 1 High-Speed ADC5-ADC0 modules have an independent DMA bus initiator and are completely separate from the assignable general purpose DMA channels. #### REGISTER 25-28: ADCDSTAT: ADC DMA STATUS REGISTER (CONTINUED) bit 5-0 RAF5:RAF0: RAM DMA Ping-Pong Buffer A Full Status bits for ADC5-ADC0 1 = RAM DMA ping-pong Buffer A is full 0 = RAM DMA ping-pong Buffer A is not full When RBFIEx = 1 and the RBFx bit status is set, the individual ADCx DMA interrupt request is generated. Note: All of these bits will self-clear upon any read by software of this register. It is recommended therefore that the user logically OR the register contents to a user defined variable to be used for testing the DMA status in the user's code. The user software would therefore need to clear the corresponding variable bit after the buffer full status was processed. **Note:** The individual Class 1 High-Speed ADC5-ADC0 modules have an independent DMA bus initiator and are completely separate from the assignable general purpose DMA channels. #### REGISTER 25-29: ADCCNTB: ADC CHANNEL SAMPLE COUNT BASE ADDRESS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|--------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 31:24 | R/W-0 | | | | 31.24 | | | | ADCCNT | B<31:24> | | | | | | | | 23:16 | R/W-0 | | | | 23.10 | ADCCNTB<23:16> | | | | | | | | | | | | 15:8 | R/W-0 | | | | 15.6 | | ADCCNTB<15:8> | | | | | | | | | | | 7:0 | R/W-0 | | | | 7.0 | | | | ADCCN <sup>-</sup> | TB<7:0> | | | | | | | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 ADCCNTB<31:0>: ADC Channel Count Base Address bits SRAM address for the DMA interface at which to save the first class channel buffer A sample count values into the System RAM. If First Class Channel 'x' (where 'x' = 0-5), is ready with a new available sample data, and the DMA interface is currently saving data for Channel 'x' to RAM Buffer 'z' (where 'z' == 0 means Buffer A and 'z' == 1 means Buffer B, with 'z' depending on 'x'), the DMA interface will increment (+1) the 1 byte count value stored at System RAM address (ADCCNTB + 2 \* x + z). ADCCNTB works in conjunction with ADCDMAB. The DMA interface will use ADCCNTB to save the buffer sample counts only if the DMACEN bit in the ADCDSTAT register is set to '1'. #### REGISTER 25-30: ADCDMAB: ADC CHANNEL SAMPLE COUNT BASE ADDRESS REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | R/W-0 | | 31.24 | | ADCDMAB<31:24> | | | | | | | | | 23:16 | R/W-0 | | 23.10 | ADCDMAB<23:16> | | | | | | | | | | 15:8 | R/W-0 | | 15.6 | | ADCDMAB<15:8> | | | | | | | | | 7:0 | R/W-0 | | 7.0 | | | | ADCDM. | AB<7:0> | | | | | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 ADCDMAB<31:0>: DMA Interface Base Address bits Address at which to save first class channels data into the System RAM. If First Class Channel 'x' (where 'x' = 0-5), is ready with a new available sample data, and the DMA interface is currently saving data for Channel 'x' to RAM Buffer 'z' (where 'z' == 0 means Buffer A and 'z' == 1 means Buffer B, 'z' depending on 'x'), and the current DMA x-counter value is 'y' (with 'y' depending on 'x'), the DMA interface will store the 2-byte output data value at System RAM address (ADCDMAB + (2 \* x + z) \* 2(DMABL+1) + 2 \* y. Also, if the DMACEN bit in the ADCDSTAT register is set to '1', the DMA interface will store without delay the value 'y' itself at the System RAM address (ADCCNTB + 2 \* x + z). #### REGISTER 25-31: ADCDATAx: ADC OUTPUT DATA REGISTER ('x' = 0-27, 33-41, and 45-53) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 31:24 | R-0 | | | 31.24 | DATA<31:24> | | | | | | | | | | | 22,46 | R-0 | | | 23:16 | DATA<23:16> | | | | | | | | | | | 15:8 | R-0 | | | 13.0 | DATA<15:8> | | | | | | | | | | | 7:0 | R-0 | | | 7.0 | | | | DATA | <7:0> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 DATA<31:0>: ADC Converted Data Output bits. - Note 1: The registers, ADCDATA23-20, ADCDATA41-33, and ADCDATA45-47, are not available on 64-pin devices - 2: The registers, ADCDATA32-28 and ADCDATA44-42, are not available on 64-pin and 100-pin devices. - **3:** When an alternate input is used as the input source for a dedicated ADC module, the data output is still read from the Primary input Data Output Register. - **4:** Reading the ADCDATAx register value after changing the FRACT bit converts the data into the format specified by FRACT bit. #### REGISTER 25-32: ADCTRGSNS: ADC TRIGGER LEVEL/EDGE SENSITIVITY REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|----------------------|----------------------|----------------------|----------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31.24 | _ | _ | _ | _ | LVL27 | LVL26 | LVL25 | LVL24 | | 23:16 | R/W-0 | 23.10 | LVL23 <sup>(1)</sup> | LVL22 <sup>(1)</sup> | LVL21 <sup>(1)</sup> | LVL20 <sup>(1)</sup> | LVL19 | LVL18 | LVL17 | LVL16 | | 15:8 | R/W-0 | 15.0 | LVL15 | LVL14 | LVL13 | LVL12 | LVL11 | LVL10 | LVL9 | LVL8 | | 7:0 | R/W-0 | 7.0 | LVL7 | LVL6 | LVL5 | LVL4 | LVL3 | LVL2 | LVL1 | LVL0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-0 LVL27:LVL0: Trigger Level and Edge Sensitivity bits - 1 = Analog input is sensitive to the high level of its trigger (level sensitivity implies retriggering as long as the trigger signal remains high) - 0 = Analog input is sensitive to the positive edge of its trigger (this is the value after a reset) - **Note 1:** This register specifies the trigger level for analog inputs 0 to 27. - 2: The higher analog input ID belongs to Class 3, and therefore, is only scan triggered. All Class 3 analog inputs use the Scan Trigger, for which the level/edge is defined by the STRGLVL bit (ADCCON1<3>). ### REGISTER 25-33: ADCxTIME: DEDICATED HIGH-SPEED ADCx TIMING REGISTER ('x' = 0 THROUGH 5) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--| | 31:24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 R/W-0 | | R/W-1 | R/W-1 | | | | | | 31.24 | _ | _ | _ | A | ADCEIS<2:0> | > | SELRE | S<1:0> | | | | | | 23:16 | R/W-0 | | | | | 23.10 | BCHEN | ADCDIV<6:0> | | | | | | | | | | | | 15:8 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | | | | | 15.6 | | _ | _ | _ | _ | _ | SAMO | >9:8> | | | | | | 7:0 | R/W-0 | | | | | 7.0 | SAMC<7:0> | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 31-29 Unimplemented: Read as '0' bit 28-26 ADCEIS<2:0>: ADCx Early Interrupt Select bits 111 = The data ready interrupt is generated 8 ADC clocks prior to the end of conversion 110 = The data ready interrupt is generated 7 ADC clocks prior to the end of conversion • 001 = The data ready interrupt is generated 2 ADC clocks prior to the end of conversion 000 = The data ready interrupt is generated 1 ADC clock prior to the end of conversion **Note:** All options are available when the selected resolution, specified by the SELRES<1:0> bits (ADCxTIME<25:24>), is 12-bit or 10-bit. For a selected resolution of 8-bit, options from '000' to '101' are valid. For a selected resolution of 6-bit, options from '000' to '011' are valid. bit 25-24 SELRES<1:0>: ADCx Resolution Select bits 11 = 12 bits 10 = 10 bits 01 = 8 bits 00 = 6 bits bit 23 BCHEN: Buffer Channel Enable bit 1 = ADC data saved in DMA system ram buffer when DMAEN (ADCDSTAT<31>) = 1 0 = ADC data must be read by CPU from appropriate ADC result register bit 22-16 ADCDIV<6:0>: ADCx Clock Divisor bits These bits divide the ADC control clock with period TQ to generate the clock for ADCx (TADx). 1111111 = **254** \* TQ = TAD*x* • 0000011 = 6 \* TQ = TADx 0000010 = 4 \* TQ = TADX 0000001 = 2 \* TQ = TADx 0000000 = Reserved bit 15-10 Unimplemented: Read as '0' # REGISTER 25-33: ADCxTIME: DEDICATED HIGH-SPEED ADCx TIMING REGISTER (CONTINUED) ('x' = 0 THROUGH 5) bit 9-0 **SAMC<9:0>:** ADCx Sample Time bits Where TADx = period of the ADC conversion clock for the dedicated ADC controlled by the ADCDIV<6:0> bits. 1111111111 = **1025** TADX : 0000000001 = 3 TADX 0000000000 = 2 TADX Note: The SAMC sample time is always enforced regardless even if the conversion trigger occurs before SAMC expiration. The conversion trigger event is persistent and will be acknowledged and start the conversion if true, immediately after the SAMC period. ADC0-ADC5 will remain indefinitely in the sample state even after the expiration of SAMC until the trigger event, which will end sampling and start conversion, except when either of the following are true: -The ADC filter is enabled and the DFMODE bit in the ADCFLTRx register = 0 -The TRGSRC3 bit in the ADCTRG1 register = Global level software trigger Note: If **ADCFLTRx<AFEN> = 1** then ADCxTIME<SAMC> min must be $\geq$ to 0x004 or equivalent to $\geq$ 6 TADx. This will correspondingly reduce the max sampling rate possible. #### REGISTER 25-34: ADCEIEN1: ADC EARLY INTERRUPT ENABLE REGISTER 1 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-----------------------|-----------------------|-----------------------|-----------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 U-0 | | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31.24 | _ | _ | _ | _ | EIEN27 | EIEN26 | EIEN25 | EIEN24 | | 00.46 | R/W-0 | 23:16 | EIEN23 <sup>(1)</sup> | EIEN22 <sup>(1)</sup> | EIEN21 <sup>(1)</sup> | EIEN20 <sup>(1)</sup> | EIEN19 | EIEN18 | EIEN17 | EIEN16 | | 15:8 | R/W-0 | 15.6 | EIEN15 | EIEN14 | EIEN13 | EIEN12 | EIEN11 | EIEN10 | EIEN9 | EIEN8 | | 7.0 | R/W-0 | 7:0 | EIEN7 | EIEN6 | EIEN5 | EIEN4 | EIEN3 | EIEN2 | EIEN1 | EIEN0 | Legend:HS = Hardware SetC = Clearable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-0 EIEN27:EIEN0: Early Interrupt Enable for Analog Input bits - 1 = Early Interrupts are enabled for the selected analog input. The interrupt is generated after the early interrupt event occurs (indicated by the EIRDYx bit ('x' = 31-0) of the ADCEISTAT1 register) - 0 = Interrupts are disabled #### REGISTER 25-35: ADCEIEN2: ADC EARLY INTERRUPT ENABLE REGISTER 2 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | - | _ | _ | _ | | 23:16 | U-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 23.10 | _ | _ | EIEN53 | _ | - | EIEN50 | EIEN49 | EIEN48 | | 15:8 | R/W-0 R/W-0 | | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 15.6 | EIEN47 <sup>(1)</sup> | EIEN46 <sup>(1)</sup> | EIEN45 <sup>(1)</sup> | _ | _ | _ | EIEN41 <sup>(1)</sup> | EIEN40 <sup>(1)</sup> | | 7:0 | R/W-0 U-0 | | 7.0 | EIEN39 <sup>(1)</sup> | EIEN38 <sup>(1)</sup> | EIEN37 <sup>12)</sup> | EIEN36 <sup>(1)</sup> | EIEN35 <sup>(1)</sup> | EIEN34 <sup>(1)</sup> | EIEN33 <sup>(1)</sup> | _ | **Legend:** HS = Hardware Set C = Clearable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' #### bit 31-22 Unimplemented: Read as '0' #### bit 21 **EIEN53**: 1 = Early Interrupts are enabled for the selected analog input. The interrupt is generated after the early interrupt event occurs (indicated by the EIRDYx bit ('x' = 44-32) of the ADCEISTAT2 register) 0 = Interrupts are disabled bit 20-19 Unimplemented: Read as '0' bit 18-13 EIEN50:EIEN45: Early Interrupt Enable for Analog Input bits - 1 = Early Interrupts are enabled for the selected analog input. The interrupt is generated after the early interrupt event occurs (indicated by the EIRDYx bit ('x' = 44-32) of the ADCEISTAT2 register) - 0 = Interrupts are disabled #### bit 12-10 Unimplemented: Read as '0' bit 9-1 **EIEN41:EIEN33:** Early Interrupt Enable for Analog Input bits - 1 = Early Interrupts are enabled for the selected analog input. The interrupt is generated after the early interrupt event occurs (indicated by the EIRDYx bit ('x' = 44-32) of the ADCEISTAT2 register) - 0 = Interrupts are disabled bit 0 Unimplemented: Read as '0' #### REGISTER 25-36: ADCEISTAT1: ADC EARLY INTERRUPT STATUS REGISTER 1 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|------------------------|------------------------|------------------------|------------------------|-------------------|-------------------|------------------|------------------|--| | 24.24 | U-0 | U-0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | | 31:24 | - | - | _ | _ | EIRDY27 | EIRDY26 | EIRDY25 | EIRDY24 | | | 00.46 | R-0, HS, HC | | 23:16 | EIRDY23 <sup>(1)</sup> | EIRDY22 <sup>(1)</sup> | EIRDY21 <sup>(1)</sup> | EIRDY20 <sup>(1)</sup> | EIRDY19 | EIRDY18 | EIRDY17 | EIRDY16 | | | 15:8 | R-0, HS, HC | | 15.6 | EIRDY15 | EIRDY14 | EIRDY13 | EIRDY12 | EIRDY11 | EIRDY10 | EIRDY9 | EIRDY8 | | | 7.0 | R-0, HS, HC | | 7:0 | EIRDY7 | EIRDY6 | EIRDY5 | EIRDY4 | EIRDY3 | EIRDY2 | EIRDY1 | EIRDY0 | | Legend:HS = Hardware SetHC = Cleared by hardwareR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-0 EIRDY27:EIRDY0: Early Interrupt for Corresponding Analog Input Ready bits - 1 = This bit is set when the early interrupt event occurs for the specified analog input. An interrupt will be generated if early interrupts are enabled in the ADCEIEN1 register. For the Class 1 analog inputs, this bit will set as per the configuration of the ADCEIS<2:0> bits in the ADCXTIME register. For the shared ADC module, this bit will be set as per the configuration of the ADCEIS<2:0> bits in the ADCCON2 register. - 0 = Interrupts are disabled #### REGISTER 25-37: ADCEISTAT2: ADC EARLY INTERRUPT STATUS REGISTER 2 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|-------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------| | 31:24 | U-0 | U-0 U-0 | | U-0 | U-0 | U-0 | U-0 | U-0 | | 31.24 | | _ | - | _ | _ | - | - | | | 23:16 | U-0 | U-0 | R-0, HS, HC | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC | | 23.10 | | _ | EIRDY53 | _ | _ | EIRDY50 | EIRDY49 | EIRDY48 | | 15:8 | R-0, HS, HC | R-0, HS, HC R-0, HS, HC | | U-0 | U-0 | U-0 | R-0, HS, HC | R-0, HS, HC | | 15.6 | EIRDY47 <sup>(1)</sup> | EIRDY46 <sup>(1)</sup> | EIRDY45 <sup>(1)</sup> | _ | _ | _ | EIRDY41 <sup>(1)</sup> | EIRDY40 <sup>(1)</sup> | | 7.0 | R-0, HS, HC U-0 | | 7:0 | EIRDY39 <sup>(1)</sup> | EIRDY38 <sup>(1)</sup> | EIRDY37 <sup>(1)</sup> | EIRDY36 <sup>(1)</sup> | EIRDY35 <sup>(1)</sup> | EIRDY34 <sup>(1)</sup> | EIRDY33 <sup>(1)</sup> | _ | | Legend: | HS = Hardware Set | = Hardware Set HC = Cleared by hardware | | | | | | |-------------------|-------------------|-----------------------------------------|--------------------|--|--|--|--| | R = Readable bit | W = Writable bit | U = Unimplemented bit, r | read as '0' | | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | | | | #### bit 31-22 Unimplemented: Read as '0' #### bit 21 **EIEN53**: - 1 = This bit is set when the early interrupt event occurs for the specified analog input. An interrupt will be generated if early interrupts are enabled in the ADCEIEN2 register. For the Class 1 analog inputs, this bit will set as per the configuration of the ADCEIS<2:0> bits in the ADCxTIME register. For the shared ADC module, this bit will be set as per the configuration of the ADCEIS<2:0> bits in the ADCCON2 register. - 0 = Interrupts are disabled bit 20-19 Unimplemented: Read as '0' bit 18-13 EIRDY50:EIRDY45: Early Interrupt for Corresponding Analog Input Ready bits - 1 = This bit is set when the early interrupt event occurs for the specified analog input. An interrupt will be generated if early interrupts are enabled in the ADCEIEN2 register. For the Class 1 analog inputs, this bit will set as per the configuration of the ADCEIS<2:0> bits in the ADCXTIME register. For the shared ADC module, this bit will be set as per the configuration of the ADCEIS<2:0> bits in the ADCCON2 register. - 0 = Interrupts are disabled #### bit 12-10 Unimplemented: Read as '0' #### bit 9-1 **EIRDY41:EIRDY33:** Early Interrupt for Corresponding Analog Input Ready bits - 1 = This bit is set when the early interrupt event occurs for the specified analog input. An interrupt will be generated if early interrupts are enabled in the ADCEIEN2 register. For the Class 1 analog inputs, this bit will set as per the configuration of the ADCEIS<2:0> bits in the ADCXTIME register. For the shared ADC module, this bit will be set as per the configuration of the ADCEIS<2:0> bits in the ADCCON2 register. - 0 = Interrupts are disabled bit 0 Unimplemented: Read as '0' #### REGISTER 25-38: ADCANCON: ADC ANALOG WARM-UP CONTROL REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 | U-0 | U-0 | R/W-0 R/W-0 | | R/W-0 | R/W-0 | | 31.24 | | _ | _ | _ | | | | | | 22:16 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | WKIEN7 | _ | WKIEN5 | WKIEN4 | WKIEN3 | WKIEN2 | WKIEN1 | WKIEN0 | | 15.0 | R-0, HS, HC | U-0 | R-0, HS, HC | R-0, HS, HC | R-0, HS, HC R-0, HS, HC | | R-0, HS, HC | R-0, HS, HC | | 15:8 | WKRDY7 | _ | WKRDY5 | WKRDY4 | WKRDY3 | WKRDY2 | WKRDY1 | WKRDY0 | | 7:0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7.0 | ANEN7 | _ | ANEN5 | ANEN4 | ANEN3 | ANEN2 | ANEN1 | ANEN0 | Legend: HS = Hardware Set HC = Cleared by Software R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-24 WKUPCLKCNT<3:0>: Wake-up Clock Count bits These bits represent the number of ADC clocks required to warm-up the ADC module before it can perform conversion. Although the clocks are specific to each ADC, the WKUPCLKCNT bit is common to all ADC modules. $1111 = 2^{15} = 32,768$ clocks • $0110 = 2^6 = 64 \text{ clocks}$ $0101 = 2^5 = 32$ clocks $0100 = 2^4 = 16$ clocks $0011 = 2^4 = 16$ clocks $0010 = 2^4 = 16 \text{ clocks}$ $0001 = 2^4 = 16$ clocks $0000 = 2^4 = 16$ clocks **Note:** Minimum required ADCx warm-up time, (i.e., WKUPCLKCNT), is the lesser of 500 ADC clocks, (i.e., TAD), or 20 μs. - bit 23 WKIEN7: Shared ADC (ADC7) Wake-up Interrupt Enable bit - 1 = Enable interrupt and generate interrupt when the WKRDY7 status bit is set - 0 = Disable interrupt - bit 22 Unimplemented: Read as '0' - bit 21-16 WKIEN5:WKIEN0: ADC5-ADC0 Wake-up Interrupt Enable bit - 1 = Enable interrupt and generate interrupt when the WKRDYx status bit is set - 0 = Disable interrupt - bit 15 WKRDY7: Shared ADC (ADC7) Wake-up Status bit - 1 = ADC7 Analog and Bias circuitry ready after the wake-up count number 2<sup>WKUPEXP</sup> clocks after setting ANEN7 to '1' - 0 = ADC7 Analog and Bias circuitry is not ready **Note:** This bit is cleared by hardware when the ANEN7 bit is cleared - bit 14 Unimplemented: Read as '0' - bit 13-8 WKRDY5:WKRDY0: ADC5-ADC0 Wake-up Status bit - 1 = ADCx Analog and Bias circuitry ready after the wake-up count number 2<sup>WKUPEXP</sup> clocks after setting ANEN*x* to '1' - 0 = ADCx Analog and Bias circuitry is not ready **Note:** These bits are cleared by hardware when the ANENx bit is cleared #### REGISTER 25-38: ADCANCON: ADC ANALOG WARM-UP CONTROL REGISTER (CONTINUED) bit 7 ANEN7: Shared ADC (ADC7) Analog and Bias Circuitry Enable bit - 1 = Analog and bias circuitry enabled. Once the analog and bias circuit is enabled, the ADC module needs a warm-up time, as defined by the WKUPCLKCNT<3:0> bits. - 0 = Analog and bias circuitry disabled - bit 6 **Unimplemented:** Read as '0' - bit 5-0 ANEN5: ANEN0: ADC5-ADC0 Analog and Bias Circuitry Enable bits - 1 = Analog and bias circuitry enabled. Once the analog and bias circuit is enabled, the ADC module needs a warm-up time, as defined by the WKUPCLKCNT<3:0> bits. - 0 = Analog and bias circuitry disabled #### REGISTER 25-39: ADCxCFG: ADCx CONFIGURATION REGISTER ('x' = 0 THROUGH 5 and 7) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit Bit 29/21/13/5 28/20/12/4 2 | | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | |-----------|-------------------|-------------------|---------------------------------|-------|-------------------|-------------------|------------------|------------------|--|--|--|--|--| | 31:24 | R/W-0 R/W-0 | | R/W-0 R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | 31.24 | ADCCFG<31:24> | | | | | | | | | | | | | | 23:16 | R/W-0 | | | | | | 23.10 | ADCCFG<23:16> | | | | | | | | | | | | | | 15:8 | R/W-0 | | | | | | 13.0 | ADCCFG<15:8> | | | | | | | | | | | | | | 7:0 | R/W-0 | | | | | | 7.0 | ADCCFG<7:0> | | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 ADCCFG<31:0>: ADC Module Configuration Data bits **Note:** These bits can only change when the applicable ANENx bit in the ADCANCON register is cleared. These are calibration values determined at product test time and are provided to the user to copy and write into these registers. #### REGISTER 25-40: ADCSYSCFG0: ADC SYSTEM CONFIGURATION REGISTER 0 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|---------------------|---------------------|---------------------|---------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | U-0 U-0 | | U-0 | HC, HS, R-0 | HC, HS, R-0 | HC, HS, R-0 | HC, HS, R-0 | | 31.24 | _ | - | _ | _ | AN27 | AN26 | AN25 | AN24 | | 23:16 | HC, HS, R-0 | 23.10 | AN23 <sup>(1)</sup> | AN22 <sup>(1)</sup> | AN21 <sup>(1)</sup> | AN20 <sup>(1)</sup> | AN19 | AN18 | AN17 | AN16 | | 15:8 | HC, HS, R-0 | 13.0 | AN15 | AN14 | AN13 | AN12 | AN11 | AN10 | AN9 | AN8 | | 7:0 | HC, HS, R-0 | 7.0 | AN7 | AN6 | AN5 | AN4 | AN3 | AN2 | AN1 | AN0 | Legend:HS = Hardware SetHC = Cleared by SoftwareR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-28 **Unimplemented:** Read as '0' bit 27-0 AN27:AN0>: ADC Analog Input bits These bits reflect the system configuration and are updated during boot-up time. By reading these readonly bits, the user application can determine whether or not an analog input in the device is available. AN<31:0>: Reflects the presence or absence of the respective analog input (AN31-AN0). #### REGISTER 25-41: ADCSYSCFG1: ADC SYSTEM CONFIGURATION REGISTER 1 | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit Bit 28/20/12/4 27/19/11/3 2 | | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|---------------------|---------------------|---------------------|---------------------------------|---------------------|---------------------|---------------------|---------------------| | 31:24 | U-0 | 31.24 | | | - | _ | _ | | - | _ | | 23:16 | U-0 | U-0 | HC, HS, R-0 | U-0 | U-1 | HC, HS, R-0 | HC, HS, R-0 | HC, HS, R-0 | | 23.10 | _ | _ | AN53 <sup>(2)</sup> | _ | _ | AN50 <sup>(2)</sup> | AN49 | AN48 | | 15:8 | HC, HS, R-0 | HC, HS, R-0 | HC, HS, R-0 | U-0 | U-0 | U-0 | HC, HS, R-0 | HC, HS, R-0 | | 15.6 | AN47 <sup>(1)</sup> | AN46 <sup>(1)</sup> | AN45 <sup>(1)</sup> | _ | _ | _ | AN41 <sup>(1)</sup> | AN40 <sup>(1)</sup> | | 7:0 | HC, HS, R-0 U-0 | | 7.0 | AN39 <sup>(1)</sup> | AN38 <sup>(1)</sup> | AN37 <sup>(1)</sup> | AN36 <sup>(1)</sup> | AN35 <sup>(1)</sup> | AN34 <sup>(1)</sup> | AN33 <sup>(1)</sup> | _ | Legend:HS = Hardware SetHC = Cleared by SoftwareR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-22 **Unimplemented:** Read as '0' bit 21 **AN53:** ADC Analog Input bits These bits reflect the system configuration and are updated during boot-up time. By reading these readonly bits, the user application can determine whether or not an analog input in the device is available. AN<63:32>: Reflects the presence or absence of the respective analog input (AN63-AN32). bit 20-19 Reserved: Read as '1' bit 18-13 AN50:AN45: ADC Analog Input bits These bits reflect the system configuration and are updated during boot-up time. By reading these readonly bits, the user application can determine whether or not an analog input in the device is available. AN<63:32>: Reflects the presence or absence of the respective analog input (AN63-AN32). bit 12-10 Unimplemented: Read as '0' bit 9-1 AN41:AN33: ADC Analog Input bits These bits reflect the system configuration and are updated during boot-up time. By reading these readonly bits, the user application can determine whether or not an analog input in the device is available. AN<63:32>: Reflects the presence or absence of the respective analog input (AN63-AN32). bit 0 **Unimplemented:** Read as '0' Note 1: This bit is not available on 64-pin devices. 2: Internal Analog inputs: AN50 = IVREF (1.2V), AN53 = CTMU TEMP. | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 26.0 CONTROLLER AREA NETWORK WITH FLEXIBLE DATA-RATE (CAN FD) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 56, "Controller Area Network with Flexible Data-rate (CAN FD)" (DS number pending), which is available from the Documentation > Reference Manual section of the Microchip PIC32 site web (www.microchip.com/pic32). The Controller Area Network with Flexible Data-rate (CAN FD) module supports the following key features: - · Standards Compliance: - Full CAN 2.0B compliance - Programmable bit rate - ISO11898-1:2015 plus CAN FD 1.0 compliant, supports up to 64 data bytes payload/message - Arbitration Bit Rate up to one Mbps - FD Bit Rate up to eight Mbps - · Message Reception and Transmission: - 32 message FIFOs - Each FIFO can have up to 32 messages for a total of 512 messages - FIFO can be a transmit message FIFO or a receive message FIFO - User-defined priority levels for message FIFOs used for transmission - 32 acceptance filters for message filtering - 32 acceptance filter mask registers for message filtering - Automatic response to remote transmit request - DeviceNet™ addressing support - · Additional Features: - Loopback, Listen All Messages, and Listen Only modes for self-test, system diagnostics and bus monitoring - Low-power operating modes - CAN FD module is a dedicated DMA bus initiator on the PIC32MK system bus so use of system general purpose DMA is not required - Dedicated time-stamp timer - Data-only Message Reception mode - Selective wake-up, and transceiver standby control - Low-power operating mode #### CAUTION The CAN FD protocol was defined to allow CAN 2.0 messages and CAN FD messages to co-exist on the same bus. This does not imply that non-CAN FD controllers can be mixed with CAN FD controllers on the same bus. Non-CAN FD controllers will generate error frames while receiving a CAN FD message Figure 26-1 illustrates the general structure of the CAN FD module. Note: Recommended CAN-FD clock frequency is 20 MHz/40 MHz/80 MHz. Implementing the following steps to set Module Clock frequency of 40 MHz while maintaining CPU clock frequency of 120 MHz: - Select module clock source as REF-CLK4 by configuring the CLKSEL0 bit (CFDxCON<7>) = 1. - Select SYSCLK as the input clock fro REFCLK4 by configuring the ROSEL bits (REFO4CON<3:0>) = 0. - Set REF4CLK prescaler to 3 by configuring the RODIV bits (REF04CON<30:16>) = 1 and the ROTRIM bits (REF04TRIM<31:23> = 256. ### FIGURE 26-1: PIC32MK CAN FD MODULE BLOCK DIAGRAM #### 26.1 Control Registers #### TABLE 26-1: CAN FD PERIPHERAL REGISTER SUMMARY | SS | 96 | | | | | | | | | В | its | | | | | | | | | |-----------------------------|----------------|---------------|---------------------------------------|-------------------|---------|----------|-------------|-------------|----------|------------------------------------|---------------------|-------|---------|----------|------------|-----------------------------------------|----------|----------|------------| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | CFD1CON | 31:16 | | | | | | | | OPMOD<2:0 | | TXQEN | STEF | SERR2LOM | ESIGM | RTXAT | 0498 | | | | 0000 | OI B TOOK | 15:0 | ON - SIDL BRSDIS BUSY WFT<1:0> WAKFIL | | | | | | WAKFIL | CLKSEL0 PXEDIS ISOCRCEN DNCNT<4:0> | | | | | | | 0760 | | | | 0010 | CFD1NBTCFG | 31:16 | | BRP<7:0> | | | | | | | | | | TSE | G1<7:0> | | | | 003E | | | | 15:0 | - TSEG2<6:0> | | | | | | | _ | | | | SJW<6:0> | | | | OFOF | | | 0020 | CFD1DBTCFG | 31:16 | BRP<7:0> TSEG2<3:0> | | | | | | | | _ | _ | | | 1 | TSEG1<4:0> | 2.0- | | 000E | | | | 15:0<br>31:16 | | | | | | | | CID11EN | | _ | _ | _ | | SJW< | | DD<1:0> | 0303 | | 0030 | CFD1TDC | 15:0 | EDGFLTEN SID11E | | | | | | SIDITEN | | | | | TDC\ | /<5:0> | TDCMC | JU<1:0> | 1000 | | | | | 31:16 | | | | | 100000.02 | | | TRC | 31:16> | _ | | | IDCV | /<5.0> | | | 0000 | | 0040 | CFD1TBC | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | TSRES | TSEOF | TBCEN | 0000 | | 0050 | CFD1TSCON | 15:0 | _ | _ | _ | _ | _ | _ | | | | | TBCP | RE<9:0> | | | | | 0000 | | 0000 | 0504)/50 | 31:16 | _ | | | F | RXCODE<6:0> | > | | | _ | | | | TXCODE<6:0 | )> | | | 4040 | | 0060 | CFD1VEC | 15:0 | _ | _ | _ | | F | FILHIT<4:0> | | | _ | | | | ICODE<6:0> | > | | | 0040 | | 0070 | CFD1INT | 31:16 | IVMIE | WAKIE | CERRIE | SERRIE | RXOVIE | TXATIE | _ | _ | _ | _ | _ | TEFIE | MODIE | TBCIE | RXIE | TXIE | 0000 | | 0070 | CFDTINT | 15:0 | IVMIF | WAKIF | CERRIF | SERRIF | RXOVIF | TXATIF | _ | _ | _ | _ | _ | TEFIF | MODIF | TBCIF | RXIF | TXIF | 0000 | | 0080 | CFD1RXIF | 31:16 | | | | | | | | | :31:16> | | | | | | | | 0000 | | 0000 | OI DITO(II | 15:0 | | | | | | | | | | | 0000 | | | | | | | | 0090 | CFD1TXIF | 31:16 | | | | | | | | | 31:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | 00A0 | CFD1RXOVIF | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | RFOVIF<15: | | | | | | | | _ | 0000 | | 00B0 | CFD1TXATIF | 31:16<br>15:0 | | | | | | | | | <31:16><br>=<15:0> | | | | | | | | 0000 | | | | 31:16 | | | | | | | | | -<15:0><br>!<31:16> | | | | | | | | 0000 | | 00C0 | CFD1TXREQ | 15:0 | | | | | | | | | Q<15:0> | | | | | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | | _ | _ | TXBO | TXBP | RXBP | TXWARN | RXWARN | EWARN | 0020 | | 00D0 | CFD1TREC | 15:0 | | | | TERRO | NT<7:0> | | | | | | 171.50 | | CNT<7:0> | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | 0000 | | | | 31:16 | | | | | CNT<7:0> | | | | | | | | RCNT<7:0> | | | | 0000 | | 00E0 | CFD1BDIAG0 | 15:0 | | | | NTERRO | CNT<7:0> | | | | | | | NRERF | RCNT<7:0> | | | | 0000 | | 0050 | CFD1BDIAG1 | 31:16 | DLCMM | ESI | DCRCERR | DSTUFERR | DFORMERR | _ | DBIT1ERR | DBIT0ERR | _ | _ | NCRCERR | NSTUFERR | NFORMERR | NACKERR | NBIT1ERR | NBIT0ERF | 0000 | | UUFU | CFD IBDIAG I | 15:0 | EFMSGCNT<15:0> | | | | | | | | 0000 | | | | | | | | | | 0100 | CFD1TEFCON | 31:16 | _ | | _ | | | FSIZE<4:0> | | | _ | _ | _ | | _ | _ | _ | _ | 0000 | | 3100 | S. D. I.L. OON | 15:0 | _ | _ | _ | _ | _ | FRESET | _ | UINC | _ | _ | TEFTSEN | _ | TEFOVIE | TEFFIE | TEFHIE | TEFNEIE | 0400 | | 0110 | CFD1TEFSTA | 31:16 | _ | I | _ | _ | 1 | _ | _ | _ | 1 | _ | _ | I | _ | _ | _ | _ | 0000 | | 30 | 2. 3 2. 0 ./ ( | 15:0 | _ | _ | _ | _ | | _ | _ | | _ | _ | _ | _ | TEFOVIF | TEFFIF | TEFHIF | TEFNEIF | 0000 | | 0120 | CFD1TEFUA | 31:16 | | | | | | | | | <31:16> | | | | | | | | XXXX | | | | 15:0 | | | | | | | | | A<15:0> | | | | | | | | XXXX | | 0130 | CFD1FIFOBA | 31:16 | | | | | | | | | \<31:16> | | | | | | | | 0000 | | | | 15:0 | | FIFOBA<15:0> 0000 | | | | | | | | | | | | | | | | PIC32MK GPK/MCM with CAN FD Family **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal Note 1: The lower order byte of the 32-bit register resides at the low-order address. TABLE 26-1: CAN FD PERIPHERAL REGISTER SUMMARY (CONTINUED) | SS | e | | | Bits | | | | | | | | | | | | | | | | |-----------------------------------|--------------------------------|-------------------|--------------------|-------------|---------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------|---------|--------------------|----------------------|-----------|-----------|---------|-------------|-----------------|---------------|------------| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | CFD1TXQCON | 31:16 | | PLSIZE<2:0> | > | | | FSIZE<4:0> | | | _ | TXAT<1:0> TXPRI<4:0> | | | | | | | 0060 | | 0140 | OIDIIAGOON | 15:0 | | I | _ | _ | ı | FRESET | TXREQ | UINC | TXEN | _ | _ | TXATIE | _ | TXQEIE | _ | TXQNIE | 0480 | | 0150 | CFD1TXQSTA | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | | _ | | TXQCI<4:0> TXABT TXLARB TXERR TXATIF — TXQEIF TXQUA<31:16> — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — <td>_</td> <td>TXQNIF</td> <td>0000</td> | | | | | | | | | | _ | TXQNIF | 0000 | | 0160 CFD1TXQUA 31:16 TXQUA<31:16> | | | | | | | | | | | | | | | | xxxx | | | | | | CFD1FIFOCONn | 31:16 | | PLSIZE<2:0> | > | | | FSIZE<4:0> | | IAQUI | - | TXAT | ·<1:0> | | | TXPRI<4:0> | | | 0060 | | 0170 | ('n' = 1) | 15:0 | _ | _ | _ | _ | _ | FRESET | TXREQ | UINC | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | 0400 | | 0400 | CFD1FIFOSTAn | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0180 | ('n'= 1) | 15:0 | _ | _ | _ | | F | FIFOCI<4:0> | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | 0000 | | 0190 | CFD1FIFOUAn | 31:16 | :16 FIFOUA<31:16> | | | | | | | | | | | | | xxxx | | | | | 0100 | ('n' = 1) | 15:0 FIFOUA<15:0> | | | | | | | | | | | | XXXX | | | | | | | | CFD1FIFOCONn | 31:16 | | PLSIZE<2:0> | | | | FSIZE<4:0> | =:/=== | | _ | | <1:0> | | | TXPRI<4:0> | | | 0000 | | 0440 | ('n' = 2-31) | 15:0 | _ | _ | _ | _ | _ | FRESET | TXREQ | UINC | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | IFNRFNIE | 0000 | | | CFD1FIFOSTAn<br>('n' = 2 to 31 | 31:16<br>15:0 | | | _ | _ | | IFOCI<4:0> | _ | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TENIDENIE | 0000 | | 0.00 | CFD1FIFOUAn<br>('n' = 2 to 31) | 31:16 | _ | | | | ' | 11 001~4.0> | | FIFOLIA | | IXLAND | IALINI | IAAIII | IXXXVII | II LIXII II | II I IIXI I III | II INIXI INII | 0000 | | | | 15:0 | | | | | | | | | | | | | | | 0000 | | | | 0740 | 050451700110 | 31:16 | FLTEN3 | _ | _ | | | F3BP<4:0> | | | FLTEN2 | _ | _ | | | F2BP<4:0> | | | 0000 | | 0740 | CFD1FLTCON0 | 15:0 | FLTEN1 | _ | _ | | | F1BP<4:0> | | | FLTEN0 | _ | _ | F0BP<4:0> | | | | | 0000 | | 0750 | CFD1FLTCON1 | 31:16 | FLTEN7 | | _ | | | F7BP<4:0> | | | FLTEN6 | _ | _ | | | F6BP<4:0> | | | 0000 | | 0730 | CIDITEICON | 15:0 | FLTEN5 | _ | _ | | | F5BP<4:0> | | | FLTEN4 | _ | _ | | | F4BP<4:0> | | | 0000 | | 0760 | CFD1FLTCON2 | 31:16 | FLTEN11 | | _ | | | F11BP<4:0> | | | FLTEN10 | _ | _ | | | F10BP<4:0> | | | 0000 | | | CFD1FLTCON3 | 15:0 | FLTEN9 | _ | _ | | | F9BP<4:0> | | | FLTEN8 | _ | _ | | | F8BP<4:0> | | | 0000 | | 0770 | | 31:16<br>15:0 | FLTEN15<br>FLTEN13 | | | | | F15BP<4:0><br>F13BP<4:0> | | | FLTEN14<br>FLTEN12 | _ | _ | | | F14BP<4:0> | | | 0000 | | | | 31:16 | FLTEN13 | | _ | | | F13BP<4:0> | | | FLTEN12<br>FLTEN18 | _ | | | | F18BP<4:0> | | | 0000 | | 0780 | CFD1FLTCON4 | 15:0 | FLTEN17 | | - | | | F17BP<4:0> | | | FLTEN16 | _ | _ | | | F16BP<4:0> | | | 0000 | | | | 31:16 | FLTEN23 | _ | _ | | | F23BP<4:0> | | | FLTEN22 | _ | _ | | | F22BP<4:0> | | | 0000 | | 0790 | CFD1FLTCON5 | 15:0 | FLTEN21 | _ | _ | | | F21BP<4:0> | | | FLTEN20 | _ | _ | | | F20BP<4:0> | | | 0000 | | 0740 | CFD1FLTCON6 | 31:16 | FLTEN27 | _ | _ | | | F28BP<4:0> | | | FLTEN26 | _ | _ | | | F26BP<4:0> | | | 0000 | | UTAU | CFD IFLICONO | 15:0 | FLTEN25 | | _ | | | F25BP<4:0> | | | FLTEN24 | _ | _ | | | F30BP<4:0> | | | 0000 | | 07B0 | CFD1FLTCON7 | 31:16 | FLTEN31 | I | _ | | | F31BP<4:0> | | | FLTEN30 | _ | _ | | | F26BP<4:0> | | | 0000 | | 0.50 | | 15:0 | FLTEN29 | | | | | F29BP<4:0> | | | FLTEN28 | | _ | | | F28BP<4:0> | | | 0000 | | 07C0 | CFD1FLTOBJn | 31:16 | - | EXIDE | SID11 | | | 1 | | | | EID<17:5> | | | | | | | 0000 | | | (n = 0) | 15:0 | | MIDE | EID<4:0> | 1 | | L | | | | MEID>17:5 | SID<10:0> | • | | | | | 0000 | | 07D0 | CFD1MASKn<br>('n' = 0) | 31:16<br>15:0 | | MIDE | MSID11<br>MEID<4:0> | <u> </u> | | 1 | | | | MEID<17:5 | MSID<10:0 | > | | | | | 0000 | | | CFD1FLTOBJn | 31:16 | | EXIDE | SID11 | ·<br> | | <u> </u> | | | | EID<17:5> | | | | | | | 0000 | | 07F0- | ('n' = 1 to 31) | 15:0 | - | LAIDL | EID<4:0> | <u> </u> | | 1 | | | | LID - 17.32 | SID<10:0> | , | | | | | 0000 | | 0BB0 | CFD1MASKn | 31:16 | - | MIDE | MSID11 | | | 1 | | | | MEID<17:5 | | | | | | | 0000 | | | ('n' = 1 to 31) | 15:0 | | | MEID<4:0> | · | | | | | | | MSID<10:0 | > | | | | | 0000 | | Leger | ٠ | | | | | . (-! D | et values are | <del> </del> | | | | | | | | | | | | $\rm x$ = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. The lower order byte of the 32-bit register resides at the low-order address. | TABLE 26-1: CAN FD PERIPHERAL REGISTER SUMMARY (CONTINU | |---------------------------------------------------------| |---------------------------------------------------------| | S | Φ. | | | Bits | | | | | | | | | | | | | | | | | | |-----------------------------|---------------|---------------|------------------------------------------------------------------------------------------------------|-------------|---------|----------|-------------|-------------|-------------|------------|---------------|------------|--------------------|----------|------------|--------------|----------|-----------|--------------|--|--| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | | 1000 | CFD2CON | 31:16 | | TXBW | 'S<3:0> | | ABAT | | REQOP<2:0 | | | OPMOD<2:0 | | TXQEN | STEF | SERR2LOM | ESIGM | RTXAT | 0498 | | | | .000 | 0. 5200.1 | 15:0 | ON | _ | SIDL | BRSDIS | BUSY | WFT | <1:0> | WAKFIL | CLKSEL0 | PXEDIS | ISOCRCEN | | | DNCNT<4:0> | | | 0760<br>003E | | | | 1010 | CFD2NBTCFG | 31:16 | | | | | | | | | | TSEG1<7:0> | | | | | | | | | | | | | 15:0 | 5:0 — TSEG2<6:0> — SJW<6:0> 1:16 BRP<7:0> — — — TSEG1<4:0> | | | | | | | | | | | | | 0F0F<br>000E | | | | | | | 1020 | CFD2DBTCFG | 15:0 | _ | | | DRP | <7:0> | TSEG2 | 0<3.0> | | _ | _ | _ | _ | 1 | SJW< | 8.0> | | 0303 | | | | | | 31:16 | | | _ | | _ | 1 - 1 - | EDGFLTEN | SID11EN | _ | _ | _ | _ | _ | | | DD<1:0> | 0002 | | | | 1030 | CFD2TDC | 15:0 | | | | | TDCO<6:0> | | LDOI LI LIV | OIDTILIV | | | _ | | TDC\ | /<5:0> | TDOWN | 70.00 | 1000 | | | | | | 31:16 | | | | | 1500 0.0 | | | TBC< | :31:16> | | l | | .50. | 0.0 | | | 0000 | | | | 1040 | CFD2TBC | 15:0 | | | | | | | | TBC• | <15:0> | | | | | | | | | | | | 1050 | CFD2TSCON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | TSRES | TSEOF | TBCEN | 0000 | | | | 1050 | CFD21SCON | 15:0 | _ | _ | _ | _ | _ | _ | | | | | TBCF | RE<9:0> | | • | | | 0000 | | | | 1060 | CFD2VEC | 31:16 | _ | | | F | RXCODE<6:0> | | | | _ | | | | TXCODE<6:0 | | | | 4040 | | | | 1000 | JI DZVLO | 15:0 | _ | I | _ | | | FILHIT<4:0> | | | _ | | | | ICODE<6:0> | | | | 0040 | | | | 1070 | CFD2INT | 31:16 | IVMIE | WAKIE | CERRIE | SERRIE | RXOVIE | TXATIE | _ | _ | _ | _ | _ | TEFIE | MODIE | TBCIE | RXIE | TXIE | 0000 | | | | | | 15:0 | IVMIF | WAKIF | CERRIF | SERRIF | RXOVIF | TXATIF | _ | | _ | _ | _ | TEFIF | MODIF | TBCIF | RXIF | TXIF | 0000 | | | | 1080 | CFD2RXIF | 31:16 | RFIF<31:16> | | | | | | | | | | | | | 0000 | | | | | | | | CFD2TXIF | 15:0 | | | | | | | | RFIF<15:1> | | | | | | | | _ | 0000 | | | | 1090 | | 31:16<br>15:0 | | | | | | | | | | | | | | | 0000 | | | | | | | | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | | | 10A0 | CFD2RXOVIF | 15:0 | | | | | | | | | | | | | | 0000 | | | | | | | | | 31:16 | TFATIF<31:16> | | | | | | | | | | | | | | 0000 | | | | | | 10B0 | CFD2TXATIF | 15:0 | | | | | | | | | F<15:0> | | | | | | | | 0000 | | | | 1000 | CFD2TXREQ | 31:16 | | | | | | | | TXREC | (<31:16> | | | | | | | | 0000 | | | | 1000 | CFD21XREQ | 15:0 | | | | | | | | TXRE | Q<15:0> | | | | | | | | 0000 | | | | 1000 | CFD2TREC | 31:16 | _ | | _ | _ | _ | _ | _ | _ | _ | _ | TXBO | TXBP | RXBP | TXWARN | RXWARN | EWARN | 0020 | | | | 1000 | OI DZTREO | 15:0 | | | | | | | | | RERRCNT<7:0> | | | | | | | | | | | | 10E0 | CFD2BDIAG0 | 31:16 | | | | | CNT<7:0> | | | | DRERRCNT<7:0> | | | | | | | | | | | | | | 15:0 | DI 01414 | F01 | DODOEDD | | CNT<7:0> | | DOITAGED | DDITAEDD | | | Lucacean | | CNT<7:0> | NA OVEDD | NOT-LEDD | LUDITATED | 0000 | | | | 10F0 | CFD2BDIAG1 | 31:16<br>15:0 | DLCMM | ESI | DCRCERR | DSTUFERR | DFORMERR | _ | DBIT1ERR | DBIT0ERR | <br>:NT<15:0> | _ | NCRCERR | NSTUFERR | NFORMERR | NACKERR | NBIT1ERR | NBIT0ERR | | | | | | | 31:16 | _ | | | | | FSIZE<4:0> | | EFINISGO | N1<15:0> | _ | | | _ | _ | | | 0000 | | | | 1100 | CFD2TEFCON | 15:0 | | | | _ | _ | FRESET | _ | UINC | | | TEFTSEN | _ | TEFOVIE | TEFFIE | TEFHIE | TEFNEIE | 0400 | | | | | | 31:16 | | | | | | - INLOCI | _ | — | | _ | - ILI 13LIN | | TLI OVIL | - | - | TEI NEIL | 0000 | | | | 1110 | CFD2TEFSTA | 15:0 | | | | | | | | | _ | | _ | | TEFOVIF | TEFFIF | TEFHIF | TEFNEIF | 0000 | | | | | | 31:16 | | | | | | | | TEFUA | \<31:16> | | | | 1 | 1 | | 1 | xxxx | | | | 1120 | CFD2TEFUA | 15:0 | TEFUA<15:0> | | | | | | | | | | | | | XXXX | | | | | | | 4400 | OFFICE OF A | 31:16 | | | | | | | | | A<31:16> | | | | | | | | 0000 | | | | 1130 | CFD2FIFOBA | 15:0 | | | | | | | | FIFOB | A<15:0> | | | | | | | | 0000 | | | | 1140 | CEDSTYCCON | 31:16 | | PLSIZE<2:0> | > | | | FSIZE<4:0> | | | _ | TXAT | <sup>-</sup> <1:0> | | | TXPRI<4:0> | | | 0060 | | | | 1140 | CFD2TXQCON | 15:0 | _ | _ | _ | _ | _ | FRESET | TXREQ | UINC | TXEN | _ | _ | TXATIE | _ | TXQEIE | _ | TXQNIE | 0480 | | | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. The lower order byte of the 32-bit register resides at the low-order address. TABLE 26-1: CAN FD PERIPHERAL REGISTER SUMMARY (CONTINUED) | Š | ne | | | | | | | | | В | its | | | | | | | | | | | | |-----------------------------|--------------------------------|--------------------------------------|------------------|------------|--------------------|----------|-------|------------------------|------------|-----------|------------------|-----------|-----------|------------------------|----------|------------|----------|----------|------------|--|--|--| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | | | 1150 | CFD2TXQSTA | 31:16 | _ | | _ | _ | | _ | _ | | _ | I | _ | _ | _ | _ | _ | _ | 0000 | | | | | | | 15:0 | _ | _ | _ | | | TXQCI<4:0> | | = 1.00111 | TXABT | TXLARB | TXERR | TXATIF | _ | TXQEIF | _ | TXQNIF | 0000 | | | | | 1160 | CFD2TXQUA | 31:16 TXQUA<31:16> 15:0 TXQUA<15:0> | | | | | | | | | | | | | | | XXXX | | | | | | | | | | | | | | | | | | | | | TVPPLAG | | | | | | | | | | 1170 | CFD2FIFOCONn<br>('n' = 1) | 15:0 | _ | FLSIZE\Z.U | <u> </u> | _ | | FRESET | TXREQ | UINC | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TXPRI<4:0> | TEHREHIE | TFNRFNIE | 0060 | | | | | | CFD2FIFOSTAn | 31:16 | | | | | | — | - IXINEQ | — | - IXLIN | — | - | - | - IXOVIL | — | — | — | 0000 | | | | | 1180 | ('n' = 2 to 31 | 15:0 | | | | | - | I<br>FIFOCI<4:0> | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TEHREHIE | TFNRFNIF | | | | | | | CFD2FIFOUAn | 31:16 | | | | | | | | FIFOUA | \<31:16> | | | | | | | | XXXX | | | | | 1190 | ('n' = 1) | 15:0 | 5:0 FIFOUA<15:0> | | | | | | | | | | | | | | | XXXX | | | | | | | CFD2FIFOCONn | 31:16 | | PLSIZE<2:0 | > | | | FSIZE<4:0> | | | _ | TXAT | <1:0> | | | TXPRI<4:0> | | | 0000 | | | | | | ('n' = 2-31) | 15:0 | _ | _ | _ | _ | _ | FRESET | TXREQ | UINC | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | 0000 | | | | | | CFD2FIFOSTAn | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | | 1730 | ('n'= 1) | 15:0 | _ | ı | _ | | F | FIFOCI<4:0> | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | 0000 | | | | | | CFD2FIFOUAn<br>('n' = 2 to 31) | 31:16 | | | | | | | | | | | | | 0000 | | | | | | | | | | | 15:0 | | | | | | FIFOUA<15:0> | | | | | | | | | | 0000 | | | | | | 1740 | CFD2FLTCON0 | 31:16 | FLTEN3 | _ | _ | | | F3BP<4:0> | | | FLTEN2 | _ | _ | F2BP<4:0> | | | | 0000 | | | | | | | | 15:0 | FLTEN1 | _ | _ | | | F1BP<4:0><br>F7BP<4:0> | | | FLTEN0 | _ | _ | F0BP<4:0><br>F6BP<4:0> | | | | | 0000 | | | | | 1750 | CFD2FLTCON1 | 31:16<br>15:0 | FLTEN7<br>FLTEN5 | _ | | | | F5BP<4:0> | | | FLTEN6<br>FLTEN4 | | _ | | | | | | 0000 | | | | | | | 31:16 | FLTEN11 | | _ | | | F11BP<4:0> | | | FLTEN10 | | _ | F10BP<4:0> | | | | | 0000 | | | | | 1760 | CFD2FLTCON2 | 15:0 | FLTEN9 | | | | | F9BP<4:0> | | | FLTEN8 | | | F8BP<4:0> | | | | | 0000 | | | | | | | 31:16 | FLTEN15 | | | | | F15BP<4:0> | | | FLTEN14 | | _ | | | F14BP<4:0> | | | 0000 | | | | | 1770 | CFD2FLTCON3 | 15:0 | FLTEN13 | _ | | | | F13BP<4:0> | | | FLTEN12 | _ | _ | F12BP<4:0> | | | | | 0000 | | | | | | CFD2FLTCON4 | 31:16 | FLTEN19 | | _ | | | F19BP<4:0> | | | FLTEN18 | _ | _ | | | F18BP<4:0> | | | 0000 | | | | | 1780 | | 15:0 | FLTEN17 | _ | _ | | | F17BP<4:0> | | | FLTEN16 | _ | _ | | | F16BP<4:0> | | | 0000 | | | | | 4700 | OFFICE TOOMS | 31:16 | FLTEN23 | | _ | | | F23BP<4:0> | | | FLTEN22 | _ | _ | | | F22BP<4:0> | | | 0000 | | | | | 1790 | CFD2FLTCON5 | 15:0 | FLTEN21 | | _ | | | F21BP<4:0> | | | FLTEN20 | | _ | | | F20BP<4:0> | | | 0000 | | | | | 1740 | CFD2FLTCON6 | 31:16 | FLTEN27 | - | _ | | | F28BP<4:0> | | | FLTEN26 | - | _ | | | F26BP<4:0> | | | 0000 | | | | | 1770 | OI DZI ETOONO | 15:0 | FLTEN25 | _ | _ | | | F25BP<4:0> | | | FLTEN24 | _ | _ | | | F30BP<4:0> | | | 0000 | | | | | 17B0 | CFD2FLTCON7 | 31:16 | FLTEN31 | _ | _ | | | F31BP<4:0> | | | FLTEN30 | - | _ | | | F26BP<4:0> | | | 0000 | | | | | | | 15:0 | FLTEN29 | | _ | | | F29BP<4:0> | | | FLTEN28 | | _ | | | F28BP<4:0> | | | 0000 | | | | | 17C0 | CFD2FLTOBJn<br>('n' = 0) | 31:16 | | EXIDE | SID11 | | | | | | | EID<17:5> | | | | | | | 0000 | | | | | | ` , | 15:0 | | MIDE | EID<4:0><br>MSID11 | 1 | | | | | | MEID<17:5 | SID<10:0> | > | | | | | 0000 | | | | | 17D0 | CFD2MASKn<br>('n' = 0) | 31:16 | | MIDE | | | | | | | | MEID<17:5 | | 1 | | | | | 0000 | | | | | | ` , | 15:0<br>31:16 | _ | EXIDE | MEID<4:0><br>SID11 | I | | <u> </u> | | | | EID<17:5> | MSID<10:0 | <b></b> | | | | | 0000 | | | | | 1750 | CFD2FLTOBJn<br>('n' = 1 to 31) | 15:0 | | EVIDE | EID<4:0> | | | 1 | | | | LID~11:52 | SID<10:0> | > | | | | | 0000 | | | | | | CFD2MASKn | 31:16 | - | MIDE | MSID11 | | | 1 | | | | MEID<17:5 | | - | | | | | 0000 | | | | | | ('n' = 1 to 31) | 15:0 | | MIDE | MEID<4:0> | <u> </u> | | | | | | | MSID<10:0 | )> | | | | | 0000 | | | | | | , | 31:16 | | TXBW | /S<3:0> | | ABAT | | REQOP<2:0> | , | ( | DPMOD<2:0 | | TXQEN | STEF | SERR2LOM | ESIGM | RTXAT | 0498 | | | | | 4000 | CFD3CON | 15:0 | ON | _ | SIDL | BRSDIS | BUSY | | <1:0> | WAKFIL | CLKSEL0 | | ISOCRCEN | | | DNCNT<4:0> | | | 0760 | | | | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal The lower order byte of the 32-bit register resides at the low-order address. | SS | 9 | Bits ### ### ### ### #################### | | | | | | | | | | | | | | | | | | |-----------------------------|---------------|-------------------------------------------|---------|-------------|----------|----------|----------------------|-------------|----------|-------------|---------------|-------------|---------|----------|------------|---------------|-----------|----------|------------| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | CFD3NBTCFG | 31:16 | | | | | <7:0> | | | | | | | TSE | G1<7:0> | | | | 003E | | | 0. 20.12.0. 0 | 15:0 | | | | | TSEG2<6:0> | | | | | | | | SJW<6:0> | | | | 0F0F | | 4020 | CFD3DBTCFG | 31:16 | | | | BRP | <7:0> | T050 | | | - | | _ | | | TSEG1<4:0> | | | 000E | | | | 15:0<br>31:16 | | | _ | _ | | TSEG2 | EDGFLTEN | SID11EN | | _ | _ | _ | | SJW< | | DD<1:0> | 0303 | | 4030 | CFD3TDC | 15:0 | | _ | _ | _ | TDCO<6:0> | _ | EDGFLIEN | SIDITEN | | <del></del> | | | TDCV | | TDCMC | JU<1:0> | 1000 | | | | 31:16 | | | | | 100000.02 | | | TRC< | 31:16> | _ | | | IDCV | <b>\J.U</b> > | | | 0000 | | 4040 | CFD3TBC | 15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | TSRES | TSEOF | TBCEN | 0000 | | 4050 | CFD3TSCON | 15:0 | _ | _ | _ | _ | _ | _ | | | | | TBCP | RE<9:0> | | ı | | | 0000 | | 4060 | CFD3VEC | 31:16 | _ | | | F | XCODE<6:0> | • | | | _ | | | | TXCODE<6:0 | > | | | 4040 | | 4000 | CFD3VEC | 15:0 | _ | _ | _ | | | FILHIT<4:0> | | | I | | | | ICODE<6:0> | | | | 0040 | | 4070 | CFD3INT | 31:16 | IVMIE | WAKIE | CERRIE | SERRIE | RXOVIE | TXATIE | _ | _ | _ | _ | _ | TEFIE | MODIE | TBCIE | RXIE | TXIE | 0000 | | | 0. 20 | 15:0 | IVMIF | WAKIF | CERRIF | SERRIF | RXOVIF | TXATIF | _ | _ | _ | _ | _ | TEFIF | MODIF | TBCIF | RXIF | TXIF | 0000 | | 4080 | CFD3RXIF | 31:16 | | | | | | | | | 31:16> | | | | | | | | 0000 | | | | 15:0 | | | | | | | | RFIF<15:1> | 31:16> | | | | | | | _ | 0000 | | 4090 | CFD3TXIF | 31:16<br>15:0 | | | | | | | | | <15:0> | | | | | | | | 0000 | | | | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | 40A0 | CFD3RXOVIF | 15:0 | | | | | | | F | RFOVIF<15:1 | | | | | | | | _ | 0000 | | | | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | 40B0 | CFD3TXATIF | 15:0 | | | | | | | | TFATIF | <15:0> | | | | | | | | 0000 | | 4000 | CFD3TXREQ | 31:16 | | | | | | | | TXREQ | <31:16> | | | | | | | | 0000 | | 40C0 | CFD3TAREQ | 15:0 | | | | | | | | TXREC | Q<15:0> | | | | | | | | 0000 | | 4000 | CFD3TREC | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | TXBO | TXBP | RXBP | TXWARN | RXWARN | EWARN | 0020 | | .050 | 0. 20.11.20 | 15:0 | | | | | NT<7:0> | | | | | | | | CNT<7:0> | | | | 0000 | | 40E0 | CFD3BDIAG0 | 31:16 | | | | | CNT<7:0> | | | | | | | | RCNT<7:0> | | | | 0000 | | | | 15:0<br>31:16 | DLCMM | ESI | IDODOEDD | | CNT<7:0><br>DFORMERR | _ | DBIT1ERR | DDITAEDD | _ | I – | NODOEDD | | RCNT<7:0> | NACKERR | LNDITAEDD | NBIT0ERR | 0000 | | 40F0 | CFD3BDIAG1 | 15:0 | DLCIVIN | ESI | DCRCERR | DSTUFERR | DFORMERR | _ | DBITTERK | | <br>:NT<15:0> | _ | NCRCERR | NSTUFERR | NFURIVIERR | NACKERR | NOII IERK | NBITUERR | 0000 | | | | 31:16 | _ | _ | _ | | | FSIZE<4:0> | | LI WOGC | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | 4100 | CFD3TEFCON | 15:0 | | _ | _ | _ | _ | FRESET | _ | UINC | _ | _ | TEFTSEN | _ | TEFOVIE | TEFFIE | TEFHIE | TEFNEIE | 0400 | | <u> </u> | | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 4110 | CFD3TEFSTA | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | TEFOVIF | TEFFIF | TEFHIF | TEFNEIF | 0000 | | 4120 | CFD3TEFUA | 31:16 | | | | | | | | | <31:16> | | | | | | • | • | xxxx | | 4120 | CEDSTEFUA | 15:0 | | | | | | | | | \<15:0> | | | | | | | | XXXX | | 4130 | CFD3FIFOBA | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | | 2. 20 02/1 | 15:0 | | | | 1 | | | | FIFOB | A<15:0> | | | | | | | | 0000 | | 4140 | CFD3TXQCON | 31:16 | | PLSIZE<2:0> | , | | | FSIZE<4:0> | TVDEC | | | | <1:0> | T)/ATIE | | TXPRI<4:0> | | TYONE | 0060 | | | | 15:0 | | _ | _ | | | FRESET — | TXREQ — | UINC<br>— | TXEN — | | | TXATIE — | | TXQEIE — | _ | TXQNIE — | 0480 | | 4150 | CFD3TXQSTA | 31:16<br>15:0 | | | | _ | | TXQCI<4:0> | _ | _ | TXABT | TXLARB | TXERR | TXATIF | | TXQEIF | | TXQNIF | 0000 | | | <br>nd: | | | | | L (a) D | | | | | IAADI | IALAND | IVEKK | IAAIIF | _ | IAQEIF | | IAQINIF | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. The lower order byte of the 32-bit register resides at the low-order address. TABLE 26-1: CAN FD PERIPHERAL REGISTER SUMMARY (CONTINUED) | SS | ne | | | | | | | | | В | its | | | | | | | | | |-----------------------------|---------------------------|---------------|--------------------|----------------------------|-----------|--------|-------|--------------------------|------------|--------|--------------------|---------------|-----------------|-----------|----------|--------------------------|-----------|-------------|------------| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 4160 | CFD3TXQUA | 31:16 | | | | | | | | | \<31:16> | | | | | | | | XXXX | | | | 15:0 | | DI 0175 -0.0 | | | | E017E : 4.0: | | TXQU | A<15:0> | T)/AT | | | | TVDDL 4.0 | | | XXXX | | 4170 | CFD3FIFOCONn<br>('n' = 1) | 31:16<br>15:0 | _ | PLSIZE<2:0> | | | _ | FSIZE<4:0> | TXREQ | UINC | TXEN | TXAT<br>RTREN | <1:0><br>RXTSEN | TXATIE | RXOVIE | TXPRI<4:0> | Тепрепіс | TFNRFNIE | 0060 | | | CFD3FIFOSTAn | 31:16 | | | | | | FRESEI | IAREQ | - OINC | I AEN | - KIKEN | - KATSEN | - IXAIIE | - KAOVIE | - | I FHKFHIE | I FINKFINIE | 0000 | | 4180 | ('n'= 1) | 15:0 | | | | | | FIFOCI<4:0> | _ | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TEHREHIE | TFNRFNIF | 0000 | | | CFD3FIFOUAn | 31:16 | | | | | | | | FIFOU | A<31:16> | 171271112 | 1712.01 | .,,,,,,,, | 10.01 | | | | xxxx | | 4190 | ('n' = 1) | 15:0 | | | | | | | | | A<15:0> | | | | | | | | xxxx | | | CFD3FIFOCONn | 31:16 | | PLSIZE<2:0> | , | | | FSIZE<4:0> | | | _ | TXAT | <1:0> | | | TXPRI<4:0> | | | 0000 | | | ('n' = 2-31) | 15:0 | _ | _ | _ | _ | _ | FRESET | TXREQ | UINC | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | 0000 | | | CFD3FIFOSTAn | 31:16 | _ | - | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 4730 | ('n' = 2 to 31 | 15:0 | _ | _ | _ | | | FIFOCI<4:0> | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | 0000 | | | CFD3FIFOUAn | 31:16 | | | | | | | | | | | | | 0000 | | | | | | | ('n' = 2 to 31) | 15:0 | | | | | | | | FIFOU | | | | | | | | | 0000 | | 4740 | CFD3FLTCON0 | 31:16 | FLTEN3<br>FLTEN1 | _ | _ | | | F3BP<4:0><br>F1BP<4:0> | | | FLTEN2 | | _ | | | F2BP<4:0><br>F0BP<4:0> | | | 0000 | | | | 15:0<br>31:16 | FLTEN7 | | _ | | | F7BP<4:0> | | | FLTEN0<br>FLTEN6 | | _ | | | F6BP<4:0> | | | 0000 | | 4750 | CFD3FLTCON1 | 15:0 | FLTEN7 | | | | | F5BP<4:0> | | | FLTEN4 | | | | | F4BP<4:0> | | | 0000 | | | | 31:16 | FLTEN11 | | | | | F11BP<4:0> | | | FLTEN10 | | | | | F10BP<4:0> | | | 0000 | | 4760 | CFD3FLTCON2 | 15:0 | FLTEN9 | _ | _ | | | F9BP<4:0> | | | FLTEN8 | | _ | | | F8BP<4:0> | | | 0000 | | 4770 | 055051 70010 | 31:16 | FLTEN15 | _ | _ | | | F15BP<4:0> | | | FLTEN14 | | _ | | | F14BP<4:0> | | | 0000 | | 4//0 | CFD3FLTCON3 | 15:0 | FLTEN13 | _ | _ | | | F13BP<4:0> | | | FLTEN12 | _ | _ | | | F12BP<4:0> | | | 0000 | | <b>4780</b> | CFD3FLTCON4 | 31:16 | FLTEN19 | 1 | _ | | | F19BP<4:0> | | | FLTEN18 | _ | _ | | | F18BP<4:0> | | | 0000 | | 4700 | 01 001 21 0014 | 15:0 | FLTEN17 | _ | _ | | | F17BP<4:0> | | | FLTEN16 | _ | _ | | | F16BP<4:0> | | | 0000 | | 4790 | CFD3FLTCON5 | 31:16 | FLTEN23 | - | _ | | | F23BP<4:0> | | | FLTEN22 | _ | _ | | | F22BP<4:0> | | | 0000 | | | | 15:0 | FLTEN21 | _ | _ | | | F21BP<4:0> | | | FLTEN20 | | _ | | | F20BP<4:0> | | | 0000 | | 47A0 | CFD3FLTCON6 | 31:16<br>15:0 | FLTEN27<br>FLTEN25 | | _ | | | F28BP<4:0><br>F25BP<4:0> | | | FLTEN26<br>FLTEN24 | | | | | F26BP<4:0><br>F30BP<4:0> | | | 0000 | | | | 31:16 | FLTEN25 | | | | | F31BP<4:0> | | | FLTEN24<br>FLTEN30 | | | | | F26BP<4:0> | | | 0000 | | 47B0 | CFD3FLTCON7 | 15:0 | FLTEN29 | | | | | F29BP<4:0> | | | FLTEN28 | | | | | F28BP<4:0> | | | 0000 | | | CFD3FLTOBJn | 31:16 | | EXIDE | SID11 | | | . 2021 1.0 | | | | EID<17:5> | | | | . 2021 1.0 | | | 0000 | | 47D0 | ('n' = 0) | 15:0 | | | EID<4:0> | | | | | | | | SID<10:0> | • | | | | | 0000 | | 4700 | CFD3MASKn | 31:16 | - | MIDE | MSID11 | | | 1 | | | | MEID<17:5 | > | | | | | | 0000 | | 47D0 | ('n' = 0) | 15:0 | | | MEID<4:0> | | | | | | | | MSID<10:0 | > | | | | | 0000 | | | CFD3FLTOBJn | 31:16 | - | EXIDE | SID11 | | | | | | | EID<17:5> | | | | | | | 0000 | | | ('n' = 1 to 31) | 15:0 | | | EID<4:0> | | | | | | | | SID<10:0> | • | | | | | 0000 | | UBB0 | CFD3MASKn | 31:16 | | MIDE | MSID11 | | | ı | | | | MEID<17:5 | | | | | | | 0000 | | | ('n' = 1 to 31) | 15:0 | | | MEID<4:0> | | | | | | - | | MSID<10:0 | | | | . ==:-: | | 0000 | | 5000 | CFD4CON | 31:16 | ON | TXBW | | PDODIC | ABAT | | REQOP<2:0> | | | PMOD<2:0 | | TXQEN | STEF | SERR2LOM | ESIGM | RTXAT | 0498 | | | | 15:0<br>31:16 | ON | _ | | | | | | | | 0760<br>003E | | | | | | | | | 5010 | CFD4NBTCFG | 15:0 | _ | | | | | | | | | | | 1950 | | | | | | | | | 15.0 | —<br>— Danat | TSEG2<6:0> — SJW<6:0> 0F0F | | | | | | | | | | | | | | | | $\rm x$ = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. The lower order byte of the 32-bit register resides at the low-order address. | SS | 96 | Bits | | | | | | | | T | | | | | | | | | | |-----------------------------|---------------|---------------|-------|------------|---------|----------|---------------|-------------|----------|------------|--------------------|---------|---------|-------------|------------|------------|----------|----------|------------| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 5020 | 1 | 31:16 | | | | BRP | P<7:0> | | | | _ | _ | _ | | | TSEG1<4:0> | | | 000E | | 0020 | 0.54551010 | 15:0 | _ | _ | _ | _ | | TSEG2 | | | _ | _ | _ | - | | SJW< | | | 0303 | | 5030 | CFD4TDC | 31:16 | _ | _ | _ | _ | | _ | EDGFLTEN | SID11EN | | _ | _ | _ | | | TDCMC | )D<1:0> | 0002 | | | | 15:0 | _ | | | | TDCO<6:0> | | | TDO | | _ | | | TDCV | <5:0> | | | 1000 | | 5040 | CFD4TBC | 31:16<br>15:0 | | | | | | | | | 31:16><br><15:0> | | | | | | | | 0000 | | | | 31:16 | _ | _ | | _ | _ | _ | | - | -13.02 | _ | | | _ | TSRES | TSEOF | TBCEN | 0000 | | 5050 | CFD4TSCON | 15:0 | | | | _ | _ | | _ | | _ | _ | TBCP | RE<9:0> | | TOILLO | ISLOI | IDCLIN | 0000 | | | | 31:16 | _ | | | | RXCODE<6:0 | | | | _ | | | 112 0.0 | TXCODE<6:0 | > | | | 4040 | | 5060 | CFD4VEC | 15:0 | _ | _ | _ | | | FILHIT<4:0> | | | _ | | | | ICODE<6:0> | | | | 0040 | | E070 | CFD4INT | 31:16 | IVMIE | WAKIE | CERRIE | SERRIE | RXOVIE | TXATIE | _ | _ | _ | _ | _ | TEFIE | MODIE | TBCIE | RXIE | TXIE | 0000 | | 3070 | CFD4IN1 | 15:0 | IVMIF | WAKIF | CERRIF | SERRIF | RXOVIF | TXATIF | _ | _ | _ | _ | _ | TEFIF | MODIF | TBCIF | RXIF | TXIF | 0000 | | 5080 | CFD4RXIF | 31:16 | | | | | | | | | :31:16> | | | | | | | | 0000 | | 0000 | 0. 2 5 | 15:0 | | | | | | | | RFIF<15:1> | | | | | | | | _ | 0000 | | 5090 | CFD4TXIF | 31:16 | | | | | | | | | 31:16> | | | | | | | | 0000 | | | | 15:0<br>31:16 | | | | | | | | | <15:0><br>-<31:16> | | | | | | | | 0000 | | 50A0 | CFD4RXOVIF | 15:0 | | | | | | | - | RFOVIF<15: | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | 50B0 | CFD4TXATIF | 15:0 | | | | | | | | | =<15:0> | | | | | | | | 0000 | | 5000 | 055 47/550 | 31:16 | | | | | | | | | <31:16> | | | | | | | | 0000 | | 50C0 | CFD4TXREQ | 15:0 | | | | | | | | TXREC | Q<15:0> | | | | | | | | 0000 | | 5000 | CFD4TREC | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | TXBO | TXBP | RXBP | TXWARN | RXWARN | EWARN | 0020 | | JUDU | CI D4TINEC | 15:0 | | | | | NT<7:0> | | | | | | | | CNT<7:0> | | | | 0000 | | 50E0 | CFD4BDIAG0 | 31:16 | | | | | CNT<7:0> | | | | | | | | RCNT<7:0> | | | | 0000 | | | | 15:0 | | | | | CNT<7:0> | | | | | | | | RCNT<7:0> | | T | | 0000 | | 50F0 | CFD4BDIAG1 | 31:16 | DLCMM | ESI | DCRCERR | DSTUFERR | DFORMERR | _ | DBIT1ERR | | — | _ | NCRCERR | NSTUFERR | NFORMERR | NACKERR | NBIT1ERR | NBIT0ERR | | | | | 15:0<br>31:16 | _ | _ | _ | ı | | FSIZE<4:0> | | EFMSGC | NT<15:0> | I – | _ | _ | _ | _ | T - | | 0000 | | 5100 | CFD4TEFCON | 15:0 | | | _ | _ | _ | FRESET | _ | UINC | | _ | TEFTSEN | | TEFOVIE | TEFFIE | TEFHIE | TEFNEIE | 0400 | | | | 31:16 | | | | _ | | | | _ | | | — | | - | | | — | 0000 | | 5110 | CFD4TEFSTA | 15:0 | _ | | _ | _ | _ | _ | _ | | _ | _ | _ | _ | TEFOVIF | TEFFIF | TEFHIF | TEFNEIF | 0000 | | 5400 | 055 4755114 | 31:16 | | | | | | | | | <31:16> | | | | | | -1 | | xxxx | | 5120 | CFD4TEFUA | 15:0 | | | | | | | | TEFU | \<15:0> | | | | | | | | XXXX | | 5130 | CFD4FIFOBA | 31:16 | | | | | | | | | N<31:16> | | | | | | | | 0000 | | 3130 | CI D4I II OBA | 15:0 | | | | | | | | FIFOB | A<15:0> | | | | | | | | 0000 | | 5140 | CFD4TXQCON | 31:16 | | PLSIZE<2:0 | > | | | FSIZE<4:0> | , | | - | | Γ<1:0> | | | TXPRI<4:0> | | | 0060 | | | | 15:0 | _ | | | _ | _ | FRESET | TXREQ | UINC | TXEN | _ | _ | TXATIE | _ | TXQEIE | _ | TXQNIE | 0480 | | 5150 | CFD4TXQSTA | 31:16 | | | | _ | | | _ | _ | —<br>TVADT | TVI ADD | TYEDD | —<br>TVATIE | _ | - TYOFIE | _ | TYCAUT | 0000 | | | | 15:0<br>31:16 | _ | | _ | | | TXQCI<4:0> | | TYOUA | TXABT<br><31:16> | TXLARB | TXERR | TXATIF | _ | TXQEIF | _ | TXQNIF | 0000 | | 5160 | CFD4TXQUA | 15:0 | | | | | | | | | A<15:0> | | | | | | | | xxxx | | Leger | I | | | | | | et values are | | | 1740/ | 10.07 | | | | | | | | AAAX | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. The lower order byte of the 32-bit register resides at the low-order address. TABLE 26-1: CAN FD PERIPHERAL REGISTER SUMMARY (CONTINUED) | SS | 9 | | | | | | 11 001111 | • | | | its | | | | | | | | | |-----------------------------|--------------------------------|---------------|---------|-------------|-----------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------|-------|----------|-----------|-----------|----------|--------|------------|----------|----------|------------| | Virtual Address<br>(BF88_#) | Register Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 5170 | CFD4FIFOCONn | 31:16 | | PLSIZE<2:0> | > | | | FSIZE<4:0> | | | _ | TXAT | T<1:0> | | | TXPRI<4:0> | | | 0060 | | 3170 | ('n' = 1) | 15:0 | _ | - | _ | _ | I | FRESET | TXREQ | UINC | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | 0400 | | 5180 | CFD4FIFOSTAn | 31:16 | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | - | - | _ | _ | _ | 0000 | | 0100 | ('n'= 1) | 15:0 | _ | _ | _ | | | FIFOCI<4:0> | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | 0000 | | 5190 | CFD4FIFOUAn | 31:16 | | | | | | | | | \<31:16> | | | | | | | | xxxx | | | (n = 1) | 15:0 | | | | | | | | FIFOU | A<15:0> | | | | | | | | xxxx | | | CFD4FIFOCONn | 31:16 | | PLSIZE<2:0> | | | | FSIZE<4:0> | | | _ | | T<1:0> | | | TXPRI<4:0> | T== | 1 | 0000 | | | ('n' = 2-31) | 15:0 | | _ | _ | _ | _ | FRESET | TXREQ | UINC | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | 0000 | | | CFD4FIFOSTAn<br>('n' = 2 to 31 | 31:16 | _ | | _ | _ | - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | | | | | | | 0000 | | | | | | | 5/30 | , | 15:0 | _ | _ | _ | | FIFOCI<4:0> TXABT TXLARB TXERR TXATIF RXOVIF TFERFFIF TFHRFHIF TFNRF | | | | | | | TFNRFNIF | 0000 | | | | | | | CFD4FIFOUAn<br>('n' = 2 to 31) | 31:16 | | | | | | | | | | | | | | | | | 0000 | | | (11 - 2 10 31) | 15:0 | FLTEN3 | | | | F3BP<4:0> FLTEN2 — — F2BP<4:0> 00 | | | | | | | | 0000 | | | | | | 5740 | CFD4FLTCON0 | 31:16<br>15:0 | FLTEN3 | | _ | | F3BP<4:0> FLTEN2 — F2BP<4:0> F1BP<4:0> FLTEN0 — — F0BP<4:0> | | | | | | | | 0000 | | | | | | | | 31:16 | FLTEN7 | _ | _ | | | | | | | | | | 0000 | | | | | | 5750 | CFD4FLTCON1 | 15:0 | FLTEN7 | _ | _ | | F7BP<4:0> FLTEN6 — — F6BP<4:0> F5BP<4:0> F1EN4 — — F4BP<4:0> | | | | | | | | 0000 | | | | | | | | 31:16 | FLTEN11 | | _ | | | F11BP<4:0> | | | FLTEN10 | _ | _ | | | F10BP<4:0> | | | 0000 | | 5760 | CFD4FLTCON2 | 15:0 | FLTEN9 | _ | | | | F9BP<4:0> | | | FLTEN8 | | | | | F8BP<4:0> | | | 0000 | | | | 31:16 | FLTEN15 | | _ | | | F15BP<4:0> | | | FLTEN14 | _ | | | | F14BP<4:0> | | | 0000 | | 5770 | CFD4FLTCON3 | 15:0 | FLTEN13 | | _ | | | F13BP<4:0> | | | FLTEN12 | _ | _ | | | F12BP<4:0> | | | 0000 | | | | 31:16 | FLTEN19 | | _ | | | F19BP<4:0> | | | FLTEN18 | | _ | | | F18BP<4:0> | | | 0000 | | 5780 | CFD4FLTCON4 | 15:0 | FLTEN17 | _ | _ | | | F17BP<4:0> | | | FLTEN16 | _ | _ | | | F16BP<4:0> | | | 0000 | | | | 31:16 | FLTEN23 | _ | _ | | | F23BP<4:0> | | | FLTEN22 | _ | _ | | | F22BP<4:0> | | | 0000 | | 5790 | CFD4FLTCON5 | 15:0 | FLTEN21 | _ | _ | | | F21BP<4:0> | | | FLTEN20 | _ | _ | | | F20BP<4:0> | | | 0000 | | | | 31:16 | FLTEN27 | _ | _ | | | F28BP<4:0> | | | FLTEN26 | _ | _ | | | F26BP<4:0> | | | 0000 | | 57A0 | CFD4FLTCON6 | 15:0 | FLTEN25 | _ | _ | | | F25BP<4:0> | | | FLTEN24 | _ | _ | | | F30BP<4:0> | | | 0000 | | 57D0 | 0ED4ELT00NZ | 31:16 | FLTEN31 | _ | _ | | | F31BP<4:0> | | | FLTEN30 | _ | _ | | | F26BP<4:0> | | | 0000 | | 57B0 | CFD4FLTCON7 | 15:0 | FLTEN29 | _ | _ | | | F29BP<4:0> | | | FLTEN28 | _ | _ | | | F28BP<4:0> | | | 0000 | | F7C0 | CFD4FLTOBJn<br>('n' = 0) | 31:16 | - | EXIDE | SID11 | 11 EID<17:5> | | | | | | | | 0000 | | | | | | | 5700 | ('n' = 0) | 15:0 | | • | EID<4:0> | | | | | | | | SID<10:0> | > | | | | | 0000 | | 57D0 | CFD4MASKn | 31:16 | - | MIDE | MSID11 | | | | | | | MEID<17:5 | > | | | | | | 0000 | | 3700 | ('n' = 0) | 15:0 | | | MEID<4:0> | | | | | | | | MSID<10:0 | > | | | | | 0000 | | | CFD4FLTOBJn | 31:16 | - | EXIDE | SID11 | | | | | | | EID<17:5> | • | | | | | | 0000 | | | ('n' = 1 to 31) | 15:0 | | | EID<4:0> | | | | | | | | SID<10:0> | > | | | | | 0000 | | 5BB0 | CFD4MASKn | 31:16 | - | MIDE | MSID11 | | | | | | | | | 0000 | | | | | | | | ('n' = 1 to 31) | 15:0 | | | MEID<4:0> | | | | | | | | MSID<10:0 | > | | | | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: The lower order byte of the 32-bit register resides at the low-order address. ### REGISTER 26-1: CFDxCON: CAN CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|-----------------------|-------------------------|----------------------|---------------------|-------------------------|----------------------|-----------------------| | 31:24 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | S, HC-0 | R/W-1 | R/W-0 | R/W-0 | | 31.24 | | TXBW | S<3:0> | | ABAT | RE | QOP<2:0> | | | 00.40 | R-1 | R-0 | R-0 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | | OPMOD<2:0 | > | TXQEN <sup>(1)</sup> | STEF <sup>(1)</sup> | SERR2LOM <sup>(1)</sup> | ESIGM <sup>(1)</sup> | RTXAT <sup>(1)</sup> | | 45.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0 | R/W-1 | R/W-1 | R/W-1 | | 15:8 | ON | _ | SIDL <sup>(2)</sup> | BRSDIS | BUSY | WFT<1: | :0> | WAKFIL <sup>(1)</sup> | | 7.0 | R/W-0 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | CLKSEL0 <sup>(1)</sup> | PXEDIS <sup>(1)</sup> | ISOCRCEN <sup>(1)</sup> | | | DNCNT<4:0> | | | Legend:S = Settable bitHC = Cleared by HardwareR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown ### bit 31-28 TXBWS<3:0>: Transmit Bandwidth Sharing bits Delay between two consecutive transmissions (in arbitration bit times) 1111-1100 = 4096 1011 = 2048 1010 = 1024 1001 = 512 1000 = 256 0111 = 128 0110 = 64 0101 = 32 0100 = 16 0011 = 8 0010 = 4 0001 = 2 0000 **= No delay** ### bit 27 ABAT: Abort All Pending Transmissions bit - 1 = Signal all transmit buffers to abort transmission - 0 = Module will clear this bit when all transmissions aborted #### bit 26-24 REQOP<2:0>: Request Operation Mode bits 111 = Set Restricted Operation mode 110 = Set Normal CAN 2.0 mode; error frames on CAN FD frames 101 = Set External Loopback mode 100 = Set Configuration mode 011 = Set Listen Only mode 010 = Set Internal Loopback mode 001 = Set Disable mode 000 = Set Normal CAN FD mode; supports mixing of Full CAN FD and Classic CAN 2.0 frames Note 1: This bit can only be modified in Configuration mode (OPMOD<2:0> bits = 100). ### REGISTER 26-1: CFDxCON: CAN CONTROL REGISTER ('x' = 1-4) (CONTINUED) - bit 23-21 **OPMOD<2:0>:** Operation Mode Status bits - 111 = Module is Restricted Operation mode - 110 = Module is Normal CAN 2.0 mode; error frames on CAN FD frames - 101 = Module is in External Loopback mode - 100 = Module is in Configuration mode - 011 = Module is in Listen Only mode - 010 = Module is in Internal Loopback mode - 001 = Module is in Disable mode - 000 = Module is in Normal CAN FD mode; supports mixing of Full CAN FD and Classic CAN 2.0 frames **Note:** In Restricted Operation mode, the node is able to receive data and remote frames, and to acknowledge valid frames, but it does not send data frames, remote frames, active error frames, or overload frames. - bit 20 **TXQEN:** Enable Transmit Queue bit<sup>(1)</sup> - 1 = Enables Transmit Queue and reserves space in RAM - 0 = Don't reserve space in RAM for Transmit Queue Note: Changes only in Configuration mode, since it changes the addresses in RAM. - bit 19 **STEF:** Store in Transmit Event FIFO bit<sup>(1)</sup> - 1 = Save transmitted messages in TEF - 0 = Don't save transmitted messages in TEF Note: Changes only in Configuration mode, since it changes the addresses in RAM. - bit 18 SERR2LOM: Transition to Listen Only Mode on System Error bit<sup>(1)</sup> - 1 = Transition to Listen Only Mode - 0 = Transition to Restricted Operation Mode - bit 17 **ESIGM:** Transmit ESI in Gateway Mode bit (1) - 1 = ESI is transmitted as recessive when ESI of message is high or CAN controller error passive - 0 = ESI reflects error status of CAN controller - bit 16 RTXAT: Restrict Retransmission Attempts bit (1) - 1 = Restricted retransmission attempts, use the TXAT<1:0> bit (CiFIFOCONn<22:21>) - 0 = Unlimited number of retransmission attempts, TXAT<1:0> bit will be ignored - bit 15 ON: Enable bit - 1 = CAN module is enabled - 0 = CAN module is disabled - bit 14 Unimplemented: Read as '0' - bit 13 SIDL: Stop-in-Idle Control bit<sup>(2)</sup> - 1 = Stop module operation in Idle mode - 0 = Don't stop module operation in Idle mode - bit 12 BRSDIS: Bit Rate Switching Disable bit - 1 = Bit Rate Switching is Disabled, regardless of BRS in the Transmit Message Object - 0 = Bit Rate Switching depends on BRS in the Transmit Message Object - bit 11 BUSY: CAN Module is Busy bit - 1 = The CAN module is active - 0 = The CAN module is inactive - bit 10-9 WFT<1:0>: Selectable Wake-up Filter Time bits - 11 = T11FILTER (Typical 600 ns) - 10 = T10FILTER (Typical 375 ns) - 01 = T01FILTER (Typical 187 ns) - 00 = T00FILTER (Typical 100 ns) - Note 1: This bit can only be modified in Configuration mode (OPMOD<2:0> bits = 100). ### REGISTER 26-1: CFDxCON: CAN CONTROL REGISTER ('x' = 1-4) (CONTINUED) - bit 8 **WAKFIL:** Enable CAN Bus Line Wake-up Filter bit<sup>(1)</sup> - 1 = Use CAN bus line filter for wake-up - 0 = CAN bus line filter is not used for wake-up - bit 7 **CLKSEL0:** Module Clock Source Select bit<sup>(1)</sup> - 1 = REFCLK4 is active when the CAN FD module is enabled - 0 = SYSCLK is active when the CAN FD module is enabled # Note: Max CAN-FD clock source cannot exceed 80 MHz. Recommended CAN-FD clock frequency is 20 MHz/40 MHz/80 MHz. Implementing the following steps to set Module Clock frequency of 40 MHz while maintaining CPU clock frequency of 120 MHz: - Select module clock source as REFCLK4 by configuring the CLKSEL0 bit (CFDxCON<7>) = 1 - Select SYSCLK as the input clock fro REFCLK4 by configuring the ROSEL bits (REFO4CON<3:0>) = 0. - Set REF4CLK prescaler to 3 by configuring the RODIV bits (REF04CON<30:16>) = 1 and the ROTRIM bits (REF04TRIM<31:23> = 256. - bit 6 **PXEDIS:** Protocol Exception Event Detection Disabled bit<sup>(1)</sup> A recessive "res bit" following a recessive FDF bit is called a Protocol Exception. - 1 = Protocol Exception is treated as a Form Error. - 0 = If a Protocol Exception is detected, the CAN FD module will enter the Bus Integrating state. - bit 5 ISOCRCEN: Enable ISO CRC in CAN FD Frames bit (1) - 1 = Include Stuff Bit Count in CRC Field and use Non-Zero CRC Initialization Vector - 0 = Do not include Stuff Bit Count in CRC Field and use CRC Initialization Vector with all zeros - bit 4-0 **DNCNT<4:0>:** Device Net Filter Bit Number bits - 11111-10011 = Invalid Selection (compare with EID<0:17>) - 10010 = Compare up to data byte 0<7:0> and Byte 1<7:0> and Byte 2<6> with EID17 - 10001 = Compare up to data byte 0<7:0> and Byte 1<7:0> and Byte 2<7> with EID<0:16> - 10000 = Compare up to data byte 0<7:0> and data byte 1<7:0> with EID<0:15> - 01111 = Compare up to data byte 0<7:0> and data byte 1<7:1> with EID<0:14> - 01110 = Compare up to data byte 0<7:0> and data byte 1<7:2> with EID<0:13> - 01101 = Compare up to data byte 0<7:0> and data byte 1<7:3> with EID<0:12> - 01100 = Compare up to data byte 0<7:0> and data byte 1<7:4> with EID<0:11> - 01011 = Compare up to data byte 0<7:0> and data byte 1<7:5> with EID<0:10> 01010 = Compare up to data byte 0<7:0> and data byte 1<7:6> with EID<0:9> - 01001 = Compare up to data byte 0<7:0> and data byte 1<7> with EID<0:8> - 01000 = Compare up to data byte 0<7:0> with EID<0:7> - 00111 = Compare up to data byte 0<7:1> with EID<0:6> - 00110 = Compare up to data byte 0<7:2> with EID<0:5> - 00101 = Compare up to data byte 0<7:3> with EID<0:4> - 00100 = Compare up to data byte 0<7:4> with EID<0:3> - 00011 = Compare up to data byte 0<7:5> with EID<0:2> - 00010 = Compare up to data byte 0<7:6> with EID<0:1> - 00001 = Compare up to data byte 0 bit 7 with EID0 - 00000 = Do not compare data bytes - **Note 1:** This bit can only be modified in Configuration mode (OPMOD<2:0> bits = 100). ### REGISTER 26-2: CFDxNBTCFG: NOMINAL BIT TIME CONFIGURATION REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | R/W-0 | 31.24 | | | | BRP: | <7:0> | | | | | 22,16 | R/W-0 | R/W-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-0 | | 23:16 | | | | TSEG | 1<7:0> | | | | | 15.0 | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | | 15:8 | _ | | | | TSEG2<6:0> | | | | | 7:0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | | 7.0 | _ | | | | SJW<6:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 23-16 **TSEG1<7:0>:** Time Segment 1 bits (Propagation Segment + Phase Segment 1) 1111 1111 = Length is 256 x TQ : 00000000 = Length is 1 x TQ bit 15 Unimplemented: Read as '0' bit 14-8 **TSEG2<6:0>:** Time Segment 2 bits (Phase Segment 2) 111111 = Length is 128 x TQ • 000000 = Length is 1 x TQ bit 7 Unimplemented: Read as '0' bit 6-0 **SJW<6:0>:** Synchronization Jump Width bits 1111111 = Length is 128 x TQ • 00000000 = Length is 1 x TQ - Note 1: This register can only be modified in Configuration mode (OPMOD<2:0> bits (CFDxCON<23:21>) = 100). - **2:** The following apply to this register: - TQ = ((BRP + 1)) / FCAN) - Nominal Bit Period = (TQ \* ((SYNC + (TSEG1 + 1) + (TSEG2 +1))) - Calc Nominal Bit Rate = (1 / Bit Period) OR - Calc CAN Bit Rate = (1 / (((BRP + 1)) / FCAN) \* (SYNC + (TSEG1 + 1) + (TSEG2 + 1)))) - **3:** The maximum allowed CAN FD error is ≤ 1% %Error = (((Calc CAN bit rate Desired CAN bit rate) / Desired CAN bit rate) \* 100). ### REGISTER 26-3: CFDxDBTCFG: DATA BIT TIME CONFIGURATION REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 21.24 | R/W-0 | 31:24 | | | | BRP | <7:0> | | | | | 00.40 | U-0 | U-0 | U-0 | R/W-0 | R/W-1 | R/W-1 | R/W-1 | R/W-0 | | 23:16 | _ | | _ | | | TSEG1<4:0> | | • | | 45.0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-1 | R/W-1 | | 15:8 | _ | | _ | _ | | TSEG | 2<3:0> | | | 7:0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-1 | R/W-1 | | 7.0 | _ | _ | _ | _ | | SJW | <3:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31-24 BRP<7:0>: Baud Rate Prescaler bits ``` 11111111 = TQ = 256/Fsys • 0000 0000 = TQ = 1/Fsys bit 23-21 Unimplemented: Read as '0' bit 20-16 TSEG1<4:0>: Time Segment 1 bits (Propagation Segment + Phase Segment 1) 11111 = Length is 32 x TQ , 00000 = Length is 1 x TQ bit 15-12 Unimplemented: Read as '0' bit 11-8 TSEG2<3:0>: Time Segment 2 bits (Phase Segment 2) 1111 = Length is 16 x TQ • 0000 = Length is 1 x TQ bit 7-4 Unimplemented: Read as '0' - **Note 1:** This register can only be modified in Configuration mode (OPMOD<2:0> bits (**CFDx**CON<23:21>) = 100). - **2:** The following apply to this register: - TQ = ((BRP + 1)) / FCAN) - Nominal Bit Period = (TQ \* ((SYNC + (TSEG1 + 1) + (TSEG2 +1))) - Calc Nominal Bit Rate = (1 / Bit Period) OR - Calc CAN Bit Rate = (1 / (((BRP + 1)) / FCAN) \* (SYNC + (TSEG1 + 1) + (TSEG2 + 1)))) - **3:** The maximum allowed CAN FD error is ≤ 1% %Error = (((Calc CAN bit rate Desired CAN bit rate) / Desired CAN bit rate) \* 100). ### REGISTER 26-3: CFDxDBTCFG: DATA BIT TIME CONFIGURATION REGISTER ('x' = 1-4) - **Note 1:** This register can only be modified in Configuration mode (OPMOD<2:0> bits (**CFDx**CON<23:21>) = 100). - **2:** The following apply to this register: - TQ = ((BRP + 1)) / FCAN) - Nominal Bit Period = (TQ \* ((SYNC + (TSEG1 + 1) + (TSEG2 +1))) - Calc Nominal Bit Rate = (1 / Bit Period) OR - Calc CAN Bit Rate = (1 / (((BRP + 1)) / FCAN) \* (SYNC + (TSEG1 + 1) + (TSEG2 + 1)))) - **3:** The maximum allowed CAN FD error is ≤ 1% %Error = (((Calc CAN bit rate Desired CAN bit rate) / Desired CAN bit rate) \* 100). ### REGISTER 26-4: CFDxTDC: TRANSMITTER DELAY COMPENSATION REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 R/W-0 | | 31:24 | _ | - | _ | _ | _ | _ | EDGFLTEN | SID11EN | | 22.16 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | | 23:16 | | 1 | - | | | - | TDCMC | D<1:0> | | 15:8 | U-0 | R/W-0 | R/W-0 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15.6 | _ | | | | TDCO<6:0> | | | | | 7:0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7.0 | | | | | TDCV | ′<5:0> | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 Unimplemented: Read as '0' bit 25 EDGFLTEN: Enable Edge Filtering during Bus Integration state bit 1 = Edge Filtering enabled, according to ISO11898-1:2015 0 = Edge Filtering disabled bit 24 SID11EN: Enable 12-Bit SID in CAN FD Base Format Messages bit 1 = RRS is used as SID11 in CAN FD base format messages: SID<11:0> = {SID<10:0>, SID11} 0 = Do not use RRS; SID<10:0> according to ISO11898-1:2015 bit 23-18 Unimplemented: Read as '0' bit 17-16 TDCMOD<1:0>: Transmitter Delay Compensation Mode bits Secondary Sample Point (SSP). 10 = Auto; measure delay and add CFDxDBTCFG.TSEG1; add TDCO 11 = Auto; measure delay and add CFDxDBTCFG.TSEG1; add TDCO 01 = Manual; Do not measure, use TDCV plus TDCO from the register 00 = Disable bit 15 Unimplemented: Read as '0' bit 14-8 TDCO<6:0>: Transmitter Delay Compensation Offset bits Secondary Sample Point (SSP). Two's complement; offset can be positive, zero, or negative. 11111111 = -64 x SYSCLK • 0111111 = **63** x SYSCLK • 0000000 = **0** x SYSCLK bit 7-6 Unimplemented: Read as '0' bit 5-0 TDCV<5:0>: Transmitter Delay Compensation Value bits; Secondary Sample Point (SSP) 111111 = 63 x SYSCLK • 000000 = 0 x SYSCLK Note: This register can only be modified in Configuration mode (OPMOD<2:0> bits (CFDxCON<23:21>) = 100). ### REGISTER 26-5: CFDxTBC: CAN TIME BASE COUNTER REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | R/W-0 | 31.24 | | | | TBC< | 31:24> | | | | | 22:46 | R/W-0 | 23:16 | | | | TBC< | 23:16> | | | | | 45.0 | R/W-0 | 15:8 | | | | TBC< | 15:8> | | | | | 7:0 | R/W-0 | 7.0 | | | | TBC | <7:0> | | | | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 TBC<31:0>: CAN Base Counter bits This is a free running 32-bit time stamp timer that increments every SYSCLK clocks (TBCPRE<9:0> (CFDxTSCON<9:0>)) when the TTBCEN bit (CFDxTSCON<8>) is set. **Note 1:** To save power, the TBC will be stopped and reset when the TBCEN bit (CFDxTSCON<16>) = 0 to save power. 2: The TBC prescaler count will be reset on any write to the CFDxTBC register (TBCPRE<9:0> (CFDxTSCON<9:0>) will be unaffected). **Note:** The timer/counter increments on SYSCLK and rolls over to zero. There are two main time stamping registers: - CFDxTBC: Time Base Counter, 32-bit - CFDxTSCON: Time Stamp Control register Time Stamp Event selectable: - Classic CAN Frame: SOF versus EOF - CAN FD Frame: After SOF/FDF versus EOF ### REGISTER 26-6: CFDxTSCON: CAN TIME STAMP CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | | _ | | 1 | | - | | 00.46 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | _ | _ | _ | _ | _ | TSRES | TSEOF | TBCEN | | 45.0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | _ | _ | _ | _ | _ | | TBCPR | E<9:8> | | 7:0 | R/W-0 | 7.0 | | | | TBCPR | E<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-19 Unimplemented: Read as '0' bit 18 TSRES: Time Stamp Resolution bit FD Frames only. 1 = At sample point of the bit following the FDF bit 0 = At sample point of SOF bit 17 TSEOF: Time Stamp EOF bit 1 = Time Stamp when frame is taken valid (11898-1 10.7): • RX no error until last but one bit of EOF) · TX no error until the end of EOF 0 = Time Stamp at "beginning" of Frame: · Classical Frame: At sample point of SOF · FD Frame: See the TSRES bit bit 16 TBCEN: Time Base Counter Enable bit 1 = Enable TBC 0 = Stop and reset TBC bit 15-10 Unimplemented: Read as '0' bit 9-0 TBCPRE<9:0>: CAN Time Base Counter Prescaler bits 111111111 = TBC increments every 1024 SYSCLK clock cycles • 000000000 = TBC increments every 1 SYSCLK clock cycle ### REGISTER 26-7: CFDxVEC: INTERRUPT CODE REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|----------------------------|-------------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | R-1 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | | 31.24 | - | | | R) | CODE<6:0> | (1) | | | | | 23:16 | U-0 | R-1 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | | | _ | TXCODE<6:0>(1) | | | | | | | | | 45.0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | | 15:8 | - | - | _ | FILHIT<4:0> <sup>(1)</sup> | | | | | | | 7:0 | U-0 | R-1 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | | | _ | | | | CODE<6:0> <sup>(1</sup> | ) | | | | ``` Legend:R = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown ``` Note 1: If multiple interrupts are pending, the interrupt with the highest number will be indicated. ### REGISTER 26-7: CFDxVEC: INTERRUPT CODE REGISTER ('x' = 1-4) (CONTINUED) bit 22-16 TXCODE<6:0>: Transmit Interrupt Flag Code bits (1) 1111111 = Reserved 1000001 = Reserved 1000000 **= No interrupt** 0111111 = Reserved 0100000 = Reserved 0011111 = FIFO 31 interrupt (TFIF<31> bit is set) 0000001 = FIFO 1 interrupt (TFIF<1> bit is set) 0000000 = FIFO 0 interrupt (TFIF<0> bit is set) bit 15-13 Unimplemented: Read as '0' bit 12-8 FILHIT<4:0>: Filter Hit Number bits(1) 11111 = Filter 31 11110 = Filter 30 00001 = Filter 1 00000 = Filter 0 bit 7 Unimplemented: Read as '0' ICODE<6:0>: Interrupt Flag Code bits(1) bit 6-0 1111111 = Reserved 1001011 = Reserved 1001010 = Transmit attempt interrupt (any bit in the CFDxTXATIF register is set) 1001001 = Transmit event FIFO interrupt (any bit in the CFDxTEFIF register is set) 1001000 = Invalid message occurred (IVMIF/IE) 1000111 = CAN module mode change Occurred (MODIF/IE) 1000110 = CAN Timer Overflow (CTMRIF/IE) 1000101 = RX/TX MAB overflow/underflow (RX: message received before previous message was saved to memory; TX: cannot feed TX MAB fast enough to transmit consistent data.) (SERRIF/IE) 1000100 = Address error interrupt (illegal FIFO address presented to system) (SERRIF/IE) 1000011 = Receive FIFO overflow interrupt (any bit in CFDxRXOVIF set) 1000010 = Wake-up interrupt (WAKIF/WAKIE) 1000001 = Error interrupt (CERRIF/IE) 1000000 **= No interrupt** 0111111 = Reserved 0100000 = Reserved 0011111 = FIFO 31 interrupt (TFIF<31> or RFIF<31> set) 0000001 = FIFO 1 interrupt (TFIF<1> or RFIF<1> set) 0000000 = FIFO 0 interrupt (TFIF<0> set) Note 1: If multiple interrupts are pending, the interrupt with the highest number will be indicated. REGISTER 26-8: CFDxINT: INTERRUPT REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|----------------------|----------------------|-----------------------|-----------------------|----------------------|----------------------|------------------|------------------| | 31:24 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | | 31.24 | IVMIE | WAKIE | CERRIE | SERRIE | RXOVIE | TXATIE | _ | _ | | 22,16 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | _ | _ | _ | TEFIE | MODIE | TBCIE | RXIE | TXIE | | 45.0 | HS/C-0 | HS/C-0 | HS/C-0 | HS/C-0 | R-0 | R-0 | U-0 | U-0 | | 15:8 | IVMIF <sup>(1)</sup> | WAKIF <sup>(1)</sup> | CERRIF <sup>(1)</sup> | SERRIF <sup>(1)</sup> | RXOVIF | TXATIF | 1 | _ | | 7.0 | U-0 | U-0 | U-0 | R-0 | HS/C-0 | HS/C-0 | R-0 | R-0 | | 7:0 | _ | _ | | TEFIF | MODIF <sup>(1)</sup> | TBCIF <sup>(1)</sup> | RXIF | TXIF | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 **IVMIE:** Invalid Message Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 30 WAKIE: Bus Wake Up Activity Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 29 CERRIE: CAN Bus Error Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 28 SERRIE: System Error Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 27 RXOVIE: Receive Buffer Overflow Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 26 **TXATIE:** Transmit Attempt Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 25-21 Unimplemented: Read as '0' bit 20 TEFIE: Transmit Event FIFO Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 19 MODIE: Mode Change Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 18 TBCIE: CAN Timer Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled bit 17 RXIE: Receive Object Interrupt Enable bit 1 = Interrupts are enabled0 = Interrupts are disabled Note 1: Flags are set by hardware and are cleared by the user application. ### REGISTER 26-8: CFDxINT: INTERRUPT REGISTER ('x' = 1-4) (CONTINUED) TXIE: Transmit Object Interrupt Enable bit 1 = Interrupts are enabled 0 = Interrupts are disabled' IVMIF: Invalid Message Interrupt Flag bit<sup>(1)</sup> bit 15 1 = An invalid message interrupt is pending 0 = No invalid message interrupts are pending **WAKIF:** Bus Wake Up Activity Interrupt Flag bit<sup>(1)</sup> bit 14 1 = A wake-up interrupt is pending 0 = No wake-up interrupts are pending bit 13 **CERRIF:** CAN Bus Error Interrupt Flag bit<sup>(1)</sup> 1 = A CAN bus error interrupt is pending 0 = No CAN bus error interrupts are pending SERRIF: System Error Interrupt Flag bit(1) bit 12 1 = A system error occurred (collision on dual-port RAM) 0 = No system error occurred bit 11 **RXOVIF:** Receive Object Overflow Interrupt Flag bit 1 = Receive object overflow occurred 0 = No receive object overflow has occurred **TXATIF:** Transmit Attempt Interrupt Flag bit bit 10 1 = A transmit interrupt is pending in one or more of the designated 32 FIFOs denoted by which of the 32 bits in the CFDxTXATIF register are set 0 = No transmit FIFO interrupts are pending bit 9-5 Unimplemented: Read as '0' bit 4 TEFIF: Transmit Event FIFO Interrupt Flag bit 1 = Receive buffer overflow occurred 0 = No receive buffer overflow has occurred **MODIF:** CAN Mode Change Interrupt Flag bit<sup>(1)</sup> bit 3 1 = CAN module mode change occurred (OPMOD has changed to reflect the REQOP<2:0> bits) 0 = No mode change occurred **TBCIF:** CAN Timer Overflow Interrupt Flag bit<sup>(1)</sup> bit 2 1 = TBC has overflowed 0 = TBC did not overflow bit 1 **RXIF:** Receive Object Interrupt Flag bit 1 = Receive object interrupt pending 0 = No receive object interrupts pending bit 0 TXIF: Transmit Object Interrupt Flag bit 1 = Transmit object interrupt pending 0 = No transmit object interrupts pending Note 1: Flags are set by hardware and are cleared by the user application. ### REGISTER 26-9: CFDxRXIF: RECEIVE INTERRUPT STATUS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|----------------------------|-------------------|-------------------|--------------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R-0 | | | 31:24 | RFIF<31:24> <sup>(1)</sup> | | | | | | | | | | | 00.40 | R-0 | | | 23:16 | RFIF<23:16> <sup>(1)</sup> | | | | | | | | | | | 45.0 | R-0 | | | 15:8 | RFIF<15:8> <sup>(1)</sup> | | | | | | | | | | | 7.0 | R-0 U-0 | | | | 7:0 | | | | RFIF<7:1> <sup>(1)</sup> | | | | _ | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-1 RFIF<31:1>: Receive FIFO Interrupt Pending bits<sup>(1)</sup> 1 = One or more enabled receive FIFO interrupts are pending 0 = No enabled receive FIFO interrupts are pending bit 0 Unimplemented: Read as '0' Note 1: RFIF = 'or' of enabled RXFIFO flags; (flags need to be cleared in FIFO register). ### REGISTER 26-10: CFDxRXOVIF: RECEIVE OVERFLOW INTERRUPT STATUS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 31:24 | R-0 | | | 31.24 | RFOVIF<31:24> <sup>(1)</sup> | | | | | | | | | | | 00.40 | R-0 | | | 23:16 | RFOVIF<23:16> <sup>(1)</sup> | | | | | | | | | | | 45.0 | R-0 | | | 15:8 | RFOVIF<15:8> <sup>(1)</sup> | | | | | | | | | | | 7.0 | R-0 U-0 | | | | 7:0 | | | R | RFOVIF<7:1> | 1) | | | _ | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-1 RFOVIF<31:1>: Receive FIFO Overflow Interrupt Pending bits<sup>(1)</sup> 1 = Interrupt is pending 0 = Interrupt not pending bit 0 Unimplemented: Read as '0' Note 1: RVOVIF (flag need to be cleared in FIFO register). ### REGISTER 26-11: CFDxTXIF: TRANSMIT INTERRUPT STATUS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|----------------------------|-------------------|-------------------|-------------------|----------------------|-------------------|------------------|------------------|--|--| | 24.24 | R-0 | | | 31:24 | | | | TFIF<3 | 1:24> <sup>(1)</sup> | | | | | | | 00.40 | R-0 | | | 23:16 | TFIF<23:16> <sup>(1)</sup> | | | | | | | | | | | 45.0 | R-0 | | | 15:8 | TFIF<15:8> <sup>(1)</sup> | | | | | | | | | | | 7.0 | R-0 | | | 7:0 | | | | TFIF< | 7:0> <sup>(1)</sup> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 **TFIF<31:0>:** Transmit FIFO/Transmit Queue<sup>(2)</sup> Interrupt Pending bits<sup>(1)</sup> 1 = One or more enabled transmit FIFO/Transmit Queue interrupts are pending 0 = No enabled transmit FIFO/Transmit Queue interrupt are pending Note 1: TFIF = 'or' of the enabled TXFIFO flags; (flags need to be cleared in FIFO register). 2: TFIF<0> is for the Transmit Queue. ### REGISTER 26-12: CFDxTXATIF: TRANSMIT ATTEMPT INTERRUPT STATUS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|------------------------------|-------------------|-------------------|-------------------|-----------------------|-------------------|------------------|------------------|--|--| | 24.24 | R-0 | | | 31:24 | | | | TFATIF< | 31:24> <sup>(1)</sup> | | | | | | | 00.46 | R-0 | | | 23:16 | TFATIF<23:16> <sup>(1)</sup> | | | | | | | | | | | 45.0 | R-0 | | | 15:8 | TFATIF<15:8> <sup>(1)</sup> | | | | | | | | | | | 7.0 | R-0 | | | 7:0 | | | | TFATIF | <7:0> <sup>(1)</sup> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 **TFATIF<31:0>:** Transmit FIFO/Transmit Queue<sup>(2)</sup> Attempt Interrupt Pending bits<sup>(1)</sup> - 1 = A transmit interrupt is pending in one or more of the designated 32 FIFOs denoted by which of the 32 bits in the CFDxTXATIF register are set - 0 = No transmit FIFO interrupts are pending - Note 1: TFATIF = 'or' of the enabled TXFIFO flags; (flags need to be cleared in FIFO register). - 2: TFATIF<0> is for the Transmit Queue. ### REGISTER 26-13: CFDxTXREQ: TRANSMIT REQUEST REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-----------------------------|-------------------|-------------------|-------------------|----------------------|-------------------|------------------|------------------|--|--| | 24.24 | S, HC-0 | | | 31:24 | TXREQ<31:24> <sup>(1)</sup> | | | | | | | | | | | 22.16 | S, HC-0 | | | 23:16 | TXREQ<23:16> <sup>(1)</sup> | | | | | | | | | | | 45.0 | S, HC-0 | | | 15:8 | TXREQ<15:8> <sup>(1)</sup> | | | | | | | | | | | 7.0 | S, HC-0 | | | 7:0 | | | | TXREQ | <7:0> <sup>(1)</sup> | | | | | | Legend: S = Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-1 TXREQ<31:1>: Message Send Request bits<sup>(1)</sup> TXEN = 1: (Object configured as a Transmit Object) Setting this bit to '1' requests sending a message. The bit will automatically clear when the message(s) queued in the object is (are) successfully sent and cannot be used for aborting a transmission. TXEN = 0: (Object configured as a Receive Object) This bit has no effect. bit 0 TXREQ<0>: Transmit Queue Message Send Request bit<sup>(1)</sup> Setting this bit to '1' requests sending a message. The bit will automatically clear when the message(s) queued in the object is (are) successfully sent and cannot be used for aborting a transmission. **Note 1:** The TXREQ<31:0> bits are ignored in Listen Only mode (REQOP<2:0> bits (CFDxCON<26:24>) = 0'b011). ### REGISTER 26-14: CFDxFIFOBA: MESSAGE MEMORY BASE ADDRESS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|---------------------------------|--|--|--|--| | 31:24 | R/W-0 | | | | | 31.24 | | | | FIFOBA | <31:24> | | | 9/1 24/16/8/0<br>R/W-0<br>R/W-0 | | | | | | 00.46 | R/W-0 | | | | | 23:16 | FIFOBA<23:16> | | | | | | | | | | | | | 45.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | SR/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | 15:8 | FIFOBA<15:8> | | | | | | | | | | | | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | | | | | | 7:0 | | | | FIFOB | A<7:0> | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 FIFOBA<31:0>: Message Memory Base Address bits Defines the base address for Transmit Event FIFO followed by the message objects. **Note 1:** Bits<1:0> are forced to '0' to be word aligned. 2: This register can only be modified in Configuration mode (OPMOD<2:0> bits (CFDxCON<23:21>) = 100). # REGISTER 26-15: CFDxTXQCON: TRANSMIT QUEUE CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|----------------------------|-------------------|-------------------|---------------------------|-------------------|-----------------------|------------------|------------------|--| | 31:24 | R/W-0 | | 31:24 | PLSIZE<2:0> <sup>(1)</sup> | | | FSIZE<4:0> <sup>(1)</sup> | | | | | | | 00.40 | U-0 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | _ | TXAT | <1:0> | | | TXPRI<4:0> | | | | | 45.0 | U-0 | U-0 | U-0 | U-0 | U-0 | S, HC-1 | R/W, HC-0 | S, HC-0 | | | 15:8 | _ | _ | _ | _ | _ | FRESET <sup>(2)</sup> | TXREQ | UINC | | | 7:0 | R-1 | U-0 | U-0 | R/W-0 | U-0 | R/W-0 | U-0 | R/W-0 | | | | TXEN | _ | _ | TXATIE | _ | TXQEIE | _ | TXQNIE | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31-29 PLSIZE<2:0>: Payload Size bits(1) ``` 111 = 64 data bytes 110 = 48 data bytes 101 = 32 data bytes 100 = 24 data bytes 011 **= 20 data bytes** 010 = 16 data bytes 001 = **12** data bytes 000 **= 8 data bytes** ### bit 28-24 **FSIZE<4:0>:** FIFO Size bits<sup>(1)</sup> 11111 = FIFO is 32 Messages deep : . 00010 = FIFO is 3 Messages deep 00001 = FIFO is 2 Messages deep 00000 = FIFO is 1 Message deep ### bit 23 Unimplemented: Read as '0' #### bit 22-21 TXAT<1:0>: Retransmission Attempts bits This feature is enabled when the RTXAT bit (CFDxCON<8>) is set. 11 = Unlimited number of retransmission attempts 10 = Unlimited number of retransmission attempts 01 = Three retransmission attempts 00 = Disable retransmission attempts **Note:** The user application must be able to change these bits in Normal mode. This can be used to go back on the bus after bus off to check if transmission works again. - Note 1: This bit can only be modified in Configuration mode ((OPMOD<2:0> bits (CFDxCON<23:21>) = 100). - 2: This bit is set while in Configuration mode and is automatically cleared in Normal mode. # REGISTER 26-15: CFDxTXQCON: TRANSMIT QUEUE CONTROL REGISTER ('x' = 1-4) (CONTINUED) bit 20-16 TXPRI<4:0>: Message Transmit Priority bits (EXPANDED) 11111 = Highest Message Priority • 00000 = Lowest Message Priority bit 15-11 Unimplemented: Read as '0' bit 10 FRESET: FIFO Reset bit<sup>(2)</sup> 1 = FIFO will be reset when bit is set; cleared by hardware when FIFO is reset. The user application should poll whether this bit is clear before taking any action. 0 = No effect bit 9 TXREQ: Message Send Request bit 1 = Requests sending a message; the bit will automatically clear when all the messages queued in the Transmit Queue are successfully sent 0 = Clearing the bit to '0' while set ('1') will request a message abort. bit 8 **UINC:** Increment Head/Tail bit When this bit is set, the FIFO head will increment by a single message. bit 7 **TXEN:** TX Enable 1 = Transmit Message Queue. This bit always reads as '1'. bit 6-5 Unimplemented: Read as '0' bit 4 **TXATIE:** Transmit Attempts Exhausted Interrupt Enable bit 1 = Enable interrupt0 = Disable interrupt bit 3 Unimplemented: Read as '0' bit 2 TXQEIE: Transmit Queue Empty Interrupt Enable bit 1 = Interrupt enabled for Transmit Queue empty 0 = Interrupt disabled for Transmit Queue empty bit 1 Unimplemented: Read as '0' bit 0 TXQNIE: Transmit Queue Not Full Interrupt Enable bit 1 = Interrupt enabled for Transmit Queue not full 0 = Interrupt disabled for Transmit Queue not full Note 1: This bit can only be modified in Configuration mode ((OPMOD<2:0> bits (CFDxCON<23:21>) = 100). 2: This bit is set while in Configuration mode and is automatically cleared in Normal mode. ### REGISTER 26-16: CFDxTXQSTA: TRANSMIT QUEUE STATUS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|-------------------------|------------------------|-------------------|-------------------|--------------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | | 1 | - | _ | - | | _ | | 23:16 | U-0 | 23.10 | _ | | 1 | - | _ | 1 | - | _ | | 15:8 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | 15.6 | _ | | - | | ٦ | TXQCI<4:0> <sup>(1</sup> | ) | | | 7:0 | R-0 | R-0 | R-0 | HS/C-0 | U-0 | R-0 | U-0 | R-0 | | 7:0 | TXABT <sup>(2,3)</sup> | TXLARB <sup>(2,3)</sup> | TXERR <sup>(2,3)</sup> | TXATIF | _ | TXQEIF | _ | TXQNIF | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-13 Unimplemented: Read as '0' bit 12-8 TXQCI<4:0>: Transmit Queue Message Index bits(1) A read of this register will return an index to the message that the FIFO will next attempt to transmit. bit 7 **TXABT:** Message Aborted Status bit<sup>(2,3)</sup> 1 = Message was aborted 0 = Message completed successfully bit 6 **TXLARB:** Message Lost Arbitration Status bit<sup>(2,3)</sup> 1 = Message lost arbitration while being sent 0 = Message did not loose arbitration while being sent bit 5 TXERR: Error Detected During Transmission bit (2,3) 1 = A bus error occurred while the message was being sent 0 = A bus error did not occur while the message was being sent bit 4 **TXATIF:** Transmit Attempts Exhausted Interrupt Pending bit 1 = Interrupt pending 0 = Interrupt Not pending bit 3 **Unimplemented:** Read as '0' bit 2 **TXQEIF:** Transmit Queue Empty Interrupt Flag bit 1 = Transmit Queue is empty 0 = Transmit Queue is not empty, at least one message queued to be transmitted bit 1 Unimplemented: Read as '0' bit 0 TXQNIF: Transmit Queue Not Full Interrupt Flag bit 1 = Transmit Queue is not full 0 = Transmit Queue is full - Note 1: TXQCI<4:0> gives a zero-indexed value to the message in the Transmit Queue. If the Transmit Queue is four messages deep (FSIZE<4:0> bits (CFDxFIFOCONn<28:24>) = 5'h03), TXQCI<4:0> will take on a value of 0 to 3 depending on the state of the Transmit Queue. - 2: This bit is reset on any read of this register or when the Transmit Queue is reset. - 3: This bit is updated when a message completes (or aborts) or when the Transmit Queue is reset. ### REGISTER 26-17: CFDxFIFOCONn: FIFO CONTROL REGISTER ('x' = 1-4; 'n' = 1-31) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|---------------------|-------------------|-----------------------|---------------------------|-------------------|-------------------|------------------|------------------|--| | 24.24 | R/W-0 | | 31:24 | F | PLSIZE<2:0>( | 1) | FSIZE<4:0> <sup>(1)</sup> | | | | | | | 00.40 | U-0 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | _ | TXAT | <1:0> | TXPRI<4:0> | | | | | | | 45.0 | U-0 | U-0 | U-0 | U-0 | U-0 | S, HC-1 | R/W, HC-0 | S, HC-0 | | | 15:8 | _ | _ | _ | _ | _ | FRESET | TXREQ | UINC | | | 7:0 | R/W-0 | | | TXEN <sup>(1)</sup> | RTREN | RXTSEN <sup>(1)</sup> | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 PLSIZE<2:0>: Payload Size bits(1) 111 = 64 data bytes 110 **= 48 data bytes** 101 = 32 data bytes 100 = 24 data bytes 011 **= 20 data bytes** 010 **= 16 data bytes** 001 = 12 data bytes 000 **= 8 data bytes** bit 28-24 **FSIZE<4:0>:** FIFO Size bits<sup>(1)</sup> 11111 = FIFO is 32 Messages deep • 00010 = FIFO is 3 Messages deep 00001 = FIFO is 2 Messages deep 00000 = FIFO is 1 Message deep bit 23 Unimplemented: Read as '0' bit 22-21 TXAT<1:0>: Retransmission Attempts bits This feature is enabled when the RTXAT bit (CFDxCON<8>) is set. 11 = Unlimited number of retransmission attempts 10 = Unlimited number of retransmission attempts 01 = Three retransmission attempts 00 = Disable retransmission attempts **Note:** Application must be able to change this in Normal mode. This can be used to go back on the bus after bus off to check if transmission works again - Note 1: This bit can only be modified in Configuration mode ((OPMOD<2:0> bits (CFDxCON<23:21>) = 100). - 2: FRESET is set while in Configuration mode and is automatically cleared in Normal mode. - 3: This bit is updated when a message completes (or aborts) or when the FIFO is reset. ### REGISTER 26-17: CFDxFIFOCONn: FIFO CONTROL REGISTER ('x' = 1-4; 'n' = 1-31) (CONTINUED) bit 20-16 TXPRI<4:0>: Message Transmit Priority bits (EXPANDED) 11111 = Highest Message Priority • . 00000 = Lowest Message Priority bit 15-11 Unimplemented: Read as '0' bit 10 FRESET: FIFO Reset bit(2) - 1 = FIFO will be reset when bit is set; cleared by hardware when FIFO is reset. User should poll whether this bit is clear before taking any action - 0 = No effect - bit 9 **TXREQ:** Message Send Request bit<sup>(3)</sup> TXEN = 1: (FIFO configured as a Transmit FIFO) - 1 = Requests sending a message; the bit will automatically clear when all the messages queued in the FIFO are successfully sent - 0 = Clearing the bit to '0' while set ('1') will request a message abort. TXEN = 0: (FIFO configured as a Receive FIFO) This bit has no effect. bit 8 **UINC:** Increment Head / Tail bit TXEN = 1: (FIFO configured as a Transmit FIFO) When this bit is set, the FIFO head will increment by a single message TXEN = 0: (FIFO configured as a Receive FIFO) When this bit is set, the FIFO tail will increment by a single message - bit 7 **TXEN:** TX / RX Buffer Selection bit<sup>(1)</sup> - 1 = Transmit Message Object - 0 = Receive Message Object - bit 6 RTREN: Auto RTR Enable bit - 1 = When a remote transmit is received, TXREQ will be set. - 0 = When a remote transmit is received, TXREQ will be unaffected. - bit 5 **RXTSEN:** Received Message Time Stamp Enable bit<sup>(1)</sup> - 1 = Capture time stamp in received message object in RAM. - 0 = Don't capture time stamp. **Note:** Change only in Configuration mode, since it is used for address calculation. - bit 4 **TXATIE:** Transmit Attempts Exhausted Interrupt Enable bit - 1 = Enable interrupt - 0 = Disable interrupt - bit 3 **RXOVIE:** Overflow Interrupt Enable bit - 1 = Interrupt enabled for overflow event - = Interrupt disabled for overflow event - Note 1: This bit can only be modified in Configuration mode ((OPMOD<2:0> bits (CFDxCON<23:21>) = 100). - 2: FRESET is set while in Configuration mode and is automatically cleared in Normal mode. - 3: This bit is updated when a message completes (or aborts) or when the FIFO is reset. ### REGISTER 26-17: CFDxFIFOCONn: FIFO CONTROL REGISTER ('x' = 1-4; 'n' = 1-31) (CONTINUED) bit 2 TFERFFIE: Transmit/Receive FIFO Empty/Full Interrupt Enable bit TXEN = 1: (FIFO configured as a Transmit FIFO) Transmit FIFO Empty Interrupt Enable 1 = Interrupt enabled for FIFO empty 0 = Interrupt disabled for FIFO empty TXEN = 0: (FIFO configured as a Receive FIFO) Receive FIFO Full Interrupt Enable 1 = Interrupt enabled for FIFO full 0 = Interrupt disabled for FIFO full bit 1 TFHRFHIE: Transmit/Receive FIFO Half Empty/Half Full Interrupt Enable bit TXEN = 1: (FIFO configured as a Transmit FIFO) Transmit FIFO Half Empty Interrupt Enable 1 = Interrupt enabled for FIFO half empty 0 = Interrupt disabled for FIFO half empty TXEN = 0: (FIFO configured as a Receive FIFO) Receive FIFO Half Full Interrupt Enable 1 = Interrupt enabled for FIFO half full 0 = Interrupt disabled for FIFO half full bit 0 TFNRFNIE: Transmit/Receive FIFO Not Full/Not Empty Interrupt Enable bit TXEN = 1: (FIFO configured as a Transmit FIFO) Transmit FIFO Not Full Interrupt Enable 1 = Interrupt enabled for FIFO not full 0 = Interrupt disabled for FIFO not full TXEN = 0: (FIFO configured as a Receive FIFO) Receive FIFO Not Empty Interrupt Enable 1 = Interrupt enabled for FIFO not empty 0 = Interrupt disabled for FIFO not empty - Note 1: This bit can only be modified in Configuration mode ((OPMOD<2:0> bits (CFDxCON<23:21>) = 100). - 2: FRESET is set while in Configuration mode and is automatically cleared in Normal mode. - 3: This bit is updated when a message completes (or aborts) or when the FIFO is reset. ### REGISTER 26-18: CFDxTXQSTAn: TRANSMIT QUEUE STATUS REGISTER ('x' = 1-4; 'n' = 1-31) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|------------------------|-------------------------|------------------------|-------------------|-------------------|-------------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 22.40 | U-0 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | 15:8 | _ | _ | _ | | F | IFOCI<4:0> <sup>(</sup> | 1) | | | 7:0 | R-0 | R-0 | R-0 | HS/C-0 | HS/C-0 | R-0 | R-0 | R-0 | | | TXABT <sup>(2,3)</sup> | TXLARB <sup>(2,3)</sup> | TXERR <sup>(2,3)</sup> | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-13 Unimplemented: Read as '0' bit 12-8 FIFOCI<4:0>: FIFO Message Index bits<sup>(1)</sup> TXEN = 1: (FIFO configured as a Transmit Buffer) A read of this register will return an index to the message that the FIFO will next attempt to transmit. TXEN = 0: (FIFO configured as a Receive Buffer) A read of this register will return an index to the message that the FIFO will use to save the next message. bit 7 **TXABT:** Message Aborted Status bit<sup>(2,3)</sup> 1 = Message was aborted 0 = Message completed successfully bit 6 **TXLARB:** Message Lost Arbitration Status bit<sup>(2,3)</sup> 1 = Message lost arbitration while being sent 0 = Message did not loose arbitration while being sent bit 5 **TXERR:** Error Detected During Transmission bit<sup>(2,3)</sup> 1 = A bus error occurred while the message was being sent 0 = A bus error did not occur while the message was being sent bit 4 **TXATIF:** Transmit Attempts Exhausted Interrupt Pending bit TXEN = 1: (FIFO configured as a Transmit Buffer) 1 = Interrupt pending 0 = Interrupt Not pending TXEN = 0: (FIFO configured as a Receive Buffer) Unused, read as '0' bit 3 RXOVIF: Receive FIFO Overflow Interrupt Flag bit TXEN = 1: (FIFO configured as a Transmit Buffer) Unused, read as '0' TXEN = 0: (FIFO configured as a Receive Buffer) 1 = Overflow event has occurred 0 = No overflow event occurred - **Note 1:** FIFOCI<4:0> gives a zero-indexed value to the message in the FIFO. If the FIFO is four messages deep (FSIZE = 5'h03), FIFOCI will take on a value of 0 to 3 depending on the state of the FIFO. - 2: This bit is reset on any read of this register or when the Transmit Queue is reset. - 3: This bit is updated when a message completes (or aborts) or when the FIFO is reset. # REGISTER 26-18: CFDxTXQSTAn: TRANSMIT QUEUE STATUS REGISTER ('x' = 1-4; 'n' = 1-31) (CONTINUED) bit 2 TFERFFIF: Transmit/Receive FIFO Empty/Full Interrupt Flag bit TXEN = 1: (FIFO configured as a Transmit FIFO) Transmit FIFO Empty Interrupt Flag 1 = FIFO is empty 0 = FIFO is not empty, at least 1 message queued to be transmitted TXEN = 0: (FIFO configured as a Receive FIFO) Receive FIFO Full Interrupt Flag 1 = FIFO is full 0 = FIFO is not full bit 1 TFHRFHIF: Transmit/Receive FIFO Half Empty/Half Full Interrupt Flag bit TXEN = 1: (FIFO configured as a Transmit FIFO) Transmit FIFO Half Empty Interrupt Flag 1 = FIFO is less than or equal to half full 0 = FIFO is greater than half full TXEN = 0: (FIFO configured as a Receive FIFO) Receive FIFO Half Full Interrupt Flag 1 = FIFO is greater than or equal to half full 0 = FIFO is less than half full bit 0 TFNRFNIF: Transmit/Receive FIFO Not Full/Not Empty Interrupt Flag bit TXEN = 1: (FIFO configured as a Transmit FIFO) Transmit FIFO Not Full Interrupt Flag 1 = FIFO is not full 0 = FIFO is full TXEN = 0: (FIFO configured as a Receive FIFO) Receive FIFO Not Empty Interrupt Flag 1 = FIFO is not empty (has at least one message) 0 = FIFO is empty - **Note 1:** FIFOCI<4:0> gives a zero-indexed value to the message in the FIFO. If the FIFO is four messages deep (FSIZE = 5'h03), FIFOCI will take on a value of 0 to 3 depending on the state of the FIFO. - 2: This bit is reset on any read of this register or when the Transmit Queue is reset. - 3: This bit is updated when a message completes (or aborts) or when the FIFO is reset. #### REGISTER 26-19: CFDxTEFCON: TRANSMIT EVENT FIFO CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|------------------------|---------------------------|-------------------|-------------------|------------------|------------------|--| | 24.24 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 31:24 | _ | _ | _ | FSIZE<4:0> <sup>(1)</sup> | | | | | | | 22.40 | U-0 | | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | | 45.0 | U-0 | U-0 | U-0 | U-0 | U-0 | S, HC-1 | U-0 | S, HC-0 | | | 15:8 | _ | _ | _ | _ | _ | FRESET | _ | UINC | | | 7:0 | U-0 | U-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | _ | _ | TEFTSEN <sup>(1)</sup> | _ | TEFOVIE | TEFFIE | TEFHIE | TEFNEIE | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 Unimplemented: Read as '0' bit 28-24 **FSIZE<4:0>:** FIFO Size bits<sup>(1)</sup> 11111 = FIFO is 32 Messages deep : 00010 = FIFO is 3 Messages deep 00001 = FIFO is 2 Messages deep 00000 = FIFO is 1 Message deep bit 23-11 Unimplemented: Read as '0' bit 10 FRESET: FIFO Reset bit 1 = FIFO will be reset when bit is set, cleared by hardware when FIFO is reset. The user should poll this bit is clear before taking any action 0 = No effect bit 9 **Unimplemented:** Read as '0' bit 8 UINC: Increment Tail bit When this bit is set the FIFO tail will increment by a single message bit 7-6 **Unimplemented:** Read as '0' bit 5 **TEFTSEN:** Transmit Event FIFO Time Stamp Enable bit<sup>(1)</sup> 1 = Time stamp elements in TEF 0 = Do not time stamp elements in TEF bit 4 Unimplemented: Read as '0' bit 3 **TEFOVIE:** Transmit Event FIFO Overflow Interrupt Enable bit 1 = Interrupt enabled for overflow event 0 = Interrupt disabled for overflow event bit 2 **TEFFIE:** Transmit Event FIFO Full Interrupt Enable bit 1 = Interrupt enabled for FIFO full 0 = Interrupt disabled for FIFO full bit 1 **TEFHIE:** Transmit Event FIFO Half Full Interrupt Enable bit 1 = Interrupt enabled for FIFO half full 0 = Interrupt disabled for FIFO half full bit 0 **TEFNEIE:** Transmit Event FIFO Not Empty Interrupt Enable bit 1 = Interrupt enabled for FIFO not empty 0 = Interrupt disabled for FIFO not empty Note 1: These bits can only be modified in Configuration mode (OPMOD<2:0> bits (CFDxCON<23:21>) = 100). ### REGISTER 26-20: CFDxTEFSTA: TRANSMIT EVENT FIFO STATUS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-----------------------|-----------------------|------------------------| | 31:24 | U-0 | 31.24 | _ | | | _ | - | _ | _ | _ | | 22.16 | U-0 | 23:16 | _ | | | _ | | _ | _ | _ | | 45.0 | U-0 | 15:8 | _ | | _ | _ | _ | _ | _ | _ | | 7:0 | U-0 | U-0 | U-0 | U-0 | HS, C-0 | R-0 | R-0 | R-0 | | | _ | _ | _ | _ | TEFOVIF | TEFFIF <sup>(1)</sup> | TEFHIF <sup>(1)</sup> | TEFNEIF <sup>(1)</sup> | Legend:C = Clearable bitHS = Set by hardwareR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-4 Unimplemented: Read as '0' bit 3 **TEFOVIF:** Transmit Event FIFO Overflow Interrupt Flag bit 1 = Overflow event has occurred0 = No overflow event has occurred bit 2 **TEFFIF:** Transmit Event FIFO Full Interrupt Flag bit<sup>(1)</sup> 1 = FIFO is full 0 = FIFO is not full bit 1 **TEFHIF:** Transmit Event FIFO Half Full Interrupt Flag bit<sup>(1)</sup> 1 = FIFO is greater than or equal to half full 0 = FIFO is less than half full bit 0 **TEFNEIF:** Transmit Event FIFO Not Empty Interrupt Flag bit<sup>(1)</sup> 1 = FIFO is not empty (has at least one message) 0 = FIFO is empty Note 1: This bit is read0only and reflects the status of the FIFO. ### REGISTER 26-21: CFDxFIFOUAn: DEFINITION REGISTER ('x' = 1-4; 'n' = 1-31) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 31:24 | R-x | | | 31.24 | FIFOUA<31:24> | | | | | | | | | | | 22,16 | R-x | | | 23:16 | FIFOUA<23:16> | | | | | | | | | | | 15:8 | R-x | | | 15.6 | FIFOUA<15:8> | | | | | | | | | | | 7:0 | R-x | | | | | FIFOUA<7:0> | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 FIFOUA<31:0>: FIFO User Address bits TXEN = 1: (FIFO configured as a Transmit Buffer) A read of this register will return the address where the next message is to be written (FIFO head). TXEN = 0: (FIFO configured as a Receive Buffer) A read of this register will return the address where the next message is to be read (FIFO tail). - **Note 1:** This register is not guaranteed to read correctly in Configuration Mode and should only be accessed when the module is *not* in Configuration Mode. - 2: This register provides the byte address in the message memory of the next element in the FIFO. The application uses this address directly to access RAM. - For a RX FIFO, the address points to the next element the application should read from - For a TX FIFO, the address points to the next element, the application should write to After accessing this register, the user application must set the UINC bit in the CFDxFIFOCONn register, which will update the FIFO pointer. ### REGISTER 26-22: CFDxTEFUA: TRANSMIT EVENT FIFO USER ADDRESS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R-x | | | 31:24 | TEFUA<31:24> | | | | | | | | | | | 22,46 | R-x | | | 23:16 | TEFUA<23:16> | | | | | | | | | | | 45.0 | R-x | | | 15:8 | TEFUA<15:8> | | | | | | | | | | | 7:0 | R-x | | | | | | | TEFU | A<7:0> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 TEFUA<31:0>: Transmit Event FIFO User Address bits A read of this register will return the address where the next event is to be read (FIFO tail). - **Note 1:** This register is not guaranteed to read correctly in Configuration Mode and should only be accessed when the module is *not* in Configuration Mode. - 2: Elements in the Transmit Event FIFO can be accessed through this register. The register provides the byte address in the message memory of the next element in the buffer. The application uses this address directly to access RAM. The address points to the next element the application should read from. After accessing this register, the user application must set the UINC bit in the CFDxTEFCON register, which will update the FIFO pointer. ### REGISTER 26-23: CFDxTXQUA: TRANSMIT QUEUE USER ADDRESS REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R-x | | | 31:24 | TXQUA<31:24> | | | | | | | | | | | 00:40 | R-x | | | 23:16 | TXQUA<23:16> | | | | | | | | | | | 45.0 | R-x | | | 15:8 | TXQUA<15:8> | | | | | | | | | | | 7:0 | R-x | | | | TXQUA<7:0> | | | | | | | | | | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 TXQUA<31:0>: Transmit Queue User Address bits A read of this register will return the address where the next message is to be written (Transmit Queue head). - **Note 1:** This register is not guaranteed to read correctly in Configuration Mode and should only be accessed when the module is *not* in Configuration Mode. - 2: Elements in the Transmit Queue can be accessed through this register. The register provides the byte address in the message memory of the next element in the Transmit Queue. The application uses this address directly to access RAM. The address points to the next element, the application should write to. After accessing this register, the user application must set the UINC bit in the CFDxTXQCON register, which will update the TXQ pointer. #### REGISTER 26-24: CFDxTREC: TRANSMIT/RECEIVE ERROR COUNT REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | - | _ | | _ | _ | _ | | 00.40 | U-0 | U-0 | R-1 | R-0 | R-0 | R-0 | R-0 | R-0 | | 23:16 | _ | _ | TXBO | TXBP | RXBP | TXWARN | RXWARN | EWARN | | 45.0 | R-0 | 15:8 | TERRCNT<7:0> | | | | | | | | | 7:0 | R-0 | 7:0 | | | | RERRC | NT<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-22 Unimplemented: Read as '0' bit 21 TXBO: Transmitter in Error State Bus Off bit (TERRCNT > 255) In Configuration mode, TXBO is set, since the CAN FD module is not on the bus. - 1 = Indicates that the number of transmit errors is greater than 255. As a result, the CAN FD module will automatically enter Bus Off mode. - 0 = Indicates that transmit errors are less than 255 - bit 20 **TXBP:** Transmitter in Error State Bus Passive bit (TERRCNT > 127) - 1 = Indicates that the number of transmit errors is greater than 127. As a result, the CAN FD module will automatically enter Bus Passive mode. - 0 = Indicates that transmit errors are less than or equal to 127 - bit 19 RXBP: Receiver in Error State Bus Passive bit (RERRCNT > 127) - 1 = Indicates that the number of receive errors is greater than 127. As a result, the CAN FD module will automatically enter Bus Passive mode. - 0 = Indicates that transmit errors are less than or equal to 127 - bit 18 **TXWARN:** Transmitter in Error State Warning bit (128 > TERRCNT > 95) - 1 = Indicates that the number of transmit errors are less than 128, but are greater than 95. - 0 = Indicates that transmit errors are greater than or equal to 95 - bit 17 RXWARN: Receiver in Error State Warning bit (128 > RERRCNT > 95) - 1 = Indicates that the number of receives errors is less than 128, but are greater than 95. - 0 = Indicates that receive errors are greater than or equal to 95 - bit 16 **EWARN:** Transmitter or Receiver is in Error State Warning bit - 1 = TXWARN or RXWARN is set - 0 = No transmit or receive warnings Note: Separate error counters for arbitration and data phase; receive and transmit: - · Successful message counter - Keep track of received ESI, (Error State Indicator) #### REGISTER 26-24: CFDxTREC: TRANSMIT/RECEIVE ERROR COUNT REGISTER ('x' = 1-4) bit 15-8 **TERRCNT<7:0>:** Transmit Error Counter bits 11111111 = Greater than or equal to 255 Transmit errors. The TXBO bit is equal to '1' if the TERRCNT<7:0> bits are greater than 255. 11111110 = 254 Transmit errors • • 00000001 = 1 transmit error 00000000 = No transmit errors **Note:** The following conditions apply: - If 128 > TERRCNT > 95, the TXWARN bit = 1 - If TERRCNT > 95, the TXBP bit = 1 and TX enters Bus Passive mode - If TERRCNT > 255, the TXBO and CERRIF bits are set and the CAN FD module enters Bus Off mode and starts the Bus Off recovery sequence #### bit 7-0 RERRCNT<7:0>: Receive Error Counter bits 111111111 = Greater than or equal to 255 Receive errors 11111110 = 254 receive errors • ٠ 00000001 = 1 receive error 00000000 = No receive errors Note: The following conditions apply: - If RERRCNT > 127, the RXBP bit = 1 - If 128 > RERRCNT > 95, the RXWARN bit = 1 Note: Separate error counters for arbitration and data phase; receive and transmit: - · Successful message counter - · Keep track of received ESI, (Error State Indicator) ### REGISTER 26-25: CFDxBDIAG0: BUS DIAGNOSTICS REGISTER 0 ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|--------------------|--|--|--| | 31:24 | R/W-0 | | | | 31.24 | | | | DTERRO | NT<7:0> | | | 5/17/9/1 24/16/8/0 | | | | | 00.46 | R/W-0 | | | | 23:16 | DRERRCNT<7:0> | | | | | | | | | | | | 45.0 | R/W-0 | | | | 15:8 | NTERRCNT<7:0> | | | | | | | | | | | | 7.0 | R/W-0 | | | | 7:0 | | | | NRERRO | NT<7:0> | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-24 **DTERRCNT<7:0>:** Data Bit Rate Transmit Error Counter bits bit 23-16 **DRERRCNT<7:0>:** Data Bit Rate Receive Error Counter bits bit 15-8 **NTERRCNT<7:0>:** Nominal Bit Rate Transmit Error Counter bits bit 7-0 NRERRCNT<7:0>: Nominal Bit Rate Receive Error Counter bits **Note:** This register keeps track of bus errors during nominal and data bit rate phases, separately. These counters work differently than in the CFDxTREC register: - · Counters are incremented (+1) on any bus error - · Counters are not decremented - · Counters are cleared on a register read #### REGISTER 26-26: CFDxBDIAG1: BUS DIAGNOSTICS REGISTER 1 ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|---------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | | 31.24 | DLCMM | ESI | DCRCERR | DSTUFERR | DFORMERR | - | DBIT1ERR | DBIT0ERR | | 22,16 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | TXBOERR | - | NCRCERR | NSTUFERR | NFORMERR | NACKERR | NBIT1ERR | NBIT0ERR | | 45.0 | R/W-0 | 15.8 | 15:8 EFMSGCNT<15:8> | | | | | | | | | 7.0 | R/W-0 | 7:0 | | | | EFMSG | CNT<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 DLCMM: Data Length Code (DLC) Mismatch Status bit 1 = Payload size error. During a transmission or reception the Data Length Code exceeds the payload size of the FIFO element defined in the PLSIZE<2:0> bits (CFDxFIFOCONn<31:29>). 0 = No payload size error occurred bit 30 ESI: Error State Indicator (ESI) Flag Status bit 1 = ESI flag of a received CAN FD message was set 0 = ESI flag of a received CAN FD message was not set bit 29 DCRCERR: Data CRC Error Status bit 1 = CRC checksum of a received message was incorrect. The CRC of an incoming message does not match with the CRC calculated from the received data 0 = No received message data CRC error occurred bit 28 **DSTUFERR:** Data Stuffing Error Status bit 1 = More than five equal bits in a sequence have occurred in a portion of a received message where this is not allowed 0 = No data received message errors bit 27 **DFORMERR:** Data Format Error Status bit 1 = Data fixed format portion of a received frame has the wrong format 0 = No format errors occurred bit 26 Unimplemented: Read as '0' bit 25 **DBIT1ERR:** Data Bit Logical '1' Error Status bit 1 = During the data transmission of a message (with the exception of the arbitration field), the device wanted to send a recessive level (bit of logical value '1'), but the monitored bus value was dominant. 0 = No data logical '1' bit transmission error occurred **Note:** This register shows the type of errors that occurred since the last read. Corresponding bits are set when an error occurs, but *all* bits are cleared on any read or R-M-W bit manipulation instruction. Errors are separately tracked for data and nominal bit rate phases. The Error Free Message Counter bits (EFMSGCNT<15:0>), together with the Error Counters and the Error Flags can be used to determine the quality of the bus. ### REGISTER 26-26: CFDxBDIAG1: BUS DIAGNOSTICS REGISTER 1 ('x' = 1-4) (CONTINUED) - bit 24 DBIT0ERR: Data Bit Logical '0' Error Status bit - 1 = During the data transmission of a message (or acknowledge bit, or active error flag, or overload flag), the device wanted to send a dominant level (data or identifier bit logical value '0'), but the monitored bus value was recessive. During Bus Off recovery, this status is set each time a sequence of 11 recessive bits has been monitored. This enables the CPU to monitor the proceeding of the Bus Off recovery sequence (indicating the bus is not stuck at dominant or continuously disturbed). - 0 = No data logical '0' bit transmission error occurred - bit 23 TXBOERR: Transmit Bus Off Error Status bit - 1 = Transmit error occurred and device enter Bus Off mode and automatically recovered - 0 = No transmit Bus Off error occurred - bit 22 **Unimplemented:** Read as '0' - bit 21 NCRCERR: Nominal CRC Error Status bit - 1 = The CRC checksum of a nominal received message was incorrect. The CRC of an incoming nominal message does not match with the CRC calculated from the received data. - 0 = No nominal CRC received message error occurred - bit 20 NSTUFERR: Nominal Stuffing Error Status bit - 1 = More than five equal bits in a sequence have occurred in a part of a nominal received message where this is not allowed - 0 = No nominal bit stuffing errors have occurred - bit 19 **NFORMERR:** Nominal Format Error Status bit - 1 = A fixed format portion of a nominal received frame has the wrong format - 0 = No nominal format error occurred - bit 18 NACKERR: Not Acknowledged Error Status bit - 1 = A transmitted message was not acknowledged - 0 = A transmitted message was acknowledged - bit 17 **NBIT1ERR:** Nominal Bit Logical '1' Error Status bit - 1 = During the transmission of a nominal message (with the exception of the arbitration field), the device wanted to send a recessive level (bit of logical value '1'), but the monitored bus value was dominant - 0 = No nominal bit logical '1' error occurred - bit 16 NBIT0ERR: Nominal Bit Logical '0' Error Status bit - 1 = During the transmission of a nominal message (or acknowledge bit, or active error flag, or overload flag), the device wanted to send a dominant level (data or identifier bit logical value '0'), but the monitored bus value was recessive. During Bus Off recovery, this status is set each time a sequence of 11 recessive bits has been monitored. This enables the CPU to monitor the proceeding of the Bus Off recovery sequence (indicating the bus is not stuck at dominant or continuously disturbed). - 0 = No nominal bit logical '0' error occurred - bit 15-0 **EFMSGCNT<15:0>:** Error Free Message Counter Status bits 111111111111111 = 65,536 error free messages since the last register read - • - • - 0000000000000000 = 0 error free messages since the last register read **Note:** The EFMSGCNT<15:0> bits increment on any error free message on the bus. These bits are cleared on any read of this register. **Note:** This register shows the type of errors that occurred since the last read. Corresponding bits are set when an error occurs, but *all* bits are cleared on any read or R-M-W bit manipulation instruction. Errors are separately tracked for data and nominal bit rate phases. The Error Free Message Counter bits (EFMSGCNT<15:0>), together with the Error Counters and the Error Flags can be used to determine the quality of the bus. #### REGISTER 26-27: CFDxFLTCON0: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|--------------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | FLTEN3 | | | F3BP<4:0> <sup>(1)</sup> | | | | | | | | 22:46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | FLTEN2 | _ | _ | F2BP<4:0> <sup>(1)</sup> | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | FLTEN1 | | _ | F1BP<4:0> <sup>(1)</sup> | | | | | | | | 7.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | FLTEN0 | _ | _ | F0BP<4:0> <sup>(1)</sup> | | | | | | | ``` Legend: ``` R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31 FLTEN3: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F3BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 23 FLTEN2: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 22-21 Unimplemented: Read as '0' bit 20-16 F2P<4:0>: Pointer to Object when Filter 'n' hits bits(1) 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 ``` 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 15 FLTEN1 Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled0 = Filter is disabled bit 14-13 Unimplemented: Read as '0' #### REGISTER 26-27: CFDxFLTCON0: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F1BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN0: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F0BP<4:0>: Pointer to Object when Filter 'n' hits bits (1) bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` #### REGISTER 26-28: CFDxFLTCON1: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|--------------------------|-------------------|--------------------------|------------------|------------------|--|--| | 24.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | FLTEN7 | - | _ | F7BP<4:0> <sup>(1)</sup> | | | | | | | | 22,46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | FLTEN6 | - | _ | F6BP<4:0> <sup>(1)</sup> | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | FLTEN5 | - | _ | | | F5BP<4:0> <sup>(1)</sup> | | | | | | 7:0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | FLTEN4 | | _ | F4BP<4:0> <sup>(1)</sup> | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31 FLTEN7: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F7BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 23 FLTEN6: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 22-21 Unimplemented: Read as '0' bit 20-16 F6P<4:0>: Pointer to Object when Filter 'n' hits bits(1) 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 ``` 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 **FLTEN5** Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 14-13 Unimplemented: Read as '0' Note 1: These bits can only be modified if the corresponding filter is disabled (FLTENx bits (CFDxFLTCONn) = 0). bit 15 #### REGISTER 26-28: CFDxFLTCON1: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F5BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN4: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F4BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` #### REGISTER 26-29: CFDxFLTCON2: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|---------------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | FLTEN11 | _ | _ | F11BP<4:0> <sup>(1)</sup> | | | | | | | | 22,46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | FLTEN10 | _ | _ | F10BP<4:0> <sup>(1)</sup> | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | FLTEN9 | _ | _ | F9BP<4:0> <sup>(1)</sup> | | | | | | | | 7.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | FLTEN8 | _ | _ | F8BP<4:0> <sup>(1)</sup> | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31 FLTEN11: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F11BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 23 FLTEN10: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 22-21 Unimplemented: Read as '0' bit 20-16 F10P<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 ``` 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 15 FLTEN9 Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled0 = Filter is disabled bit 14-13 Unimplemented: Read as '0' #### REGISTER 26-29: CFDxFLTCON2: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F9BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN8: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F8BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` #### REGISTER 26-30: CFDxFLTCON3: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|---------------------------|---------------------------|-------------------|------------------|------------------|--|--| | 24.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | FLTEN15 | _ | _ | F15BP<4:0> <sup>(1)</sup> | | | | | | | | 22,46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | FLTEN4 | _ | _ | F14BP<4:0> <sup>(1)</sup> | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | FLTEN13 | _ | _ | F13BP<4:0> <sup>(1)</sup> | | | | | | | | 7.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | FLTEN12 | _ | _ | | F12BP<4:0> <sup>(1)</sup> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31 FLTEN15: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F15BP<4:0>: Pointer to Object when Filter 'n' hits bits (1) 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 23 FLTEN14: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 22-21 Unimplemented: Read as '0' bit 20-16 F14P<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 ``` bit 15 **FLTEN13** Enable Filter 'n' to Accept Messages bits 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. 1 = Filter is enabled 0 = Filter is disabled bit 14-13 Unimplemented: Read as '0' ### REGISTER 26-30: CFDxFLTCON3: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F13BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN12: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F12BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` #### REGISTER 26-31: CFDxFLTCON4: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|---------------------------|-------------------|-------------------|------------------|------------------|--|--| | 21.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | FLTEN19 | _ | _ | F19BP<4:0> <sup>(1)</sup> | | | | | | | | 22,46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | FLTEN18 | _ | _ | F18BP<4:0> <sup>(1)</sup> | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | FLTEN17 | _ | _ | F17BP<4:0> <sup>(1)</sup> | | | | | | | | 7.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | FLTEN16 | _ | _ | F16BP<4:0> <sup>(1)</sup> | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31 FLTEN19: Enable Filter 'n' to Accept Messages bits ``` 1 = Filter is enabled 0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F19BP<4:0>: Pointer to Object when Filter 'n' hits bits (1) 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 • 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. #### bit 23 FLTEN18: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled #### bit 22-21 Unimplemented: Read as '0' bit 20-16 **F18P<4:0>:** Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 : . 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. #### bit 15 FLTEN17 Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled #### bit 14-13 Unimplemented: Read as '0' #### REGISTER 26-31: CFDxFLTCON4: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F17BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN16: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F16BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` #### REGISTER 26-32: CFDxFLTCON5: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|---------------------------|-------------------|-------------------|------------------|------------------|--|--| | 21.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | FLTEN23 | _ | _ | F23BP<4:0> <sup>(1)</sup> | | | | | | | | 22,46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | FLTEN22 | _ | _ | F22BP<4:0> <sup>(1)</sup> | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | FLTEN21 | _ | _ | F21BP<4:0> <sup>(1)</sup> | | | | | | | | 7.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | FLTEN20 | _ | _ | F20BP<4:0> <sup>(1)</sup> | | | | | | | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is ``` bit 31 FLTEN23: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F23BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 23 FLTEN22: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 22-21 Unimplemented: Read as '0' bit 20-16 F22P<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 15 FLTEN21 Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled ``` Note 1: These bits can only be modified if the corresponding filter is disabled (FLTENx bits (CFDxFLTCONn) = 0). 0 = Filter is disabled bit 14-13 **Unimplemented:** Read as '0' Legend: x = Bit is unknown #### REGISTER 26-32: CFDxFLTCON5: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F21BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN20: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F20BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` #### REGISTER 26-33: CFDxFLTCON6: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|---------------------------|-------------------|-------------------------|------------------|------------------|--|--| | 21.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 31:24 | FLTEN27 | - | _ | F27BP<4:0> <sup>(1)</sup> | | | | | | | | 22,46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 23:16 | FLTEN26 | - | _ | F26BP<4:0> <sup>(1)</sup> | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 15:8 | FLTEN25 | - | _ | F25BP<4:0> <sup>(1)</sup> | | | | | | | | 7.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | 7:0 | FLTEN24 | | _ | | F | 24BP<4:0> <sup>(1</sup> | ) | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ``` bit 31 FLTEN27: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F27P<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 23 FLTEN26: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 22-21 Unimplemented: Read as '0' bit 20-16 F25P<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 ``` 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 15 **FLTEN25** Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 14-13 Unimplemented: Read as '0' #### REGISTER 26-33: CFDxFLTCON6: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F25BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN24: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F24BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` ### REGISTER 26-34: CFDxFLTCON7: FILTER CONTROL REGISTER ('x' = 1-4) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |--------------|-------------------|-------------------|-------------------|---------------------------|-------------------|-------------------|------------------|------------------|--| | 24.24 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 31:24 | FLTEN31 | _ | _ | F31BP<4:0> <sup>(1)</sup> | | | | | | | 22:46 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | FLTEN30 | _ | _ | F30BP<4:0> <sup>(1)</sup> | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 15:8 | FLTEN29 | _ | _ | F29BP<4:0> <sup>(1)</sup> | | | | | | | 7.0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 7:0 | FLTEN28 | _ | | F28BP<4:0> <sup>(1)</sup> | | | | | | R = Readable bit W = Writable bit -n = Value at POR '1' = Bit is set '1' = Bit is set '0' = Bit is cleared x = Bit is unknown U = Unimplemented bit, read as '0' bit 31 **FLTEN31:** Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled0 = Filter is disabled bit 30-29 Unimplemented: Read as '0' bit 28-24 F31BP<4:0>: Pointer to Object when Filter 'n' hits bits(1) 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 • Legend: 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 23 FLTEN30: Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 22-21 Unimplemented: Read as '0' bit 20-16 **F30P<4:0>:** Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 • 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 15 FLTEN29 Enable Filter 'n' to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 14-13 Unimplemented: Read as '0' #### REGISTER 26-34: CFDxFLTCON7: FILTER CONTROL REGISTER ('x' = 1-4) (CONTINUED) ``` bit 12-8 F29BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. bit 7 FLTEN28: Enable Filter n to Accept Messages bits 1 = Filter is enabled 0 = Filter is disabled bit 6-5 Unimplemented: Read as '0' F28BP<4:0>: Pointer to Object when Filter 'n' hits bits<sup>(1)</sup> bit 4-0 11111 = Message matching filter is stored in Object 31 11110 = Message matching filter is stored in Object 30 00010 = Message matching filter is stored in Object 2 00001 = Message matching filter is stored in Object 1 00000 = Reserved. Object 0 is the TX Queue and cannot receive messages. ``` #### REGISTER 26-35: CFDxFLTOBJn: FILTER OBJECT REGISTER ('x' = 1-4; 'n' = 0-31) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | U-0 | R/W-0 | | | 31:24 | _ | EXIDE | SID11 | EID<17:13> | | | | | | | | 22,46 | R/W-0 | | | 23:16 | EID<12:5> | | | | | | | | | | | 45.0 | R/W-0 | | | 15:8 | EID<4:0> | | | | | SID<10:8> | | | | | | 7.0 | R/W-0 | | | 7:0 | | | | SID< | 7:0> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 Unimplemented: Read as '0' bit 30 **EXIDE:** Extended Identifier Enable bit If MIDE = 1: 1 = Match only messages with extended identifier addresses 0 = Match only messages with standard identifier addresses bit 29 SID11: Standard Identifier Filter bit 1 = Extended standard identifier to 12-bit (i.e., SID<11:0>) 0 = Do not use extended standard Identifier bits **Note:** Standard identifier filter bit RRS in the CAN FD base frame can be used to extend the SID to 12-bit. When enabled, it is referred to as SID11, which is the MSB of SID<11:0>. bit 28-11 EID<17:0>: Extended Identifier Filter bits In DeviceNet<sup>™</sup> mode, these are the filter bits used in conjunction with the Device Net Filter Bit Number bits, DNCNT<4:0> (CFDxCON<4:0>). bit 10-0 SID<10:0>: Standard Identifier filter bits These are the standard ID message filter bits. Note: This register can only be changed when the filter is disabled (FLTENx bits (CFDxFLTCONn) = 0). #### REGISTER 26-36: CFDxMASKn: MASK REGISTER ('x' = 1-4; 'n' = 0-31) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | R/W-0 | | _ | MIDE | MSID11 | MEID<17:13> | | | | | | 23:16 | R/W-0 | | MEID<12:5> | | | | | | | | | 15:8 | R/W-0 | | MEID<4:0> | | | | MSID<10:8> | | | | | 7:0 | R/W-0 | | MSID<7:0> | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 Unimplemented: Read as '0' bit 30 MIDE: Identifier Receive Mode bit 1 = Match only message types (standard or extended address) that correspond to EXIDE bit in filter 0 = Match either standard or extended address message if filters match (i.e., if (Filter SID) = (Message SID) or if (Filter SID/EID) = (Message SID/EID)) bit 29 MSID11: Standard Identifier Mask bit 1 = Enable extended standard identifier mask to 12 bits (MSID<10:0>, MEID<0>) 0 = Do not enable extended standard identifier mask (MSID<10:0>) bit 28-11 MEID<17:0>: Extended Identifier Mask bits In DeviceNet™ mode, these are the mask bits for the extended CAN ID, which are the first two data bytes. bit 10-0 MSID<10:0>: Standard Identifier Mask bits These are the standard CAN message identifier mask bits. Note: This register can only be changed when the filter is disabled (FLTENx bits (CFDxFLTCONn = 0). | | | anniy | | |--------|--|-------|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 27.0 OP AMP/COMPARATOR MODULE Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 39. "Op amp/Comparator"** (DS60001178), which is available from the *Documentation > Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). Depending on the device, the op amp/Comparator module consists of a Comparator and Op amp modules. When available, the Op amps can be independently enabled or disabled from the Comparator. The following are key features of the Comparator include: - · Differential inputs - · Rail-to-rail operation - · Selectable output and trigger event polarity - Selectable inputs: - Analog inputs multiplexed with I/O pins - On-chip internal voltage reference via a 12-bit CDAC output or an external pin - Output debounce or Digital noise filter with these selectable clocks: - Peripheral Bus Clock (PBCLK2) - System Clock (SYSCLK) - Reference Clock 3 (REFCLK3) - PBCLK2/Timer PRx ('x' = 2-5) - PWM Secondary Special Event - Outputs can be internally configured as trigger sources The following are key features of the op amps: - Inverting and non-inverting Inputs and output accessible on pins - Rail-to-rail operation (3V ≤ AVDD ≤ 3.6V) - Internal connection to ADC Sample and Hold circuits/SAR cores - Special voltage follower mode for buffering signals - · Low-Power mode - 10 mA IOL/IOH (Sink/Source) Refer to the PIC32MK GP Family Features in TABLE 1: "PIC32MK General Purpose (GP) Family Features" for the actual number of available Op amp/Comparator modules on your specific device. Block diagrams of the Op amp/Comparator module are illustrated in Figure 27-1 through Figure 27-5. Note: The op amps are disabled by default (ithat is, OPAxMD bit in the PMD2 register is equal to '1') on any Reset. Before using or accessing any corresponding op amp, ensure that the OPAxMD bit is equal to '0'. FIGURE 27-1: OP AMP 1/COMPARATOR 1 MODULE BLOCK DIAGRAM PIC32MK GPK/MCM with CAN FD - Note 1: Refer to the device pin tables (Table 3 and Table 5) for other analog inputs that may be also be connected to the Op amp and Comparator inputs. - 2: The PWM Blank Function is available only on PIC32MKXXMCXXX devices. - 3: Caution: To avoid false comparator output faults or glitches when using the internal DAC as a comparator reference, always initialize the DAC before initializing and enabling the comparator. - Note 1: Refer to the device pin tables (Table 3 and Table 5) for other analog inputs that may be also be connected to the Op amp and Comparator inputs. - 2: The PWM Blank Function is available only on PIC32MKXXMCXXX devices. - 3: Caution: To avoid false comparator output faults or glitches when using the internal DAC as a comparator reference, always initialize the DAC before initializing and enabling the comparator. **FIGURE 27-3:** OP AMP 3/COMPARATOR 3 MODULE BLOCK DIAGRAM PIC32MK GPK/MCM with - Refer to the device pin tables (Table 3 and Table 5) for other analog inputs that may be also be connected to the Op amp and Comparator inputs. - The PWM Blank Function is only available on PIC32MKXXMCXXX devices. - Caution: To avoid false comparator output faults or glitches when using the internal DAC as a comparator reference, always initialize the DAC before initializing and enabling the comparator. #### FIGURE 27-4: COMPARATOR 4 MODULE BLOCK DIAGRAM - Note 1: Refer to the device pin tables (Table 3 and Table 5) for other analog inputs that may be also be connected to the Op amp and Comparator inputs. - 2: The PWM Blank Function is only available on PIC32MKXXMCXXX devices. - 3: Caution: To avoid false comparator output faults or glitches when using the internal DAC as a comparator reference, always initialize the DAC before initializing and enabling the comparator. FIGURE 27-5: OP AMP 5/COMPARATOR 5 MODULE BLOCK DIAGRAM - Note 1: Refer to the device pin tables (Table 3 and Table 5) for other analog inputs that may be also be connected to the Op amp and Comparator inputs. - The PWM Blank Function is only available on PIC32MKXXMCXXX devices. - 3: Caution: To avoid false comparator output faults or glitches when using the internal DAC as a comparator reference, always initialize the DAC before initializing and enabling the comparator. ### 27.1 Op amp Interface PIC32MK GP devices implement a total of five comparators and four Op amps. The Op amp Comparator module 4 does not implement the associated Op amp. The Op amp can be configured to operate in two different modes: Regular Op amp mode and Unity Gain mode. When an Op amp is available on a Op amp/Comparator module, both of its inputs and output are accessible at the device pins. The Op amp's Unity Gain mode is the only exception to this rule, which is described in **Section 27.6 "Op amp Unity Gain Mode"**. The op amp is disabled at reset and has to be enabled by writing a '1' to CMxCON<OPAON>, (that is (CMxCON<31>). The op amp outputs are capable of rail-to-rail operation, which are limited by the maximum output load current. Refer to **37.0** "Electrical Characteristics" for the op amp minimum gain requirements and VOH/VOL loading specifications. **Note:** The exception to the minimum gain specification is the special internal Unity Gain buffer mode. Table 27-1 provides the different SFR bits and their logic states to set the op amp in two different modes of operation. TABLE 27-1: OP AMP(X) FUNCTIONAL MODES (X=1-3, 5) | Op-Amp Functional Mode | CMxCON <opaon></opaon> | CMxCON <enpga></enpga> | CMxCON <oplpwr></oplpwr> | |-------------------------------------------|------------------------|------------------------|--------------------------| | High-Performance Mode > 10 MHz,Gain ≥ 2 | 1 | 0 | 0 | | High-Performance Unity Gain Mode > 10 MHz | 1 | 1 | 0 | | Low-Power Mode ≤ 10 MHz.,Gain ≥ 2 | 1 | 0 | 1 | | Low-Power Unity Gain Mode ≤ 10 MHz | 1 | 1 | 1 | | Op-amp output Tri-Stated | 0 | Х | X | #### 27.2 Comparator Interface The Comparators also have both their inverting and non-inverting inputs accessible via device pins. The non-inverting input pins can be connected to an internal 12-bit CDAC to generate a precise reference or to an external reference through a pin. These references can be individually selected for each comparator module. The inverting inputs can be connected to one of four external pins or internally to outputs of the Op amps. The Comparator outputs can be entirely disabled from appearing on the output pins, which relieves a pin for other uses, remapped to different pins via the peripheral pin select module, and selected to active-high or active-low polarity. In Comparator modules that do not implement the Op amp, the Comparator module has a different input selection configuration. The stand-alone Comparator implements a 4 $\times$ 1 multiplexer at the inverting input to enable selection of the desired signal to compare against the non-inverting input. Up to three outputs of Op amps can be internally connected to the Comparator via the multiplexer. The Comparator may be enabled or disabled using the corresponding ON bit (CMxCON<15>) in the Op amp/Comparator Control register. When the Comparator is disabled, the corresponding trigger and interrupt generation is disabled as well. It is recommended to first configure the CMxCON register with all bits to the desired value, and then set the ON bit. When not used, the Comparator should be disabled expressly by writing a '0' to the ON bit. #### 27.3 Comparator Output Blanking Comparator output blanking is a feature that is only PIC32MK Motor Control (i.e., available on PIC32MKXXMCXX) devices. The outputs of the Comparators can be further blanked/masked based on external events for programmable durations. This feature can be very useful in reducing the interrupt or trigger frequencies. It is primarily used to select Comparator events (interrupts and triggers) synchronized to desired edge transitions on external digital signals such as the PWM outputs from the MCPWM module. A prudent choice of these external signals has potential to greatly simplify software where otherwise extra software logic will be needed to arbitrate for the desired event source. Refer to the Comparator Mask Control Register, CMxMSKCON (Register 27-3), for details on the 16 different external signals that can be used for masking. The logic AND, logic OR and multiplexer blocks shown in Figure 27-6 can be visualized as built-in programmable array logic used to reject the unwanted transitions of the comparator output. For each Comparator, the multiplexers A, B, and C can logically AND or OR either the positive or negative levels (edges) of the 16 different external signals. The outputs of the multiplexers can then be ANDed or ORed together with the AND logic outputs of the multiplexers being further capable of selection for positive or negative transitions as shown in the diagram. For a detailed usage of the output blanking feature, refer to **Section 39.** "Op Amp/Comparator" (DS60001178) of the "PIC32 Family reference Manual". FIGURE 27-6: USER PROGRAMMABLE BLANKING FUNCTION DIAGRAM ### 27.4 Comparator Output Filtering The outputs can also be digitally filtered for glitches or noise. The digital filter has the capability to sample at different frequencies using different clock sources specified by the CFSEL<2:0> bits in the CxCON register. The digital filter looks for three consecutive samples of the same logic state before updating the comparator output. Since the digital filter affects the response times of the output, care should be taken while choosing the filter clock divisor to best suit the application at hand. FIGURE 27-7: DIGITAL FILTER INTERCONNECT BLOCK DIAGRAM ### 27.5 Op amp Mode The Op amp in the Op amp/Comparator module can be enabled by writing a '1' to CMxCON<OPAON>. When configured this way, the output of the Op amp is available at the OAxOUT pin for the external gain/filtering components to be added in the feedback path. With the proper configuration of the ADC module, the op amp can be configured such that the ADC can directly sample the output of the op amp without the need to route the Op amp output to a separate analog input pin (see Figure 27-8). CMxCON<ENPGA> = 1 configures the op amp for unity gain 1x mode configuration. For CMxCON<ENPGA> = 0, the minimum Gain $\geq$ 2 using external resistors as shown in the op amp configuration figures. The RFB in the differential amplifier configuration example must be part of any calculated max IOH/IOL load, see Figure 27-8. ### 27.6 Op amp Unity Gain Mode Usually the op amps have a minimum gain stable setting as defined in Table 37-30 in 37.0 "Electrical Characteristics". However, there is one exception in that the Op amps have an internal 1x gain setting (i.e., the CMxCON<ENPGA> = 1). The mode utilizes only the non-inverting input pin of the Op amp. This configuration needs no external components. The Op amps will be placed in a unity gain/follower mode following a software write to these bits: - CM1CON<30>=1 for op amp 1 - CM2CON<30>=2 for op amp 2 - CM3CON<30> = 3 for op amp 3 - CM5CON<30> = 5 for op amp 5 Refer to **37.0 "Electrical Characteristics"** for the specifications of this mode. ### 27.7 Op-amp High Performance Mode 10 MHz-100MHz Use Requirements (CMXCON<OPLPWR> = 0) - PIC32 Package I/O pin capacitance/ea. = 4 pf - Standard PCB = 1.5 pf per 12.5 mm(0.5 inches) (TRACE W = 0.175 mm, H = 36 μm, T = 113 μm) - Ceffective = (Package Pin capacitance + PCB trace capacitance) - CLOAD = (PIC32 Package pin capacitance + PCB trace capacitance + Target destination input pin capacitance) - BANDWIDTH = User Application Desired Max Bandwidth ≤ 100 MHz - VIN (max) = AVDD / Gain - CEFFECTIVE ≤ 24 pf max. - RSERIES = $5 / (2\pi * CLOAD * BANDWIDTH)$ capacitive coupling. CLOAD (max) ≤ 32pf Note: In High-Performance mode ≥ 10 MHz, all op amp traces must be as short as possible on same layer if possible as MCU and employ surface mount resistors. Op amp traces must have a continuous ground plane beneath them, and not routed adjacent to digital high-frequency signals without a ground guard trace separating them or alternately crossing at right angles to minimize the cross-sectional area to avoid FIGURE 27-8: OP-AMP UNITY GAIN HIGH PERFORMANCE ≥10 MHZ SINGLE ENDED MODE REQUIREMENTS (CMXCON<OPLPWR> = 0) FIGURE 27-9: OP-AMP GAIN ≥ 2: HIGH PERFORMANCE ≥10 MHZ SINGLE ENDED MODE REQUIREMENTS (CMXCON<OPLPWR> = 0) - PIC32 Package I/O pin capacitance/ea. = 4 pf - Standard PCB = 1.5 pf per 12.5 mm (0.5 inches) (TRACE W=0.175 mm, H=36 μm, T=113 μm) - CEFFECTIVE = (Package Pin capacitance + PCB trace capacitance) - CEFFECTIVE ≤ 16 pf max. - RIN Ω = ((8pf / user application CEFFECTIVE) \* 300) **Note:** Ceffective Typ = 8 pf in figure 27-9 if no other node connections. - RFEEDBACK Ω = ((Desired User Gain 1) \* RIN) - Gain = (1 + (RFEEDBACK/RIN)) - VIN (max) = AVDD/GAIN - IDRIVE (min) = (10 ma (VIN (pk) / RIN)) - RSERIES = $5/(2\pi * CLOAD * BANDWIDTH)$ - Vout = Vin \* Gain - PCB Layout Considerations: - RFEEDBACK & RIN must be placed close to PIC32 pins as possible - CLOAD (max) ≤ 32pf FIGURE 27-10: OP-AMP HIGH PERFORMANCE ≥10 MHZ DIFFERENTIAL MODE REQUIREMENTS (CMXCON<OPLPWR> = 0) - PIC32 Package I/O pin capacitance/ea. = 4 pf - Standard PCB = 1.5 pf per 12.5 mm(0.5 inches) (TRACE W=0.175 mm, H=36 μm, T=113 μm) - CEFFECTIVE = (Package Pin capacitance + PCB trace capacitance) - CEFFECTIVE ≤ 16 pf max - R1 Ω = ((8PF / CEFFECTIVE) \* 300) **Note:** Ceffective Typ = 8 pf in figure 27-10 if no other node connections. - R2 $\Omega$ = ((DESIRED USER GAIN ) \* R1) - GAIN = (R2 / R1) - IDRIVE(MIN) = [10MA-[(VOUT / R2) (VIN2(PEAK) / (R1+R2))]] - RSERIES = 5 / (2Π \* CLOAD \* SIGNAL BANDWIDTH) - Vout = (Vin2 Vin1) \* GAIN - · PCB layout consideration: - R2 & R1 must be placed close to CPU pins as possible. - CLOAD (max) ≤ 32pf 27.7.1 OP AMP LOW-POWER MODE ≤10 MHZ USE REQUIREMENTS (CMXCON<OPLPWR> = 1) FIGURE 27-11: OP AMP UNITY GAIN LOW POWER MODE ≤10 MHZ REQUIREMENTS (CMXCON<OPLPWR> = 1) - PIC32 Package I/O pin capacitance/ea. = 4 pf - Standard PCB = 1.5 pf per 12.5 mm (0.5 inches) (TRACE W = 0.175 mm, H = 36 $\mu$ m, T = 113 $\mu$ m) - CEFFECTIVE = (Package Pin capacitance + PCB trace capacitance) - CLOAD = (CEFFECTIVE + Target destination input pin capacitance) - VIN (max) = AVDD / Gain - CLOAD max ≤ 32 pf FIGURE 27-12: OP-AMP GAIN ≥ 2: LOW-POWER MODE ≤10 MHZ REQUIREMENTS (CMXCON<OPLPWR> = 1) - PIC32 Package I/O pin capacitance/ea. = 4 pf - Standard PCB = 1.5 pf per 12.5 mm (0.5 inches) (TRACE W=0.175 mm, H=36 μm, T=113 μm) - CEFFECTIVE = (Package Pin capacitance + PCB trace capacitance) - CEFFECTIVE ≤ 8 pf max. - RIN = $3k \Omega$ (Highly Recommended) - RFEEDBACK $\Omega = ((Desired User Gain 1) * RIN)$ - = ((Desired User Gain 1) \* 3k) - Gain = (1 + (RFEEDBACK / RIN)) - = (1 + (RFEEDBACK / 3k)) - Vin (Max) = AVDD/Gain - IDRIVE (min.) = (10 ma (VIN (pk) / RIN)) - = (10 ma (Vin (pk) / 3k)) FIGURE 27-13: OP AMP LOW-POWER DIFFERENTIAL MODE ≤10 MHZ REQUIREMENTS (CMXCON<OPLPWR> = 1) - PIC32 Package I/O pin capacitance/ea. = 4 pf - Standard PCB = 1.5 pf per 12.5 mm(0.5 inches) (TRACE W=0.175 mm, H=36 μm, T=113 μm) - CEFFECTIVE = (Package Pin capacitance + PCB trace capacitance) - CEFFECTIVE ≤ 8 pf max. - R1 $\Omega$ = 3K (min.) (Highly Recommended) - R2 $\Omega$ = ((Desired User Gain ) \* R1) - Gain = (R2 / R1) - Vin (max) = AVDD / Gain - IDRIVE (min) = [10 ma-[(VOUT / R2) (VIN2(peak) / (R1+R2))]] - Vout = (VIN2 VIN1) \* Gain - PCB Layout Considerations: - R2 & R1 must be placed close to CPU pins as possible #### 27.8 Op amp Circuit Examples #### FIGURE 27-14: OP AMP CONFIGURATION CIRCUIT EXAMPLES #### FIGURE 27-15: OP-AMP CONFIGURATION CIRCUIT EXAMPLES #### FIGURE 27-16: OP-AMP CONFIGURATION CIRCUIT EXAMPLES #### FIGURE 27-17: OP-AMP CONFIGURATION CIRCUIT EXAMPLES #### FIGURE 27-18: OP-AMP CONFIGURATION CIRCUIT EXAMPLES Note 1: Microchip's FilterLab® software is an innovative software tool that simplifies analog active filter (using op amps) design. This free software tool is available for download from the Microchip web site at <a href="https://www.microchip.com/filterlab">www.microchip.com/filterlab</a>. The FilterLab design tool provides schematic diagrams of the filter circuit with component values. It also outputs the filter circuit in SPICE format, which can be used with the macro model to simulate filter performance. <sup>2:</sup> Microchip's Mindi™ simulator tool aids in the design of various circuits useful for active filter, amplifier and power-management applications. It is a free online simulation tool available for download from the Microchip web site at <a href="https://www.microchip.com/mindi">www.microchip.com/mindi</a>. This interactive simulator enables designers to quickly generate circuit diagrams and simulate circuits. Circuits that are developed using the Mindi simulation tool can be downloaded to a personal computer or workstation. #### 27.9 **Comparator Configuration** The Comparator and the relationship between the analog input levels and the digital output are illustrated in Figure 27-19. Each Comparator can be individually configured to compare against an external voltage reference or internal voltage reference. For more information on the internal op amp/comparator voltage reference, refer to Section 45. "Control Digital-to-Analog converter" (DS60001327) of the "PIC32 Family Reference Manual". A standard configuration with default built in hysteresis is shown in Figure 27-19. The external reference at VIN+ is a fixed voltage. The analog input signal at VINis compared to the reference signal at VIN+, and the digital output of the comparator is created by the difference between the two signals as shown in the figure. The polarity of the comparator output can be inverted by writing a '1' to the CPOL bit (CMxCON<13>) such that the output is a digital low level when VIN+ > VIN-. FIGURE 27-19: **COMPARATOR CONFIGURATION FOR DEFAULT BUILT-IN HYSTERESIS** TABLE 27-2: COMPARATOR CMPX OUTPUT AND EVENT POLARITY SELECTION (X=1-5) | CPOL | EVPO | L[1:0] | Comparator Input<br>Change<br>(comparator_status_in) | Comparator<br>Output | CxOUT | Trigger/Interrupt Generated? | |------|------|--------|------------------------------------------------------|----------------------|-------|------------------------------| | 0 | 0 | 0 | +ln > -ln | High | High | No | | 0 | 0 | 0 | +ln < -ln | Low | Low | No | | 0 | 0 | 1 | +ln > -ln | High | High | Yes (only while CEVT = 0) | | 0 | 0 | 1 | +ln < -ln | Low | Low | No | | 0 | 1 | 0 | +ln > -ln | High | High | No | | 0 | 1 | 0 | +ln < -ln | Low | Low | Yes (only while CEVT = 0) | | 0 | 1 | 1 | +ln > -ln | High | High | Yes (only while CEVT = 0) | | 0 | 1 | 1 | +ln < -ln | Low | Low | Yes (only while CEVT = 0) | | 1 | 0 | 0 | +ln > -ln | High | Low | No | | 1 | 0 | 0 | +ln < -ln | Low | High | No | | 1 | 0 | 1 | +ln > -ln | High | Low | No | | 1 | 0 | 1 | +ln < -ln | Low | High | Yes (only while CEVT = 0) | | 1 | 1 | 0 | +ln > -ln | High | Low | Yes (only while CEVT = 0) | | 1 | 1 | 0 | +ln < -ln | Low | High | No | | 1 | 1 | 1 | +ln > -ln | High | Low | Yes (only while CEVT = 0) | | 1 | 1 | 1 | +ln < -ln | Low | High | Yes (only while CEVT = 0) | #### 27.10 Op amp/Comparator Control Registers TABLE 27-3: OP AMP/COMPARATOR REGISTER MAP | ., | LL 21-3. ( | <i>-</i> , , , | , • • | 71111 7 11 17 | | LGISTL | 1 1 1717 11 | | | | | | | | | | | | | |---------------------------|---------------------------------|----------------|-------|---------------|-------|--------|-------------|-------|---------|---------|------|--------|----------|-------|---------|---------|----------|-------|------------| | ess | | | | | | | | | | Bits | | | | | | | | | | | Virtual Address<br>(BF82) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | C000 | CMSTAT | 31:16 | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | C5EVT | C4EVT | C3EVT | C2EVT | C1EVT | 0000 | | 0000 | OWOTAT | 15:0 | _ | | SIDL | _ | _ | _ | _ | _ | _ | _ | _ | C5OUT | C4OUT | C3OUT | C2OUT | C10UT | 0000 | | C010 | CM1CON | 31:16 | OPAON | ENPGA | _ | HYSPOL | | _ | HYSSE | EL<1:0> | _ | С | FSEL<2:0 | > | CFLTREN | CF | DIV<2:0> | | 0000 | | 0010 | OWTOON | 15:0 | ON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPO | L<1:0> | _ | CREF | _ | _ | CCH< | 1:0> | 0000 | | C020 | CM1MSKCON | 31:16 | — | _ | _ | _ | | SELSR | CC<3:0> | | | SELSRC | B<3:0> | | | SELSRCA | <3:0> | | 0000 | | 0020 | OWNINGROOM | 15:0 | HLMS | _ | OCEN | OCNEN | OBEN | OBNEN | OAEN | OANEN | NAGS | PAGS | ACEN | ACNEN | ABEN | ABNEN | AAEN | AANEN | 0000 | | C030 | CM2CON | 31:16 | OPAON | ENPGA | _ | HYSPOL | | _ | HYSSE | EL<1:0> | _ | С | FSEL<2:0 | > | CFLTREN | CF | DIV<2:0> | | 0000 | | 0000 | 011120011 | 15:0 | ON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPO | L<1:0> | _ | CREF | _ | _ | CCH< | 1:0> | 0000 | | C040 | CM2MSKCON | 31:16 | _ | _ | _ | _ | | SELSR | CC<3:0> | | | SELSRC | B<3:0> | | | SELSRCA | | | 0000 | | 00.0 | 02 | 15:0 | HLMS | _ | OCEN | OCNEN | OBEN | OBNEN | OAEN | OANEN | NAGS | PAGS | ACEN | ACNEN | ABEN | ABNEN | | AANEN | 0000 | | C050 | CM3CON | 31:16 | OPAON | ENPGA | _ | HYSPOL | | _ | | L<1:0> | _ | | FSEL<2:0 | | CFLTREN | CF | DIV<2:0> | | 0000 | | 0000 | OMOGON | 15:0 | ON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPO | L<1:0> | _ | CREF | _ | _ | CCH< | 1:0> | 0000 | | C060 | CM3MSKCON | 31:16 | _ | _ | _ | _ | | SELSR | CC<3:0> | | | SELSRC | B<3:0> | | | SELSRCA | | | 0000 | | 0000 | | 15:0 | HLMS | _ | OCEN | OCNEN | OBEN | OBNEN | OAEN | OANEN | NAGS | PAGS | ACEN | ACNEN | ABEN | ABNEN | AAEN | AANEN | 0000 | | C070 | CM4CON | 31:16 | _ | _ | _ | HYSPOL | _ | _ | HYSSE | L<1:0> | _ | | FSEL<2:0 | , | CFLTREN | CF | DIV<2:0> | | 0000 | | 00.0 | | 15:0 | ON | COE | CPOL | _ | _ | _ | CEVT | COUT | EVPO | L<1:0> | _ | CREF | _ | _ | CCH< | 1:0> | 0000 | | C080 | CM4MSKCON | 31:16 | _ | _ | _ | _ | | | CC<3:0> | | | SELSRC | | | | SELSRCA | | | 0000 | | 0000 | | 15:0 | HLMS | _ | OCEN | OCNEN | OBEN | OBNEN | OAEN | OANEN | NAGS | PAGS | ACEN | ACNEN | ABEN | ABNEN | AAEN | AANEN | 0000 | | C090 | CM5CON | 31:16 | OPAON | ENPGA | _ | HYSPOL | _ | _ | HYSSE | L<1:0> | _ | С | FSEL<2:0 | > | CFLTREN | CF | DIV<2:0> | | 0000 | | | | 15:0 | ON | COE | CPOL | CLPWR | | _ | CEVT | COUT | EVPO | L<1:0> | _ | CREF | _ | _ | CCH< | 1:0> | 0000 | | C0A0 | CM5MSKCON | 31:16 | _ | _ | _ | _ | | | CC<3:0> | 1 | | SELSRC | | T | | SELSRCA | | | 0000 | | 22710 | | 15:0 | HLMS | _ | OCEN | OCNEN | OBEN | OBNEN | OAEN | OANEN | NAGS | PAGS | ACEN | ACNEN | ABEN | ABNEN | AAEN | AANEN | 0000 | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. #### REGISTER 27-1: CMSTAT: OP AMP/COMPARATOR STATUS REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | - | _ | _ | | 23:16 | U-0 | U-0 | U-0 | HS, R-0 | HS, R-0 | HS, R-0 | HS, R-0 | HS, R-0 | | 23.10 | _ | _ | _ | C5EVT | C4EVT | C3EVT | C2EVT | C1EVT | | 15:8 | U-0 | U-x | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | 15.6 | _ | _ | SIDL | _ | _ | _ | _ | _ | | 7:0 | U-0 | U-0 | U-0 | R-0 | R-0 | R-0 | R-0 | R-0 | | 7.0 | _ | | _ | C5OUT | C4OUT | C3OUT | C2OUT | C1OUT | **Legend:** HS = Set by hardware R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-21 Unimplemented: Read as '0' bit 20 C5EVT: Comparator 5 Event Status bit - 1 = Comparator event according to EVPOL<1:0> settings occurred. Future events/triggers and interrupts are disabled until the CEVT bit (CMxCON<9>) is cleared by user software. - 0 = Comparator event did not occur - bit 19 **C4EVT:** Comparator 4 Event Status bit - 1 = Comparator event according to EVPOL<1:0> settings occurred. Future events/triggers and interrupts are disabled until the CEVT bit (CMxCON<9>) is cleared by user software. - 0 = Comparator event did not occur - bit 18 C3EVT: Comparator 3 Event Status bit - 1 = Comparator event according to EVPOL<1:0> settings occurred. Future events/triggers and interrupts are disabled until the CEVT bit (CMxCON<9>) is cleared by user software. - 0 = Comparator event did not occur - bit 17 C2EVT: Comparator 2 Event Status bit - 1 = Comparator event according to EVPOL<1:0> settings occurred. Future events/triggers and interrupts are disabled until the CEVT bit (CMxCON<9>) is cleared by user software. - 0 = Comparator event did not occur - bit 16 C1EVT: Comparator 1 Event Status bit - 1 = Comparator event according to EVPOL<1:0> settings occurred. Future events/triggers and interrupts are disabled until the CEVT bit (CMxCON<9>) is cleared by user software. - 0 = Comparator event did not occur - bit 15-14 Unimplemented: Read as '0' - bit 13 SIDL: Stop in Idle Mode bit - 1 = Discontinue operation of all Op amp/Comparators when device enters Idle mode - 0 = Continue module operation in Idle mode - bit 12-5 **Unimplemented:** Read as '0' - bit 4-0 C50UT:C10UT: Op amp/Comparator 5 through Comparator 1 Output Status bit When CPOL = 0: 1 = VIN+ > VTH+ 0 = VIN+ < VTH- When CPOL = 1: 1 = VIN+ < VTH- 0 = VIN+ > VTH+ ## REGISTER 27-2: CMxCON: OP AMP/COMPARATOR 'x' CONTROL REGISTER ('x' = 1-5) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|----------------------|----------------------|-------------------|-------------------|-------------------|-------------------|---------------------|------------------| | 31:24 | R/W-0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 31.24 | OPAON <sup>(2)</sup> | ENPGA <sup>(2)</sup> | _ | HYSPOL | _ | _ | HYSSE | EL<1:0> | | 23:16 | U-0 | R/W-0 | 23.10 | _ | | CFSEL<2:0> | | CFLTREN | | CFDIV<2:0> | | | 15:8 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | HS, R/W-0 | R-0 | | 13.0 | ON | COE | CPOL | OPLPWR | _ | _ | CVET <sup>(1)</sup> | COUT | | 7:0 | R/W-0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 7:0 | EVPO | L<1:0> | _ | CREF | _ | — CCH<1:0> | | | **Legend:** HS = Set by hardware R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 **OPAON:** Op amp Enable bit<sup>(2)</sup> 1 = Op amp enabled and connected to pin 0 = Op amp disabled and pin is released to other functions Note: Initialize ENPGA & OPLPWR prior to enabling the op amp, CMxCON<OPAON>=1. bit 30 **ENPGA:** Op amp Fixed Gain Enable bit<sup>(2)</sup> 1 = Op amp is operating in Fixed Gain 1X mode 0 = Op amp is operating in Open Loop mode (default) bit 29 Unimplemented: Read as '0' bit 28 **HYSPOL:** Comparator Hysteresis Polarity Selection 1 = Hysteresis on falling edge, rising edge is accurate 0 = Hysteresis on rising edge, falling edge is accurate bit 27-26 Unimplemented: Read as '0' bit 25-24 HYSSEL<1:0>: Hysteresis Selection bits 11 = Set highest hysteresis level (Typical 45 mV) 10 = Set medium hysteresis level (Typical 30 mV) 01 = Set lowest hysteresis level (Typical 15 mV) 00 = No hysteresis selected. **Note:** These bits select the hysteresis of the analog comparator. bit 23 Unimplemented: Read as '0' bit 22-20 CFSEL<2:0>: Comparator Output Filter Clock Source Select bits 111 = PBCLK2/Timer5 Period Value (PR5) 110 = PBCLK2/Timer4 Period Value (PR4) 101 = PBCLK2/Timer3 Period Value (PR3) 100 = PBCLK2/Timer2 Period Value (PR2) 011 = REFCLK3 Clock 010 = PWM Secondary Special Event 001 = PPBCLK2 Clock 000 = SYSCLK Clock **Note 1:** Before attempting to initialize or enable any of the Op amp bits, the user application must clear the corresponding OPA5MD, OPA3MD, OPA2MD, OPA1MD bits in the PMD register. 2: These bits are not available in the CM4CON register. Note: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition has occurred. The IFSx bits are persistent, so they must be cleared by user software. ## REGISTER 27-2: CMxCON: OP AMP/COMPARATOR 'x' CONTROL REGISTER ('x' = 1-5) (CONTINUED) - bit 19 **CFLTREN:** Comparator Output Digital Filter Enable bit - 1 = Digital Filters are enabled - 0 = Digital Filters are disabled - bit 18-16 CFDIV<2:0>: Comparator Output Filter Clock Divide Select bits These bits are based on the CFSEL clock source selection. - 111 = 1:128 Clock Divide - 110 = 1:64 Clock Divide - 101 = 1:32 Clock Divide - 100 = 1:16 Clock Divide - 011 = 1:8 Clock Divide - 010 = 1:4 Clock Divide - 001 = 1:2 Clock Divide - 000 = 1:1 Clock Divide - bit 15 **ON:** Comparator Enable bit - 1 = Comparator is enabled - 0 = Comparator is disabled - bit 14 **COE:** Comparator Output Enable bit - 1 = Comparator output is present on the CxOUT pin - 0 = Comparator output is internal only - bit 13 CPOL: Comparator Output Polarity Select bit - 1 = Comparator output is inverted - 0 = Comparator output is not inverted - bit 12 **OPLPWR:** Op-Amp Power mode - 1 = Op amp operating in low-power mode (1/10 power, slower response, Bandwidth ≤ 10 MHz) - 0 = Op amp operating in normal power mode, (10 MHz ≥ Bandwidth ≤ 100 MHz) **Note:** This bit does not exist for in CM4CON as there is no op amp #4. - bit 11-10 Unimplemented: Read as '0' - bit 9 **CEVT:** Comparator Event bit<sup>(1)</sup> - 1 = Comparator event according to EVPOL<1:0> bit settings occurred **Note:** CEVT = 1 disables future events/triggers and interrupts until the bit is cleared by user software. - 0 = Comparator event did not occur - bit 8 **COUT:** Comparator Output bit When CPOL = 0 (non-inverted polarity): - 1 = VIN+ > VTH+ - 0 = VIN+ < VTH- #### When CPOL = 1 (inverted polarity): - 1 = VIN+ < VTH- - 0 = VIN+ > VTH+ - **Note 1:** Before attempting to initialize or enable any of the Op amp bits, the user application must clear the corresponding OPA5MD, OPA3MD, OPA2MD, OPA1MD bits in the PMD register. - 2: These bits are not available in the CM4CON register. **Note:** The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition has occurred. The IFSx bits are persistent, so they must be cleared by user software. ## REGISTER 27-2: CMxCON: OP AMP/COMPARATOR 'x' CONTROL REGISTER ('x' = 1-5) (CONTINUED) - bit 7-6 **EVPOL<1:0>:** Trigger/Event Polarity Select bits - 11 = Trigger/Event generated on any change of the comparator output - 10 = Trigger/Event generated only on high-to-low transition of the polarity-selected comparator output If CPOL = 0 (non-inverted polarity): High-to-low transition of the comparator output If CPOL = 1 (inverted polarity): Low-to-high transition of the comparator output 01 = Trigger/Event generated only on low-to-high transition of the polarity-selected comparator output If CPOL = 0 (non-inverted polarity): Low-to-high transition of the comparator output If CPOL = 1 (inverted polarity): High-to-low transition of the comparator output 00 = Trigger/Event generation is disabled - bit 5 **Unimplemented:** Read as '0' - bit 4 CREF: Op amp/Comparator Reference Select bit - 1 = VIN+ input connects to internal CDAC3 output voltage - 0 = VIN+ input connects to CxIN1+ pin - bit 3-2 Unimplemented: Read as '0' - bit 1-0 CCH<1:0>: Comparator Channel Select bits - 11 = CxIN4- - 10 = CxIN3- - 01 = CxIN2- - 00 = CxIN1- - **Note 1:** Before attempting to initialize or enable any of the Op amp bits, the user application must clear the corresponding OPA5MD, OPA3MD, OPA2MD, OPA1MD bits in the PMD register. - 2: These bits are not available in the CM4CON register. Note: The IFSx bits, as with all interrupt flag status register bits, are set as long as the peripheral is enabled and an interrupt condition event occurs. Interrupts do not have to be enabled for the IFSx bits to be set. If the user application does not want to use an interrupt, it can poll the corresponding peripheral IFSx bit to see whether an interrupt condition has occurred. The IFSx bits are persistent, so they must be cleared by user software. ## REGISTER 27-3: CMxMSKCON: COMPARATOR 'x' MASK CONTROL REGISTER ('x' = 1-5) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 31:24 | _ | _ | | _ | | SELSR | CC<3:0> | | | 00.46 | R/W-0 | 23:16 | | SELSR | CB<3:0> | | | SELSR | CA<3:0> | | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15:8 | HLMS | _ | OCEN | OCNEN | OBEN | OBNEN | OAEN | OANEN | | 7.0 | R/W-0 | 7:0 | NAGS | PAGS | ACEN | ACNEN | ABEN | ABNEN | AAEN | AANEN | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-24 SELSRCC<3:0>: Mask C Input Select bits See the definitions for the SELSRCA<3:0> bits. bit 23-20 SELSRCB<3:0>: Mask B Input Select bits See the definitions for the SELSRCA<3:0> bits. bit 19-16 SELSRCA<3:0>: Mask A Input Select bits 1111 = FLT4 pin 1110 = FLT2 pin 1101 = Reserved 1100 = Reserved 1011 **= PWM12H** 1010 = PWM11H 1001 **= PWM10H** 1000 **= PWM9H** 0111 **= PWM8H** 0110 **= PWM7H** 0101 **= PWM6H** 0100 **= PWM5H** 0011 **= PWM4H** 0010 **= PWM3H** 0001 = PWM2H 0000 = PWM1H bit 15 **HLMS:** High or Low Level Masking Select bit - 1 = The comparator deasserted state is 1, and the masking (blanking) function will prevent any asserted ('0') comparator signal from propagating - 0 = The comparator deasserted state is 0, and the masking (blanking) function will prevent any asserted ('1') comparator signal from propagating - bit 14 Unimplemented: Read as '0' - bit 13 OCEN: OR Gate "C" Input Enable bit 1 = "C" input enabled as input to OR gate 0 = "C" input disabled as input to OR gate Note: This register is only available on PIC32MKXXMCXXX devices. #### CMxMSKCON: COMPARATOR 'x' MASK CONTROL REGISTER REGISTER 27-3: ('x' = 1-5) (CONTINUED) bit 12 OCNEN: OR Gate "C" Input Inverted Enable bit 1 = "C" input (inverted) enabled as input to OR gate 0 = "C" input (inverted) disabled as input to OR gate bit 11 **OBEN:** OR Gate "B" Input Enable bit 1 = "B" input enabled as input to OR gate 0 = "B" input disabled as input to OR gate bit 10 **OBNEN:** OR Gate "B" Input Inverted Enable bit 1 = "B" input (inverted) enabled as input to OR gate 0 = "B" input (inverted) disabled as input to OR gate bit 9 OAEN: OR Gate "A" Input Enable bit 1 = "A" input enabled as input to OR gate 0 = "A" input disabled as input to OR gate bit 8 OANEN: OR Gate "A" Input Inverted Enable bit 1 = "A" input (inverted) enabled as input to OR gate 0 = "A" input (inverted) disabled as input to OR gate NAGS: Negative AND Gate Output Select bit bit 7 1 = The negative (inverted) output of the AND gate to the OR gate is enabled 0 = The negative (inverted) output of the AND gate to the OR gate is disabled bit 6 PAGS: Positive AND Gate Output Select bit 1 = The positive output of the AND gate to the OR gate is enabled 0 = The positive output of the AND gate to the OR gate is disabled bit 5 ACEN: AND Gate "C" Input Enable bit 1 = "C" input enabled as input to AND gate 0 = "C" input disabled as input to AND gate bit 4 ACNEN: AND Gate "C" Inverted Input Enable bit 1 = "C" input (inverted) enabled as input to AND gate 0 = "C" input (inverted) disabled as input to AND gate bit 3 ABEN: AND Gate "B" Input Enable bit 1 = "B" input enabled as input to AND gate 0 = "B" input disabled as input to AND gate bit 2 ABNEN: AND Gate "B" Inverted Input Enable bit 1 = "B" input (inverted) enabled as input to AND gate 0 = "B" input (inverted) disabled as input to AND gate bit 1 AAEN: AND Gate "A" Input Enable bit 1 = "A" input enabled as input to AND gate 0 = "A" input disabled as input to AND gate bit 0 AANEN: AND Gate "A" Inverted Input Enable bit 1 = "A" input (inverted) enabled as input to AND gate 0 = "A" input (inverted) disabled as input to AND gate Note: This register is only available on PIC32MKXXMCXXX devices. # 28.0 CHARGE TIME MEASUREMENT UNIT (CTMU) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 37. "Charge Time Measurement Unit (CTMU)" (DS60001167), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The Charge Time Measurement Unit (CTMU) is a flexible analog module that has a configurable current source with a digital configuration circuit built around it. The CTMU can be used for differential time measurement between pulse sources and can be used for generating an asynchronous pulse. By working with other on-chip analog modules, the CTMU can be used for high resolution time measurement, measure capacitance, measure relative changes in capacitance or generate output pulses with a specific time delay. The CTMU is ideal for interfacing with capacitive-based sensors. The CTMU module includes the following key features: - Two channels are available for capacitive or time measurement input - · On-chip precision current source - 16-edge input trigger sources - · Selection of edge or level-sensitive inputs - · Polarity control for each edge source - · Control of edge sequence - · Control of response to edges - · High precision time measurement - Time delay of external or internal signal asynchronous to system clock - · Integrated temperature sensing diode - Control of current source during auto-sampling - · Four current source ranges - · Time measurement resolution of one nanosecond - · Up to 39 inputs for capacitive measurement A block diagram of the CTMU is shown in Figure 28-1. FIGURE 28-1: CTMU BLOCK DIAGRAM #### 28.1 Control Registers #### **TABLE 28-1: CTMU REGISTER MAP** | ess | | • | | | | | | | | Bits | | | | | | | | | " | |----------------------------|------------------------------------|-----------|---------|--------------------------|-------|-------|-------|----------|------------------------------------------------|--------|------|------|-------|-------|------|------|------|-------|------------| | Virtual Addres<br>(BF82_#) | (BF82_#) (BF82_#) Register Name(f) | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | D000 | CTMUCON | 31:16 | EDG1MOD | MOD EDG1POL EDG1SEL<3:0> | | | | | EDG2STAT EDG1STAT EDG2MOD EDG2POL EDG2SEL<3:0> | | | | | | | _ | _ | 0000 | | | טטטט | CTWOCON | 15:0 | ON | _ | SIDLE | TGEN | EDGEN | EDGSEQEN | IDISSEN | CTTRIG | | | ITRIM | <5:0> | | | IRNG | <1:0> | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. #### REGISTER 28-1: CTMUCON: CTMU CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|---------------------|-------------------|-------------------|------------------------|------------------| | 24.24 | R/W-0 | 31:24 | EDG1MOD | EDG1POL | | EDG1S | EL<3:0> | | EDG2STAT | EDG1STAT | | 00.46 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | | 23:16 | EDG2MOD | EDG2POL | EDG2SEL<3:0> | | | | _ | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15:8 | ON | _ | SIDLE | TGEN <sup>(1)</sup> | EDGEN | EDGSEQEN | IDISSEN <sup>(2)</sup> | CTTRIG | | 7.0 | R/W-0 | 7:0 | | | ITRIM | 1<5:0> | | | IRNG | <1:0> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 **EDG1MOD:** Edge 1 Edge Sampling Select bit 1 = Reserved 0 = Input is level-sensitive bit 30 EDG1POL: Edge 1 Polarity Select bit 1 = Edge 1 programmed for a logic high level response 0 = Edge 1 programmed for a logic low level response bit 29-26 EDG1SEL<3:0>: Edge 1 Source Select bits 1111 = C5OUT Capture Event is selected 1110 = C4OUT pin is selected 1101 = C1OUT pin is selected 1100 = IC6 Capture Event is selected 1011 = IC5 Capture Event is selected 1010 = IC4 Capture Event is selected 1001 = IC3 pin is selected 1000 = IC2 pin is selected 0111 = IC1 pin is selected 0110 = OC4 pin is selected 0101 = OC3 pin is selected 0100 = OC2 pin is selected 0011 = CTED1 pin is selected 0010 = CTED2 pin is selected 0001 = OC1 Compare Event is selected 0000 = Timer1 Event is selected - **Note 1:** When this bit is set for Pulse Delay Generation, the EDG2SEL<3:0> bits must be set to '1101' to select C1OUT. - 2: The ADC module Sample and Hold capacitor is not automatically discharged between sample/conversion cycles. Software using the ADC as part of a capacitive measurement, must discharge the ADC capacitor before conducting the measurement. The IDISSEN bit, when set to '1', performs this function. The ADC module must be sampling while the IDISSEN bit is active to connect the discharge sink to the capacitor array. - 3: Refer to the CTMU Current Source Specifications (Table 37-45) in 37.0 "Electrical Characteristics" for current values. - **4:** This bit setting is not available for the CTMU temperature diode. - **5:** For CTMU temperature measurements on this range, ADC sampling time $\geq 1.6 \, \mu s$ . - 6: For CTMU temperature measurements on this range, ADC sampling time ≥ 300 ns. #### REGISTER 28-1: CTMUCON: CTMU CONTROL REGISTER (CONTINUED) bit 25 **EDG2STAT:** Edge 2 Status bit Indicates the status of Edge 2 and can be written to control edge source 1 = Edge 2 event has occurred 0 = Edge 2 event has not occurred bit 24 **EDG1STAT:** Edge 1 Status bit Indicates the status of Edge 1 and can be written to control edge source 1 = Edge 1 event has occurred 0 = Edge 1 event has not occurred bit 23 EDG2MOD: Edge 2 Edge Sampling Select bit 1 = Reserved 0 = Input is level-sensitive bit 22 EDG2POL: Edge 2 Polarity Select bit 1 = Edge 2 programmed for a high-level response 0 = Edge 2 programmed for a low-level response bit 21-18 EDG2SEL<3:0>: Edge 2 Source Select bits 1111 = C5OUT Capture Event is selected 1110 = C4OUT pin is selected 1101 = C1OUT pin is selected 1100 = PBCLK2 is selected 1011 = IC5 Capture Event is selected 1010 = IC4 Capture Event is selected 1001 = IC3 pin is selected 1000 = IC2 pin is selected 0111 = IC1 pin is selected 0110 = OC4 pin is selected 0101 = OC3 pin is selected 0100 = OC2 pin is selected 0011 = CTED1 pin is selected 0010 = CTED2 pin is selected 0001 = OC1 Compare Event is selected 0000 = Timer1 Event is selected bit 17-16 Unimplemented: Read as '0' bit 15 ON: ON Enable bit 1 = Module is enabled 0 = Module is disabled bit 14 Unimplemented: Read as '0' bit 13 SIDLE: Stop in Idle mode 1 = Stop CTMU operation in CPU Idle mode 0 = Continue CTMU operation in CPU Idle mode Note 1: When this bit is set for Pulse Delay Generation, the EDG2SEL<3:0> bits must be set to '1101' to select C10UT. - 2: The ADC module Sample and Hold capacitor is not automatically discharged between sample/conversion cycles. Software using the ADC as part of a capacitive measurement, must discharge the ADC capacitor before conducting the measurement. The IDISSEN bit, when set to '1', performs this function. The ADC module must be sampling while the IDISSEN bit is active to connect the discharge sink to the capacitor array. - 3: Refer to the CTMU Current Source Specifications (Table 37-45) in 37.0 "Electrical Characteristics" for current values. - 4: This bit setting is not available for the CTMU temperature diode. - 5: For CTMU temperature measurements on this range, ADC sampling time $\geq$ 1.6 $\mu s.$ - **6:** For CTMU temperature measurements on this range, ADC sampling time $\geq$ 300 ns. # REGISTER 28-1: CTMUCON: CTMU CONTROL REGISTER (CONTINUED) bit 12 TGEN: Time Generation Enable bit<sup>(1)</sup> 1 = Enables edge delay generation 0 = Disables edge delay generation bit 11 **EDGEN:** Edge Enable bit 1 = Edges are not blocked 0 = Edges are blocked bit 10 EDGSEQEN: Edge Sequence Enable bit 1 = Edge 1 must occur before Edge 2 can occur 0 = No edge sequence is needed bit 9 IDISSEN: Analog Current Source Control bit<sup>(2)</sup> 1 = Analog current source output is grounded 0 = Analog current source output is not grounded bit 8 **CTTRIG:** Trigger Control bit 1 = Trigger output is enabled 0 = Trigger output is disabled bit 7-2 ITRIM<5:0>: Current Source Trim bits 011111 = Maximum positive change from nominal current 011110 • 000001 = Minimum positive change from nominal current 000000 = Nominal current output specified by IRNG<1:0> 111111 = Minimum negative change from nominal current • 100010 100001 = Maximum negative change from nominal current bit 1-0 **IRNG<1:0>:** Current Range Select bits<sup>(3)</sup> 11 = 100 times base current (i.e., 0.55 $\mu$ A Typical)<sup>(6)</sup> 10 = 10 times base current (i.e., 5.5 $\mu$ A Typical)<sup>(5)</sup> 01 = Base current level (i.e., 0.55 μA Typical)<sup>(4)</sup> 00 = 1000 times base current (i.e., 550 μA Typical)<sup>(4)</sup> - Note 1: When this bit is set for Pulse Delay Generation, the EDG2SEL<3:0> bits must be set to '1101' to select C1OUT. - 2: The ADC module Sample and Hold capacitor is not automatically discharged between sample/conversion cycles. Software using the ADC as part of a capacitive measurement, must discharge the ADC capacitor before conducting the measurement. The IDISSEN bit, when set to '1', performs this function. The ADC module must be sampling while the IDISSEN bit is active to connect the discharge sink to the capacitor array. - **3:** Refer to the CTMU Current Source Specifications (Table 37-45) in **37.0 "Electrical Characteristics"** for current values. - **4:** This bit setting is not available for the CTMU temperature diode. - 5: For CTMU temperature measurements on this range, ADC sampling time ≥ 1.6 µs. - **6:** For CTMU temperature measurements on this range, ADC sampling time $\geq$ 300 ns. | | | y | | |--------|--|---|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 29.0 CONTROL DIGITAL-TO-ANALOG CONVERTER (CDAC) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended be a comprehensive reference source. To complement the information in this data sheet, refer to Section 45. "Control Digital-to-Analog Converter (DS60001327), (CDAC)" which available from the Documentation Reference Manual section of the PIC32 web Microchip site (www.microchip.com/pic32). The PIC32MK GPK/MCM with CAN FD Family Control Digital-to-Analog Converter (CDAC) generates analog voltage corresponding to the digital inputs. The voltage can be used as a reference source for comparators or can be used as an offset to an Op amp. This module is targeted for control applications, as opposed to other DAC modules, which are used for audio applications. The following are key features of the CDAC module: - Wide voltage range (1.8V to 3.6V) - · 12-bit resolution - · Fast conversion times, 1 Msps - · Buffered output for comparator use For additional information on conversion time, sampling rate, module turn-on time and glitch reduction circuit characteristics, refer to 37.0 "Electrical Characteristics". Figure 29-1 illustrates the functional block diagram of the CDAC module. FIGURE 29-1: CDAC BLOCK DIAGRAM #### 29.1 Control Registers #### TABLE 29-1: CDAC REGISTER MAP | ess | | | | | | | | | | Bits | | | | | | | | | y | |--------------|---------------------------------|-----------|-------|-------|-------|-------|------------------------|-------|------|-------|------|-----------|------|------|------|------|--------|--------|-----------| | Virtual Addr | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Reset | | BF82 | DAC1CON | 31:16 | _ | _ | _ | _ | DACDAT<11:0> 0000 | | | | | | | | | | | | | | C200 | DACTOON | 15:0 | ON | _ | _ | _ | _ | _ | _ | DACOE | _ | _ | _ | _ | _ | _ | REFSEI | L<1:0> | 0000 | | BF84 | DAGGGGN | 31:16 | - | _ | _ | _ | | | | | D | ACDAT<11: | 0> | | | | | | 0000 | | C400 | DAC2CON | 15:0 | ON | _ | _ | _ | DACOE REFSEL<1:0> 0000 | | | | | | | | | | | | | | BF84 | DAGGGGN | 31:16 | | _ | _ | _ | | | • | • | D | ACDAT<11: | 0> | • | | • | | | 0000 | | C600 | DAC3CON | 15:0 | ON | _ | _ | _ | _ | | | | | | | | | | | | | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. #### REGISTER 29-1: DACxCON: CDAC CONTROL REGISTER 'x' ('x' = 1 THROUGH 3) | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-----------------------|------------------------|--|--|--|--| | 24.24 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | 31:24 | - | _ | - | _ | | DACDAT | <11:8> <sup>(1)</sup> | • | | | | | | 00.46 | R/W-0 | | | | | 23:16 | DACDAT<7:0>(1) | | | | | | | | | | | | | 45.0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | | | | | | 15:8 | ON <sup>(1)</sup> | _ | _ | _ | _ | _ | _ | DACOE <sup>(1)</sup> | | | | | | 7.0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | | | | | 7:0 | _ | _ | _ | _ | _ | _ | REFSEL | <1:0> <sup>(1,2)</sup> | | | | | **Legend:** y = Value set from Configuration bits on POR R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 Unimplemented: Read as '0' bit 27-16 DACDAT<11:0>: CDAC Data Port bits(1) Data input register bits for the CDAC. bit 15 ON: CDAC Enable bit 1 = The CDAC is enabled0 = The CDAC is disabled bit 14-9 Unimplemented: Read as '0' bit 8 DACOE: CDAC Output Buffer Enable bit 1 = Output is enabled; CDAC voltage is connected to the pin 0 = Output is disabled; drive to pin is floating bit 7-2 Unimplemented: Read as '0' bit 1-0 REFSEL<1:0>: Reference Source Select bits<sup>(1,2)</sup> 11 = Positive reference voltage = AVDD 10 = No reference selected (no reference current consumption) 01 = No reference selected (no reference current consumption) 00 = No reference selected (no reference current consumption) - Note 1: To minimize CDAC start-up output transients, configure the DACDATA<15:0>, DACOE, and REFSEL<1:0> bits prior to enabling the CDAC (prior to making DACON = 1). Also, remember to wait ToN time, after enabling the CDAC. This time is required to allow the CDAC output to stabilize. Refer to 37.0 "Electrical Characteristics" for the ToN specification. - 2: If the ON bit is '0', the reference source is disconnected from the internal resistor network. | | | y | | |--------|--|---|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 30.0 QUADRATURE ENCODER INTERFACE (QEI) Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 43. "Quadrature Encoder Interface (QEI)" (DS60001346), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). This chapter describes the Quadrature Encoder Interface (QEI) module and associated operational modes. The QEI module provides the interface to incremental encoders for obtaining mechanical position data. The QEI module consists of the following major features: - Four input pins: two phase signals, an index pulse and a home pulse - · Programmable digital noise filters on inputs - Quadrature decoder providing counter pulses and count direction - Count direction status - · 4x count resolution - · Index (INDX) pulse to reset the position counter - General purpose 32-bit Timer/Counter mode - · Interrupts generated by QEI or counter events - · 32-bit velocity counter - · 32-bit position counter - · 32-bit index pulse counter - · 32-bit interval timer - · 32-bit position Initialization/Capture register - 32-bit Compare Less Than and Greater Than registers - · External Up/Down Count mode - · External Gated Count mode - · External Gated Timer mode - · Interval Timer mode Figure 30-1 illustrates the QEI block diagram. #### 30.1 QEI Control Registers #### TABLE 30-1: QEI1 THROUGH QEI6 REGISTER MAP | sse | | | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|---------------|--------|-------------------------------------|----------|------------|------------|----------|----------|-------------|--------|--------|------------|----------|--------|--------|--------|--------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | B200 | QEI1CON | 31:16 | _ | _ | 1 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | 0000 | | DEGG | | 15:0 | QEIEN | _ | QEISIDL | F | PIMOD<2:0> | | IMV< | :1:0> | _ | | INTDIV<2:0 | )> | CNTPOL | GATEN | | <1:0> | 0000 | | B210 | QEI1IOC | 31:16 | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | | HCAPEN | | | | | | QCAPEN | FLTREN | | QFDIV<2:0> | | OUTFN | IC<1:0> | SWPAB | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | 0000 | | B220 | QEI1STAT | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | | | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | 0000 | | B230 | POS1CNT | 31:16 | | | | | | | | OSCNT<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | OSCNT<15: | | | | | | | | | 0000 | | B240 | POS1HLD | 31:16 | | POSHLD<31:16> 000 POSHLD<15:0> 000 | | | | | | | | | | | | | 0000 | | | | | | 15:0 | | POSHLD<15:0> 000 VELCNT<31:16> 000 | | | | | | | | | | | | | | | | | B250 | VEL1CNT | 31:16 | | | | | | | | | | | | | | | | | | | | | 15:0<br>31:16 | | | | | | | | | | | | | | | | 0000 | | | B260 | VEL1HLD | 15:0 | | | | | | | | /ELHLD<31.1 | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | NTTMR<31:1 | | | | | | | | | + | | B270 | INT1TMR | 15:0 | | | | | | | | NTTMR<15:0 | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | NTHLD<31:1 | | | | | | | | | 0000 | | B280 | INT1HLD | 15:0 | | | | | | | | NTHLD<15:0 | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | DXCNT<31: | | | | | | | | | 0000 | | B290 | INDX1CNT | 15:0 | | | | | | | | IDXCNT<15 | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | DXHLD<31: | | | | | | | | | 0000 | | B2A0 | INDX1HLD | 15:0 | | | | | | | | NDXHLD<15 | | | | | | | | | 0000 | | | | 31:16 | | | | | | | C | EIICC<31:1 | 6> | | | | | | | | 0000 | | B2B0 | QEI1ICC | 15:0 | | | | | | | ( | QEIICC<15:0 | )> | | | | | | | | 0000 | | | | 31:16 | | | | | | | | | | | | | 0000 | | | | | | B2C0 | QEI1CMPL | 15:0 | | | | | | | | | | | | | 0000 | | | | | | D400 | 051000:: | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | B400 | QEI2CON | 15:0 | QEIEN | _ | QEISIDL | F | PIMOD<2:0> | | IMV< | :1:0> | _ | | INTDIV<2:0 | )> | CNTPOL | GATEN | CCM | <1:0> | 0000 | | D440 | 0510100 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | HCAPEN | 0000 | | B410 | QEI2IOC | 15:0 | QCAPEN | FLTREN | | QFDIV<2:0> | | OUTFN | IC<1:0> | SWPAB | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. TABLE 30-1: QEI1 THROUGH QEI6 REGISTER MAP (CONTINUED) | ess | | | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|---------------|--------|--------------------|------------|------------|-----------------|----------------|---------------|---------------------------|----------|-------------|---------------|--------------|----------|----------|-------------|-------------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | B420 | QEI2STAT | 31:16<br>15:0 | _ | _ | - PCHEOIRO | - PCHECIEN | PCI ECIRO | —<br>PCI ECIEN | —<br>POSOVIRQ | - POSOVJENI | - PCIIRQ | —<br>PCIIEN | —<br>VELOVIRQ | <br>VELOVIEN | - HOMIRO | - HOMIEN | —<br>IDXIRQ | -<br>IDXIEN | 0000 | | | | 31:16 | | | I OIILQIIQ | CHECKEN | I OLLQING | I OLLQILIN | l | OSCNT<31: | | I CIILIN | VLLOVINQ | VLLOVILIN | HOMING | HOMILIN | IDAIRQ | IDAILIN | 0000 | | B430 | POS2CNT | 15:0 | | | | | | | | OSCNT<15: | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | OSHLD<31: | | | | | | | | | 0000 | | B440 | POS2HLD | 15:0 | | | | | | | P | OSHLD<15: | 0> | | | | | | | | 0000 | | D450 | VELOCNIT | 31:16 | | | | | | | V | ELCNT<31:1 | 6> | | | | | | | | 0000 | | B450 | VEL2CNT | 15:0 | | | | | | | ١ | /ELCNT<15: | 0> | | | | | | | | 0000 | | B460 | VEL2HLD | 31:16 | | | | | | | V | ELHLD<31:1 | 6> | | | | | | | | 0000 | | D400 | VELZITED | 15:0 | | VELHLD<15:0> 0000 | | | | | | | | | | | | | | | | | B470 | INT2TMR | 31:16 | | INTTMR<31:16> 0000 | | | | | | | | | | | | | | | | | J 0 | | 15:0 | | INTTMR<15:0> 0000 | | | | | | | | | | | | | | | | | B480 | INT2HLD | 31:16 | | INTHLD<31:16> 0000 | | | | | | | | | | | | | | | | | | | 15:0 | | | | | | | | NTHLD<15:0 | | | | | | | | | 0000 | | B490 | INDX2CNT | 31:16 | | | | | | | | DXCNT<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | NDXCNT<15 | | | | | | | | | 0000 | | B4A0 | INDX2HLD | 31:16 | | | | | | | | DXHLD<31: | | | | | | | | | 0000 | | | | 15:0<br>31:16 | | | | | | | | NDXHLD<15:<br>QEIICC<31:1 | | | | | | | | | 0000 | | B4B0 | QEI2ICC | 15:0 | | | | | | | | QEIICC<31.1 | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | EICMPL<31: | | | | | | | | | 0000 | | B4C0 | QEI2CMPL | 15:0 | | | | | | | | EICMPL<15 | | | | | | | | | 0000 | | | | 31:16 | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | B600 | QEI3CON | 15:0 | QEIEN | _ | QEISIDL | ı | L<br>PIMOD<2:0> | | IMV< | :1:0> | _ | | INTDIV<2:0 | )> | CNTPOL | GATEN | CCM | <1:0> | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | HCAPEN | | | B610 | QEI3IOC | 15:0 | QCAPEN | FLTREN | | QFDIV<2:0> | | OUTFN | VC<1:0> | SWPAB | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | 0000 | | Door | OFICETIT | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | B620 | QEI3STAT | 15:0 | _ | _ | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | PCIIRQ | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | 0000 | | D620 | DOSCOUT | 31:16 | | | • | | | | P | OSCNT<31: | 16> | | | | • | | • | | 0000 | | B630 | POS3CNT | 15:0 | | | | | | | P | OSCNT<15: | 0> | | | | | | | | 0000 | | B640 | POS3HLD | 31:16 | | | | | | | P | OSHLD<31: | 16> | | | | | | | | 0000 | | 5040 | 1 OGGITED | 15:0 | | | | | | | P | OSHLD<15: | 0> | | | | | | | | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more Note 1: | <b>TABLE 30-1:</b> | <b>QEI1 THROUGH QEI6 REGISTER MAP (</b> | (CONTINUED) | 1 | |--------------------|-----------------------------------------|-------------|---| | | | | | | ess | | | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|---------------|------------|----------------------------------------|----------|--------------|-----------------|----------|----------|----------------|--------|--------|------------|----------|--------|--------|--------|--------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | B650 | VEL3CNT | 31:16 | | | | | | | V | ELCNT<31: | 16> | | | | | • | | | 0000 | | D030 | VELOCIVI | 15:0 | | | | | | | V | 'ELCNT<15: | 0> | | | | | | | | 0000 | | B660 | VEL3HLD | 31:16 | | | | | | | V | ELHLD<31: | 16> | | | | | | | | 0000 | | Вооо | VELOTIED | 15:0 | | | | | | | V | /ELHLD<15: | 0> | | | | | | | | 0000 | | B670 | INT3TMR | 31:16 | | | | | | | | NTTMR<31:1 | | | | | | | | | 0000 | | 20.0 | | 15:0 | | | | | | | | NTTMR<15: | | | | | | | | | 0000 | | B680 | INT3HLD | 31:16 | | INTHLD<31:16> 0000 INTHLD<15:0> 0000 | | | | | | | | | | | | | | | | | | | 15:0 | | INTHLD<15:0> 0000 INDXCNT<31:16> 0000 | | | | | | | | | | | | | | | | | B690 | INDX3CNT | 31:16 | | INDXCNT<31:16> 0000 INDXCNT<15:0> 0000 | | | | | | | | | | | | | | | | | | | 15:0 | | INDXCNT<15:0> 0000 | | | | | | | | | | | | | | | | | B6A0 | INDX3HLD | 31:16 | | INDXHLD<31:16> 0000 | | | | | | | | | | | | | | | | | | | 15:0 | | INDXHLD<15:0> 0000 | | | | | | | | | | | | | | | | | B6B0 | QEI3ICC | 31:16 | | QEIICC<31:16> 000 | | | | | | | | | | | | | | | | | | | 15:0<br>31:16 | | QEIICC<15:0> 0000 QEICMPL<31:16> 0000 | | | | | | | | | | | + | | | | | | B6C0 | QEI3CMPL | 15:0 | | | | | | | | EICMPL<15 | | | | | | | | | 0000 | | | | 31:16 | _ | _ | | _ | _ | _ | l _ | LICIVIF L < 13 | .o> | _ | _ | _ | _ | _ | | | 0000 | | B800 | QEI4CON | 15:0 | QEIEN | | QEISIDL | - | I<br>PIMOD<2:0> | | IMV< | :1:0> | _ | | INTDIV<2:0 | | CNTPOL | GATEN | CCM | /<1:0> | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | <u> </u> | _ | | _ | HCAPEN | | | B810 | QEI4IOC | | QCAPEN | FLTREN | | QFDIV<2:0> | | OUTFN | NC<1:0> | SWPAB | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | 0000 | | | | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | B820 | QEI4STAT | 15:0 | _ | _ | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | PCIIRQ | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | 0000 | | Dago | DOGAGNIT | 31:16 | | | | | | I | | OSCNT<31: | | | | I | | ı | I. | 1 | 0000 | | B830 | POS4CNT | 15:0 | | | | | | | Р | OSCNT<15 | :0> | | | | | | | | 0000 | | B840 | POS4HLD | 31:16 | | | | | | | P | OSHLD<31: | 16> | | | | | | | | 0000 | | D040 | PUS4FILD | 15:0 | | | | | | | Р | OSHLD<15 | :0> | | | | | | | | 0000 | | B850 | VEL4CNT | 31:16 | | | | | | | V | ELCNT<31: | 16> | | | | | | | | 0000 | | D000 | V LL4CINI | 15:0 | | | | | | | | 'ELCNT<15: | | | | | | | | | 0000 | | B860 | VEL4HLD | 31:16 | | | | | | | V | ELHLD<31: | 16> | | | | | | | | 0000 | | 5000 | * CLTITIED | 15:0 | | | | | | | | /ELHLD<15: | | | | | | | | | 0000 | | B870 | INT4TMR | 31:16 | | | | | | | | NTTMR<31:1 | | | | | | | | | 0000 | | 20.0 | | 15:0 | value en F | | | stad raad aa | | | ا ا | NTTMR<15: | 0> | | | | | | | | 0000 | x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. Note 1: | | <b>TABLE 30-1:</b> | <b>QEI1 THROUGH QEI6 REGISTER MAP (</b> | (CONTINUED) | |--|--------------------|-----------------------------------------|-------------| |--|--------------------|-----------------------------------------|-------------| | ess | | _ | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|---------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|----------|-------------------|-------------|--------|--------|----------|----------|--------|--------|--------|--------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | B880 | INT4HLD | 31:16 | | | <u> </u> | | | <u> </u> | II | NTHLD<31:1 | 6> | I | L | | | | | | 0000 | | Б000 | IN 14HLD | 15:0 | | | | | | | | NTHLD<15:0 | | | | | | | | | 0000 | | B890 | INDX4CNT | 31:16 | | | | | | | | DXCNT<31: | | | | | | | | | 0000 | | D000 | INDATOIN | 15:0 | | | | | | | | NDXCNT<15 | | | | | | | | | 0000 | | B8A0 | INDX4HLD | 31:16 | | | | | | | | DXHLD<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | NDXHLD<15 | | | | | | | | | 0000 | | B8B0 | QEI4ICC | 31:16 | | | | | | | | QEIICC<31:1 | | | | | | | | | 0000 | | | | 15:0 | | QEICC<15:0> 0000 QEICMPL<31:16> 0000 | | | | | | | | | | | | | | | | | B8C0 | QEI4CMPL | 31:16 | | | | | | | | | | | | | | | | | | | | | 15:0 | | QEICMPL<15:0> 0000 | | | | | | | | | | | | | | | | | BA00 | QEI5CON | 31:16 | | | | | | | | | | | | | | | | | | | | | 15:0 | QEIEN | EIEN | | | | | | | | | | | | | | | | | BA10 | QEI5IOC | 31:16<br>15:0 | OCAPEN | — — — — — — — — — — HCAPEN 0000 CAPEN FLTREN QFDIV<2:0> OUTFNC<1:0> SWPAB HOMPOL IDXPOL QEBPOL QEAPOL HOME INDEX QEB QEA 0000 | | | | | | | | | | | | 0000 | | | | | | | 31:16 | — | — | _ | — — | _ | _ | — | — | — | | — | — | | | — | — QL/1 | 0000 | | BA20 | QEI5STAT | 15:0 | | _ | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | PCIIRQ | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | 0000 | | | | 31:16 | | | | | | | | OSCNT<31: | | | | | | | | 1 | 0000 | | BA30 | POS5CNT | 15:0 | | | | | | | P | OSCNT<15: | 0> | | | | | | | | 0000 | | D 4 40 | D005111D | 31:16 | | | | | | | P | OSHLD<31: | 16> | | | | | | | | 0000 | | BA40 | POS5HLD | 15:0 | | | | | | | P | OSHLD<15: | 0> | | | | | | | | 0000 | | BA50 | VEL5CNT | 31:16 | | | | | | | V | ELCNT<31:1 | 6> | | | | | | | | 0000 | | DASU | VELOCIVI | 15:0 | | | | | | | \ | /ELCNT<15: | 0> | | | | | | | | 0000 | | BA60 | VEL5HLD | 31:16 | | | | | | | V | ELHLD<31:1 | 6> | | | | | | | | 0000 | | DAGO | VELSTILD | 15:0 | | | | | | | | /ELHLD<15: | | | | | | | | | 0000 | | BA70 | INT5TMR | 31:16 | | | | | | | II. | NTTMR<31:1 | 6> | | | | | | | | 0000 | | D/ (I O | | 15:0 | | | | | | | | NTTMR<15: | | | | | | | | | 0000 | | BA80 | INT5HLD | 31:16 | | | | | | | | NTHLD<31:1 | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | NTHLD<15:0 | | | | | | | | | 0000 | | BA90 | INDX5CNT | 31:16 | | | | | | | | DXCNT<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | NDXCNT<15 | | | | | | | | | 0000 | | BAA0 | INDX5HLD | 31:16 | | | | | | | | DXHLD<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | II<br>No in hevad | NDXHLD<15 | :0> | | | | | | | | 0000 | **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. | TABLE 30-1. QETT THROUGH QETO REGISTER WAF (CONTINUED) | <b>TABLE 30-1:</b> | <b>QEI1 THROUGH QEI6 REGISTER MAP (</b> | CONTINUED) | |--------------------------------------------------------|--------------------|-----------------------------------------|------------| |--------------------------------------------------------|--------------------|-----------------------------------------|------------| | SS | | | | | | | | | | Bits | | | | | | | | | | |-----------------------------|---------------------------------|---------------|---------|--------------------|---------|------------|------------|-------|-------------|--------------------------|--------|--------|-----------|--------|--------|-------|------|--------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | BAB0 | QEI5ICC | 31:16 | | | | | | | ( | QEIICC<31:1 | 6> | | | | | | | | 0000 | | DADU | QEISICO | 15:0 | | | | | | | ( | QEIICC<15:0 | )> | | | | | | | | 0000 | | BACO | QEI5CMPL | 31:16 | | | | | | | QI | EICMPL<31: | 16> | | | | | | | | 0000 | | DAGO | QLISOWII L | 15:0 | | QEICMPL<15:0> 0000 | | | | | | | | | | | | | | | | | BC00 | QEI6CON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | 0000 | | B000 | QLIOOON | 15:0 | QEIEN | _ | QEISIDL | l | PIMOD<2:0> | | IMV< | <1:0> | _ | | INTDIV<2: | | CNTPOL | GATEN | | <1:0> | 0000 | | BC10 | QEI6IOC | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | | HCAPEN | 0000 | | | | | QCAPEN | FLTREN | | QFDIV<2:0> | | OUTF | VC<1:0> | SWPAB | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | 0000 | | BC20 | QE6STAT | 31:16 | _ | _ | - | - | _ | _ | _ | _ | _ | - | 1 | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | | | | | | | | | | | | 0000 | | | | | | BC30 | POS6CNT | 31:16 | | POSCNT<31:16> 0000 | | | | | | | | | | | | | | | | | | | 15:0 | | POSCNT<15:0> 0000 | | | | | | | | | | | | | | | | | BC40 | POS6HLD | 31:16 | | | | | | | | OSHLD<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | POSHLD<15 | | | | | | | | | 0000 | | BC50 | VEL6CNT | 31:16 | | | | | | | | ELCNT<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | /ELCNT<15: | | | | | | | | | 0000 | | BC60 | VEL6HLD | 31:16 | | | | | | | | ELHLD<31: | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | /ELHLD<15: | | | | | | | | | 0000 | | BC70 | INT6TMR | 31:16 | | | | | | | | NTTMR<31:1 | | | | | | | | | 0000 | | | | 15:0 | | | | | | | | NTTMR<15: | | | | | | | | | 0000 | | BC80 | INT6HLD | 31:16 | | | | | | | | NTHLD<31:1 | | | | | | | | | 0000 | | | | 15:0<br>31:16 | | | | | | | | INTHLD<15:<br>IDXCNT<31: | | | | | | | | | 0000 | | BC90 | INDX6CNT | 15:0 | | | | | | | | NDXCNT<31. | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | IDXHLD<31: | | | | | | | | | 0000 | | BCA0 | INDX6HLD | 15:0 | | | | | | | | NDXHLD<31. | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | QEIICC<31:1 | | | | | | | | | | | BCB0 | QEI6ICC | 15:0 | | | | | | | | QEIICC<31.1 | | | | | | | | | 0000 | | | | 31:16 | | | | | | | | EICMPL<31: | | | | | | | | | 0000 | | BCC0 | QEI6CMPL | 15:0 | | | | | | | | EICMPL<15 | | | | | | | | | 0000 | | Lagan | | | <u></u> | | | | | | un in hoved | | .0- | | | | | | | | 0000 | **Legend:** x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: All registers in this table have corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. #### REGISTER 30-1: QEIXCON: QEIX CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|--------------------------|-------------------|-------------------|-------------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | | _ | _ | | _ | _ | _ | | 22,16 | U-0 | 23:16 | _ | - | _ | _ | | _ | _ | _ | | 45.0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 15:8 | QEIEN | — QEISIDL | | PIMOD<2:0>(1) | ) | IMV<1:0> <sup>(2)</sup> | | | | 7.0 | U-0 | U-0 U-0 U-0 | | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | 11 | NTDIV<2:0> <sup>(3</sup> | 3) | CNTPOL | GATEN | CCM- | <1:0> | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 QEIEN: Quadrature Encoder Interface Module Counter Enable bit 1 = Module counters are enabled 0 = Module counters are disabled, but SFRs can be read or written bit 14 Unimplemented: Read as '0' bit 13 QEISIDL: Stop in Idle Mode bit 1 = Discontinue module operation when device enters Idle mode 0 = Continue module operation in Idle mode bit 12-10 PIMOD<2:0>: Position Counter Initialization Mode Select bits(1) 111 = Modulo Count mode for position counter and every index event resets the position counter 110 = Modulo Count mode for position counter 101 = Resets the position counter when the position counter equals QEIxICCH register 100 = Second index event after home event initializes position counter with contents of QEIxICCH register 011 = First index event after home event initializes position counter with contents of QEIxICCH register 010 = Next index input event initializes the position counter with contents of QEIxICCH register 001 = Every Index input event resets the position counter 000 = Index input event does not affect position counter bit 9-8 IMV<1:0>: Index Match Value bits(2) 11 =Index match occurs when QEB = 1 and QEA = 1 10 =Index match occurs when QEB = 1 and QEA = 0 01 =Index match occurs when QEB = 0 and QEA = 1 00 = Index match occurs when QEB = 0 and QEA = 0 bit 7 **Unimplemented:** Read as '0' **Note 1:** When CCM equals modes '01', '10', and '11', all of the QEI counters operate as timers and the PIMOD<2:0> bits are ignored. 2: When CCM = 00 and QEA and QEB values match Index Match Value (IMV), the POSxCNTH and POSxCNTL registers are reset. 3: The selected clock rate should be at least twice the expected maximum quadrature count rate. #### REGISTER 30-1: QEIXCON: QEIX CONTROL REGISTER (CONTINUED) - bit 6-4 **INTDIV<2:0>:** Timer Input Clock Prescale Select bits (Interval timer, Main timer (position counter), velocity counter and index counter internal clock divider select)<sup>(3)</sup> - 111 = 1:128 prescale value - 110 = 1:64 prescale value - 101 = 1:32 prescale value - 100 = 1:16 prescale value - 011 = 1:8 prescale value - 010 = 1:4 prescale value - 001 = 1:2 prescale value - 000 = 1:1 prescale value - bit CNTPOL: Position and Index Counter/Timer Direction Select bit - 1 = Counter direction is negative unless modified by external Up/Down signal - 0 = Counter direction is positive unless modified by external Up/Down signal - bit GATEN: External Count Gate Enable bit - 1 = External gate signal controls position counter operation - 0 = External gate signal does not affect position counter/timer operation - bit CCM<1:0>: Counter Control Mode Selection bits - 11 = Internal Timer mode with optional QEB external clock gating input control based on GATEN. QEB High = Timer Run, QEB Low = Timer Stop. - 10 = QEA is the external clock input, QEB is optional clock gating input control based on GATEN. QEB High= Clock Run, QEB Low = Clock Stop. - 01 = QEA is the external clock input, QEB is external UP/DN direction input. (QEB High = Count Up, QEB Low = Count Down) - 00 = Quadrature Encoder Interface Count mode (x4 mode) - **Note 1:** When CCM equals modes '01', '10', and '11', all of the QEI counters operate as timers and the PIMOD<2:0> bits are ignored. - 2: When CCM = 00 and QEA and QEB values match Index Match Value (IMV), the POSxCNTH and POSxCNTL registers are reset. - 3: The selected clock rate should be at least twice the expected maximum quadrature count rate. #### REGISTER 30-2: QEIXIOC: QEIX I/O CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 21.24 | U-0 | U-0 | U-0 U-0 | | U-0 U-0 | | U-0 | U-0 | | 31:24 | _ | | _ | | | _ | _ | _ | | 22:16 | U-0 | U-0 | U-0 U-0 | | U-0 | U-0 | U-0 | R/W-0 | | 23:16 | - | - | _ | 1 | | _ | _ | HCAPEN | | 45.0 | R/W-0 | 15:8 | QCAPEN | FLTREN | | QFDIV<2:0> | • | OUTFN | C<1:0> | SWPAB | | 7.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-x | R-x | R-x | R-x | | 7:0 | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-17 Unimplemented: Read as '0' bit 16 HCAPEN: Position Counter Input Capture by Home Event Enable bit 1 = HOMEx input event (positive edge) triggers a position capture event 0 = HOMEx input event (positive edge) does not trigger a position capture event bit 15 QCAPEN: Position Counter Input Capture Enable bit 1 = Positive edge detect of Home input triggers position capture function 0 = Home input event (positive edge) does not trigger a capture even bit 14 FLTREN: QEA/QEB/INDX/HOMEx Digital Filter Enable bit 1 = Input Pin Digital filter is enabled 0 = Input Pin Digital filter is disabled (bypassed) bit 13-11 QFDIV<2:0>: QEA/QEB/INDX/HOMEx Digital Input Filter Clock Select bits 111 = 1:128 clock divide 110 = 1:64 clock divide 101 = 1:32 clock divide 100 = 1:16 clock divide 011 = 1:8 clock divide 010 = 1:4 clock divide 001 = 1:2 clock divide 000 = 1:1 clock divide bit 10-9 OUTFNC<1:0>: QEI Module Output Function Mode Select bits 11 = The CNTCMPx pin goes high when POSxCNT ≤ QEIxCMPL or POSxCNT ≥ QEIxICCH 10 = The CNTCMPx pin goes high when POSxCNT $\leq$ QEIxCMPL 01 = The CNTCMPx pin goes high when POSxCNT ≥ QEIxICCH 00 = Output is disabled bit 8 **SWPAB:** Swap QEA and QEB Inputs bit 1 = QEAx and QEBx are swapped prior to quadrature decoder logic 0 = QEAx and QEBx are not swapped bit 7 HOMPOL: HOMEx Input Polarity Select bit 1 = Input is inverted 0 = Input is not inverted bit 6 IDXPOL: INDXx Input Polarity Select bit 1 = Input is inverted 0 = Input is not inverted bit 5 QEBPOL: QEBx Input Polarity Select bit 1 = Input is inverted 0 = Input is not inverted ``` REGISTER 30-2: QEIXIOC: QEIX I/O CONTROL REGISTER (CONTINUED) bit 4 QEAPOL: QEAx Input Polarity Select bit 1 = Input is inverted 0 = Input is not inverted bit 3 HOME: Status of HOMEx Input Pin after Polarity Control bit (read-only) 1 = Pin is at logic '1', if HOMPOL bit is set to '0' Pin is at logic '0'. if HOMPOL bit is set to '1' 0 = Pin is at logic '0', if HOMPOL bit is set to '0' Pin is at logic '1', if HOMPOL bit is set to '1' bit 2 INDEX: Status of INDXx Input Pin after Polarity Control bit (Read-Only) 1 = Pin is at logic '1', if IDXPOL bit is set to '0' Pin is at logic '0', if IDXPOL bit is set to '1' 0 = Pin is at logic '0', if IDXPOL bit is set to '0' Pin is at logic '1', if IDXPOL bit is set to '1' bit 1 QEB: Status of QEBx Input Pin after Polarity Control and SWPAB Pin Swapping bit (read-only) 1 = Physical pin QEB is at logic '1', if QEBPOL bit is set to '0' and SWPAB bit is set to '0' Physical pin QEB is at logic '0', if QEBPOL bit is set to '1' and SWPAB bit is set to '0' Physical pin QEA is at logic '1', if QEBPOL bit is set to '0' and SWPAB bit is set to '1' Physical pin QEA is at logic '0', if QEBPOL bit is set to '1' and SWPAB bit is set to '1' 0 = Physical pin QEB is at logic '0', if QEBPOL bit is set to '0' and SWPAB bit is set to '0' Physical pin QEB is at logic '1', if QEBPOL bit is set to '1' and SWPAB bit is set to '0' Physical pin QEA is at logic '0', if QEBPOL bit is set to '0' and SWPAB bit is set to '1' Physical pin QEA is at logic '1', if QEBPOL bit is set to '1' and SWPAB bit is set to '1' bit 0 QEA: Status of QEAx Input Pin after Polarity Control and SWPAB Pin Swapping bit (read-only) 1 = Physical pin QEA is at logic '1', if QEAPOL bit is set to '0' and SWPAB bit is set to '0' Physical pin QEA is at logic '0', if QEAPOL bit is set to '1' and SWPAB bit is set to '0' Physical pin QEB is at logic '1', if QEAPOL bit is set to '0' and SWPAB bit is set to '1' Physical pin QEB is at logic '0', if QEAPOL bit is set to '1' and SWPAB bit is set to '1' 0 = Physical pin QEA is at logic '0', if QEAPOL bit is set to '0' and SWPAB bit is set to '0' Physical pin QEA is at logic '1', if QEAPOL bit is set to '1' and SWPAB bit is set to '0' Physical pin QEB is at logic '0', if QEAPOL bit is set to '0' and SWPAB bit is set to '1' Physical pin QEB is at logic '1', if QEAPOL bit is set to '1' and SWPAB bit is set to '1' ``` #### REGISTER 30-3: QEIXSTAT: QEIX STATUS REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit Bit 29/21/13/5 28/20/12/4 | | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-----------------------|-------------------|-------------------------------|----------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | | _ | _ | _ | | 00:40 | U-0 | 23:16 | _ | _ | | | - | U-0 U-0 U-0 U-0 | _ | | | 45.0 | U-0 | U-0 | RC-0, HS | R/W-0 | RC-0, HS | R/W-0 | RC-0, HS | R/W-0 | | 15:8 | _ | _ | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | | 7.0 | RC-0, HS | R/W-0 | RC-0, HS | R/W-0 | RC-0, HS | R/W-0 | RC-0, HS | R/W-0 | | 7:0 | PCIIRQ <sup>(1)</sup> | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-14 Unimplemented: Read as '0' bit 13 PCHEQIRQ: Position Counter Greater Than or Equal Compare Status bit 1 = POSxCNT > QEIxICCH 0 = POSxCNT < QEIxICCH bit 12 **PCHEQIEN:** Position Counter Greater Than or Equal Compare Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 11 PCLEQIRQ: Position Counter Less Than or Equal Compare Status bit 1 = POSxCNT < QEIxCMPL 0 = POSxCNT > QEIxCMPL bit 10 PCLEQIEN: Position Counter Less Than or Equal Compare Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 9 POSOVIRQ: Position Counter Overflow Status bit 1 = Overflow has occurred 0 = No overflow has occurred bit 8 POSOVIEN: Position Counter Overflow Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 7 **PCIIRQ:** Position Counter (Homing) Initialization Process Complete Status bit<sup>(1)</sup> 1 = POSxCNT was reinitialized0 = POSxCNT was not reinitialized bit 6 PCIIEN: Position Counter (Homing) Initialization Process Complete Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 5 **VELOVIRQ:** Velocity Counter Overflow Status bit 1 = Overflow has occurred0 = No overflow has not occurred VELOVIEN: Velocity Counter Overflow Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled **Note 1:** This status bit in only applies to PIMOD<2:0> modes '011' and '100'. bit 4 #### REGISTER 30-3: QEIXSTAT: QEIX STATUS REGISTER (CONTINUED) bit 3 **HOMIRQ:** Status Flag for Home Event Status bit 1 = Home event has occurred 0 = No Home event has occurred bit 2 **HOMIEN:** Home Input Event Interrupt Enable bit 1 = Interrupt is enabled 0 = Interrupt is disabled bit 1 IDXIRQ: Status Flag for Index Event Status bit 1 = Index event has occurred0 = No Index event has occurred IDXIEN: Index Input Event Interrupt Enable bit 1 = Interrupt is enabled bit 0 0 = Interrupt is disabled Note 1: This status bit in only applies to PIMOD<2:0> modes '011' and '100'. #### REGISTER 30-4: POSxCNT: POSITION COUNTER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--| | 24.24 | R/W-0 | | | | | | | 31:24 | POSCNT<31:24> | | | | | | | | | | | | | | | 00.40 | R/W-0 | R/W-0 R/W-0 | | R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | | | | | | | | 23:16 | POSCNT<23:16> | | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | 15:8 | POSCNT<15:8> | | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | | 7:0 | | | | POSCN | NT<7:0> | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 POSCNT<31:0>: 32-bit Position Counter Register bits The Operating mode of the position counter is controlled by the CCM bit in the QEIxCON register. **Quadrature Count mode:** The QEA and QEB inputs are decoded to generate count pulses and direction information for controlling the position counter operation. **External Count with External Up/Down mode:** The QEA/EXTCNT input is treated as an external count signal, and the QEB/DIR/GATE input provides the count direction information. **External Count with External Gate mode:** The QEA/EXTCNT input is treated as an external count signal. If the GATEN bit in the QEIxCON register is equal to '1', the QEB/DIR/GATE input will gate the counter signal. **Internal Timer mode:** The position counter uses PBCLK2 divided by the clock divider INTDIV as the count source. #### REGISTER 30-5: VELxCNT: VELOCITY COUNTER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit Bit Bit Bit 29/21/13/5 28/20/12/4 | | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------|---------------------------------------|-------------|-------------------|-------------------|------------------|------------------|-------|--|--|--|--|--| | 24.24 | R/W-0 | | | | | | 31:24 | | | | VELCNT | <31:24> | | | | | | | | | | 22.46 | R/W-0 | R/W-0 | R/W-0 | R/W-0 R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | | | | | | | 23:16 | VELCNT<23:16> | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | 15:8 | VELCNT<15:8> | | | | | | | | | | | | | | 7.0 | R/W-0 | R/W-0 | R/W-0 R/W-0 | | R/W-0 R/W-0 | | R/W-0 | R/W-0 | | | | | | | 7:0 | | | | VELCN | IT<7:0> | | · | | | | | | | | Legend: | | | | |-------------------|------------------|-----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit | t, read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | #### bit 31-0 VELCNT<31:0>: 32-bit Velocity Counter bits The velocity counter is automatically cleared after every processor read of the velocity counter. It is not reset by the index input or otherwise affected by any of the PIMOD<2:0> specified modes. The contents of the counter represents the distance traveled during the time between samples. Velocity equals the distance traveled per unit of time. The velocity counter can save the application software the trouble of performing 32-bit math operations between current and previous position counter values to calculate velocity. If the velocity counter rolls over from 0x7FFFFFFF to 0x80000000, or from 0x80000000 to 0x7FFFFFFF, an overflow/underflow condition is detected. If the VELOVIEN bit is set in the QEISTAT register, an interrupt will be generated. #### REGISTER 30-6: VELXHLD: VELOCITY HOLD REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--| | 21.24 | R/W-0 | | | | | | | 31:24 | VELHLD<31:24> | | | | | | | | | | | | | | | 00:40 | R/W-0 | R/W-0 | R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | | 23:16 | VELHLD<23:16> | | | | | | | | | | | | | | | 45.0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | | | | | 15:8 | VELHLD<15:8> | | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | | 7:0 | | | | VELHL | D<7:0> | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 VELHLD<31:0>: 32-bit Velocity Hold bits When VELxCNT is read, the contents are captured at the same time into the VELxHLD register. #### REGISTER 30-7: INTXHLD: INTERVAL TIMER HOLD REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit Bit 29/21/13/5 28/20/12/4 | | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------|-------------------|-------------------------------|-------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--| | 24.04 | R/W-0 | | | | | | | 31:24 | INTHLD<31:24> | | | | | | | | | | | | | | | 23:16 | R/W-0 | | | | | | | | INTHLD<23:16> | | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | 15:8 | INTHLD<15:8> | | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | | 7:0 | INTHLD<7:0> | | | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 INTHLD<31:0>: 32-bit Index Counter Hold bits When the next count pulse is detected, the current contents of the interval timer (INTxTMR) are transferred to the Interval Hold register (INTxHLD) and the interval timer is cleared and the process repeats. #### REGISTER 30-8: INDxCNT: INDEX COUNTER REGISTER | Bit<br>Range | | | | | Bit<br>27/19/11/3 | | | Bit<br>24/16/8/0 | | | | | | | |--------------|----------------|-------------|-------------------|--------|-------------------|-------|-------|------------------|--|--|--|--|--|--| | 24.24 | R/W-0 | R/W-0 R/W-0 | | R/W-0 | R/W-0 R/W-0 | | R/W-0 | R/W-0 | | | | | | | | 31:24 | INDxCNT<31:24> | | | | | | | | | | | | | | | 00:40 | R/W-0 | R/W-0 | R/W-0 R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | | 23:16 | INDxCNT<23:16> | | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | 15:8 | INDxCNT<15:8> | | | | | | | | | | | | | | | 7.0 | R/W-0 | R/W-0 | R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | | 7:0 | | | | INDxCN | NT<7:0> | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 IDXCNT<31:0>: 32-bit Position Counter bits #### REGISTER 30-9: INTXTMR: INTERVAL TIMER REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | | | Bit Bit 28/20/12/4 27/19/11/3 | | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | |--------------|-------------------|-------------------|-------|-------------------|-------------------------------|-------|------------------|------------------|--|--|--|--|--|--| | 04:04 | R/W-0 | | | | | | | 31:24 | INTTMR<31:24> | | | | | | | | | | | | | | | 23:16 | R/W-0 | R/W-0 | R/W-0 | R/W-0 R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | | | | | | | | | INTTMR<23:16> | | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | 15:8 | INTTMR<15:8> | | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | | 7:0 | | | | INTTM | R<7:0> | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 INTTMR<31:0>: 32-bit Interval Timer Counter bits The INTxTMR register provides a means to measure the time between each decoded quadrature count pulse to yield improved velocity information. The interval timer should be set to run at a frequency chosen such that the counter does not overflow at the expected minimum operating speed of the motor. The interval timer is automatically cleared when a count pulse is detected. The timer then counts at the specified rate based on the setting of the INTDIV bit in the QEIxCON register. #### REGISTER 30-10: QEIXICC: QEIX INITIALIZE/CAPTURE/COMPARE REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--|--| | 21.24 | R/W-0 | | | | | | | | 31:24 | | ICCH<31:24> | | | | | | | | | | | | | | | 00.46 | R/W-0 | R/W-0 | R/W-0 R/W-0 R | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | | | 23:16 | ICCH<23:16> | | | | | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | | 15:8 | ICCH<15:8> | | | | | | | | | | | | | | | | 7.0 | R/W-0 | R/W-0 | R/W-0 R/W-0 R/W- | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | | | | 7:0 | | | | ICCH | <7:0> | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 ICCH<31:0>: 32-bit Initialize/Capture/Compare High bits #### REGISTER 30-11: QEIXCMPL: CAPTURE LOW REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--|--| | 24.24 | R/W-0 | | | | | | | | 31:24 | | CMPL<31:24> | | | | | | | | | | | | | | | 00.40 | R/W-0 | R/W-0 R/W-0 | | R/W-0 R/W-0 | | R/W-0 | R/W-0 | R/W-0 | | | | | | | | | 23:16 | | | | CMPL< | <23:16> | | | | | | | | | | | | 45.0 | R/W-0 | | | | | | | | 15:8 | CMPL<15:8> | | | | | | | | | | | | | | | | 7.0 | R/W-0 | | | | | | | | 7:0 | | | | CMPL | _<7:0> | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-0 CMPL<31:0>: 32-bit Compare Low Value bits # 31.0 MOTOR CONTROL PWM MODULE Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to **Section 44.** "**Motor Control PWM (MCPWM)**" (DS60001393), which is available from the *Documentation > Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32). The PIC32MK GPK/MCM with CAN FD Family of devices support a dedicated Motor Control Pulse-Width Modulation (PWM) module with up to 24 outputs. The Motor Control PWM module consists of the following key features: - Two master time base modules with special event triggers - · PWM module input clock prescaler - · Two synchronization inputs - · Two synchronization outputs - 12 PWM generators with complimentary output pairs - Four PWM generators with considerable single ended outputs - Period, duty cycle, phase shift and dead time minimum resolution of 1/FSYSCLK in Edge-Aligned mode and 2/FSYSCLK minimum resolution in Center-Aligned mode - Cycle-by-cycle fault recovery and latched fault modes - · PWM time-base capture upon current limit - Nine fault input pins are available for faults and current limits - Programmable analog-to-digital trigger with interrupt for each PWM pair - · Complementary PWM outputs - · Push-Pull PWM outputs - · Redundant PWM outputs - Edge-Aligned PWM mode - Center-Aligned PWM mode - · Variable Phase PWM mode - · Multi-Phase PWM mode - · Fixed-Off Time PWM mode - · Current Limit PWM mode - · Current Reset PWM mode - PWMxH and PWMxL output override control - · PWMxH and PWMxL output pin swapping - Chopping mode (also known as Gated mode) - · Dead time insertion - · Dead time compensation - Enhanced Leading-Edge Blanking (LEB) - · 15 mA PWM pin output drive The Motor Control PWM module contains up to twelve PWM generators. Two master time base generators provide a synchronous signal as a common time base to synchronize the various PWM outputs. Each generator can operate independently or in synchronization with either of the two master time bases. The individual PWM outputs are available on the output pins of the device. The input Fault signals and current-limit signals, when enabled, can monitor and protect the system by placing the PWM outputs into a known "safe" state. Each PWM can generate a trigger to the ADC module to sample the analog signal at a specific instance during the PWM period. In addition, the Motor Control PWM module also generates two Special Event Triggers to the ADC module based on the two master time bases. PWM generators 1 through 12 have two outputs, PWMxH and PWMxL, brought out to the dedicated pins. Independent complimentary PWM output supported on PWMs 1-6 by multiplexing PWM 7-12 PWMH outputs onto PWM 1-6 PWML outputs, based on the PWMAPINx bits in the CFGCON register. The configuration bits PWMAPINx (CFGCON<23:18>) contain bits that arbitrate which PWM takes control of the PWMxL (where 'x' = 1-6) output pins. This is in addition to PENx control bits which decide the if the MCPWM module of the I/O module assumes ownership of the output pin. Figure 31-1 illustrates an architectural overview of the Motor Control PWM module and its interconnection with the CPU and other peripherals. #### 31.1 PWM Faults The PWM module incorporates multiple external Fault inputs to include FLT1 and FLT2, which are remappable using the PPS feature, and FLT15, which has been implemented with Class B safety features, and is available on a fixed pin at reset for Fault detection. Fault pins are selectable for active level (active high or low). FLT pins provide a safe and reliable way to shut down the PWM outputs, tri-state, when the Fault input is asserted. Therefore, the user should provide the necessary external pull-up or pull-down to disable the high or low side FETs in motor control applications. #### 31.1.1 PWM FAULTS AT RESET During any reset event, the PWM module maintains ownership of the Class B fault FLT15. At reset, this fault is enabled in latched mode to guarantee the fail-safe power-up of the application. The application software must clear the PWM fault before enabling the High-Speed Motor Control PWM module. To clear the fault condition, the FLT15 pin must first be pulled low externally or the internal pull down resistor in the CNPDx register can be enabled. Note: The Fault mode may be changed using the FLTMOD<1:0> bits (IOCONx<17:16>) regardless of the state of FLT15. #### 31.1.2 WRITE-PROTECTED REGISTERS Write protection is implemented for the IOCONx register. The write protection feature prevents any inadvertent writes. This protection feature can be controlled by the PWMLOCK Configuration bit (DEVCFG3<20>). The default state of the write protection feature is disabled (PWMLOCK = 1). The write protection feature can be enabled by configuring the PWMLOCK = 0. To gain write access, the application software must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation. The write access to the IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. Every write to the IOCONx register requires a prior unlock operation. The unlocking sequence is described in Example 31-1. Figure 31-3 shows the register interconnection diagram for the Motor Control PWM module. #### **EXAMPLE 31-1: PWM WRITE-PROTECTED REGISTER UNLOCK SEQUENCE** ``` Untested Code - For Information Purposes Only ; In the default Reset state, the FLT15 pin must be pulled low externally to clear and disable ; the fault. ; Writing to IOCONx register requires unlock sequence di ehb ;Disable interrupts #0xXXXX.r3 ; Move desired IOCON4 register data to r3 register mov. #0xabcd,r1 ;Load first unlock key to r1 register mov #0x4321,r2 ;Load second unlock key to r2 register mov r1, PWMKEY ;Write first unlock key to PWMKEY register mov r2, PWMKEY ;Write second unlock key to PWMKEY register mov r3, IOCON4 ;Write desired value to IOCON SFR for channel 4 mov mfc0 v0,c0 status v0, v0, 0x1 ori mtc0 v0,c0_status ehb ; Re-enable Interrupts ``` ### 31.2 Motor Control PWM Control Registers #### TABLE 31-1: MCPWM REGISTER MAP | | LL 31-1. | MICE WIN REGISTER MAF | | | | | | | | | | | | | | | | | | |-----------------------------|------------------|-----------------------|----------|---------|--------|---------|--------|--------|--------|---------|---------|--------|----------|----------|---------|--------|---------|-------|------------| | ess | | | | | | | | | | Bits | | | | | | | | | <b>"</b> | | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | A000 | PTCON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PTEN | _ | PTSIDL | SESTAT | SEIEN | PWMRDY | _ | _ | _ | P | CLKDIV<2 | :0> | | SEVT | PS<3:0> | | 0000 | | A010 | PTPER | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PTPER<1 | 15:0> | | | | | | | | 0020 | | A020 | SEVTCMP | 31:16 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | ; | SEVTCMP | <15:0> | | | | | | | | 0000 | | A030 | PMTMR | 31:16 | _ | _ | - | _ | I | _ | 1 | 1 | | 1 | - | 1 | 1 | 1 | - | _ | 0000 | | | | 15:0 | | | | | | | | PMTMR< | 15:0> | | | | | | | | 0000 | | A040 | STCON | 31:16 | _ | - | ı | _ | I | _ | I | I | | 1 | 1 | I | I | I | | _ | 0000 | | | | 15:0 | _ | _ | - | SSESTAT | SSEIEN | _ | 1 | 1 | | S | CLKDIV<2 | :0> | | SEVT | PS<3:0> | | 0000 | | A050 | STPER | 31:16 | _ | _ | - | _ | ı | _ | I | - | _ | - | | 1 | 1 | - | _ | _ | 0000 | | | | 15:0 | | | | | | | | STPER<1 | 15:0> | | | | | | | | 0020 | | A060 | SSEVTCMP | 31:16 | _ | _ | - | _ | I | _ | 1 | 1 | | 1 | - | 1 | 1 | 1 | - | _ | 0000 | | | | 15:0 | | | | | | | S | SEVTCMF | P<15:0> | | | | | | | | 0000 | | A070 | SMTMR | 31:16 | _ | _ | - | _ | I | _ | 1 | 1 | | 1 | - | 1 | 1 | 1 | - | _ | 0000 | | | | 15:0 | | | | | | | | SMTMR< | 15:0> | | | | | | | | 0000 | | A080 | CHOP | 31:16 | _ | _ | _ | _ | - | _ | 1 | _ | _ | _ | _ | 1 | _ | _ | _ | _ | 0000 | | | | | CHPCLKEN | _ | | _ | | _ | | | | | CHOP | CLK<9:0> | | | | | 0000 | | A090 | PWMKEY | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PWMKEY< | <15:0> | | | | | | | | 0000 | | A0C0 | PWMCON1 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | | _ | FLTIEN | CLIEN | | | PWMHIEN | | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | _ | DTC< | :1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | A0D0 | IOCON1 | 31:16 | _ | _ | | CLSR | | | CLPOL | CLMOD | _ | | | RC<3:0> | | FLTPOL | FLTMO | | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | T<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A0E0 | PDC1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PDC<15 | 5:0> | | | | | | | | 0000 | | A0F0 | SDC1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | SDC<15 | 5:0> | | | | | | | | 0000 | | A100 | PHASE1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PHASE<1 | 15:0> | | | | | | | | 0000 | | A110 | DTR1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | PIC32MK GPK/MCM with CAN FD Family TABLE 31-1: MCPWM REGISTER MAP (CONTINUED) | sss | | | | | | | | | | Bits | | | | | | | | | | |------------|---------------|-----------|---------|---------|--------|--------|----------|---------|--------|---------|--------|---------|--------|----------------|----------------|--------|---------|---------|------------| | | gister<br>ame | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | A120 ALTD | TR1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | ALTDTR | <13:0> | | | | | | | 0000 | | A130 DTCO | OMP1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | COMP | <13:0> | | | | | | | 0000 | | A140 TRIG1 | 1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TRGCMP< | :15:0> | | | | | | | | 0000 | | A150 TRGC | CON1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | TRGDI\ | /<3:0> | | TRGSE | L<1:0> | STRGSI | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A160 STRIC | G1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | , | STRGCMP | <15:0> | | | | | | | | 0000 | | A170 CAP1 | 1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | • | • | • | | | CAP<15 | 5:0> | • | | • | | • | • | • | 0000 | | A180 LEBC | CON1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A190 LEBD | DLY1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | • | | LEB | <11:0> | • | | • | • | • | 0000 | | A1A0 AUXC | CON1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOPS | SEL<3:0> | | CHOPHEN | CHOPLEN | 10000 | | A1B0 PTMR | ₹1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | · | TMR<15 | 5:0> | | | | | | | · | 0000 | | A1C0 PWM0 | ICON2 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | <b>PWMLIEN</b> | <b>PWMHIEN</b> | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | _ | DTC< | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | A1D0 IOCOI | N2 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTS | RC<3:0> | l | FLTPOL | FLTMC | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | \T<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A1E0 PDC2 | 2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | ı | 1 | PDC<15 | 5:0> | ı | | | | | | | 0000 | | A1F0 SDC2 | 2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | ı | 1 | SDC<15 | 5:0> | ı | | | | | | | 0000 | | A200 PHAS | SE2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | 1 | | PHASE<1 | 15:0> | | | | | | | | 0000 | | A210 DTR2 | 2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | | A220 ALTD | TR2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | | | | | ALTDTR | !<13:0> | | | | | | | 0000 | | <u> </u> | | | | | 1 | | | | | | .=. = | | | | | | | | 1 | | <b>TABLE 31-1:</b> | MCPWM REGISTER MAP ( | (CONTINUED) | |--------------------|----------------------|-------------| | | | | | sse | | | 21 <b>4414</b> 1 13 | | | ` | | | | Bits | | | | | | | | | | |-----------------------------|------------------|-----------|---------------------|---------|--------|--------|----------|---------|--------|---------|--------|---------|--------|---------|----------|--------|---------|---------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | DTCOMP2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | • | | | | | COMP- | <13:0> | • | | | | | | 0000 | | A240 | TRIG2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TRGCMP< | 15:0> | | | | | | | | 0000 | | A250 | TRGCON2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | TRGDIV | /<3:0> | • | TRGSE | L<1:0> | STRGS | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A260 | STRIG2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | • | | • | • | • | | STRGCMP | <15:0> | | | • | • | • | • | • | 0000 | | A270 | CAP2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | • | | • | • | • | | CAP<15 | 5:0> | | | • | • | • | • | • | 0000 | | A280 | LEBCON2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A290 | LEBDLY2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | LEB | <11:0> | | | | | | 0000 | | A2A0 | AUXCON2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOPS | SEL<3:0> | • | CHOPHEN | CHOPLEN | 0000 | | A2B0 | PTMR2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | • | | • | • | • | | TMR<15 | 5:0> | | | • | • | • | • | • | 0000 | | A2C0 | PWMCON3 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | _ | DTC | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | A2D0 | IOCON3 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTS | RC<3:0> | • | FLTPOL | FLTMO | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | AT<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A2E0 | PDC3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PDC<15 | 5:0> | | | | | | | | 0000 | | A2F0 | SDC3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | • | • | | | SDC<15 | 5:0> | • | | | • | • | • | • | 0000 | | A300 | PHASE3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | • | • | | | PHASE<1 | 15:0> | • | | | • | • | • | • | 0000 | | A310 | DTR3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | | A320 | ALTDTR3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | ALTDTF | R<13:0> | | | | | | | 0000 | | A330 | DTCOMP3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | COMP- | <13:0> | | | | | | | 0000 | | <u> </u> | 1 | | | | | | | | | | | | | | | | | | | TABLE 31-1: MCPWM REGISTER MAP (CONTINUED) | SS | | | | | | ` | | | | Bits | | | | | | | | | | |-----------------------------|------------------|-----------|---------|---------|--------|--------|----------|---------|--------|---------|--------|---------|--------|---------|----------------|--------|---------|---------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | A340 | TRIG3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | • | | • | | | TRGCMP< | <15:0> | | | | | | • | | 0000 | | A350 | TRGCON3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | TRGDI\ | /<3:0> | | TRGSE | L<1:0> | STRGSE | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A360 | STRIG3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | 5 | STRGCMP | <15:0> | | | | | | | | 0000 | | A370 | CAP3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CAP<15 | 5:0> | | | | | | | | 0000 | | A380 | LEBCON3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A390 | LEBDLY3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | LEB | <11:0> | | | | | | 0000 | | A3A0 | AUXCON3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOPS | SEL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | A3B0 | PTMR3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TMR<15 | 5:0> | | | | | | | | 0000 | | A3C0 | PWMCON4 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | <b>PWMHIEN</b> | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | _ | DTC- | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | A3D0 | IOCON4 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTS | RC<3:0> | | FLTPOL | FLTMO | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | T<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A3E0 | PDC4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | • | • | - | • | | | PDC<15 | 5:0> | | • | | - | | • | | 0000 | | A3F0 | SDC4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | SDC<15 | 5:0> | | | | | | | | 0000 | | A400 | PHASE4 | 31:16 | _ | _ | _ | _ | _ | - | 1 | I | _ | _ | _ | _ | _ | - | _ | - | 0000 | | | | 15:0 | | | | | | | | PHASE< | 15:0> | | | | | | | | 0000 | | A410 | DTR4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | | A420 | ALTDTR4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | ALTDTF | R<13:0> | | | | | | | 0000 | | A430 | DTCOMP4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | COMP | <13:0> | | | | | | | 0000 | | A440 | TRIG4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | | _ | | _ | _ | 0000 | | | | 15:0 | | | | | | | | TRGCMP< | <15:0> | | | | | | | | 0000 | | IABLE 31-1. INICENTIAL REGISTER MAP (CONTINUED | <b>TABLE 31-1:</b> | MCPWM REGISTER MAP | (CONTINUED) | |------------------------------------------------|--------------------|--------------------|-------------| |------------------------------------------------|--------------------|--------------------|-------------| | SS | | | | | | ` | • | | | Bits | | | | | | | | | | |-----------------------------|------------------|-----------|---------|---------|--------|--------|----------|---------|--------|---------|--------|---------|--------|---------|----------|--------|---------|---------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | TRGCON4 | 31:16 | _ | _ | _ | | _ | _ | _ | _ | | _ | _ | - | _ | _ | _ | _ | 0000 | | | | 15:0 | | TRGDIV | /<3:0> | | TRGSE | L<1:0> | STRGSI | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A460 | STRIG4 | 31:16 | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | • | | • | STRGCMP | <15:0> | • | - | | 3 | • | • | • | 0000 | | A470 | CAP4 | 31:16 | _ | _ | _ | 1 | _ | _ | _ | _ | - | _ | _ | 1 | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CAP<15 | :0> | | | | | | | | 0000 | | A480 | LEBCON4 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A490 | LEBDLY4 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | LEB | <11:0> | | | | | | 0000 | | A4A0 | AUXCON4 | 31:16 | _ | _ | _ | 1 | _ | _ | _ | _ | - | _ | _ | 1 | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | 1 | _ | _ | _ | _ | - | _ | | CHOPS | SEL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | A4B0 | PTMR4 | 31:16 | _ | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TMR<15 | 5:0> | | | | | | | | 0000 | | A4C0 | PWMCON5 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | l<1:0> | ITB | _ | DTC | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | A4D0 | IOCON5 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTS | RC<3:0> | | FLTPOL | FLTMC | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | )<1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | AT<1:0> | CLDA | Γ<1:0> | SWAP | OSYNC | 0000 | | A4E0 | PDC5 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PDC<15 | 5:0> | | | | | | | | 0000 | | A4F0 | SDC5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | SDC<15 | 5:0> | | | | | | | | 0000 | | A500 | PHASE5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PHASE<1 | 15:0> | | | 1 | | | | | 0000 | | A510 | DTR5 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | | A520 | ALTDTR5 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | | | | | ALTDTF | R<13:0> | | | | | | | 0000 | | A530 | DTCOMP5 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | | | | | COMP | <13:0> | | | | | | | 0000 | | A540 | TRIG5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TRGCMP< | :15:0> | | | | | | | | 0000 | | A550 | TRGCON5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | l | | 15:0 | | TRGDIV | /<3:0> | | TRGSE | L<1:0> | STRGSI | EL<1:0> | DTM | STRGIS | _ | - | _ | _ | _ | _ | 0000 | TABLE 31-1: MCPWM REGISTER MAP (CONTINUED) | Water Address (BF82_#) Water Address (BF82_#) Water Address (BF82_#) Water Address (BF82_#) Water Address (BF82_#) | egister<br>lame | Bit Range | | | | | | | | | | | | | | | | | | |------------------------------------------------------------------------------------------------------------------------|-----------------|-----------|---------|---------|--------|--------|----------|---------|--------|---------|--------|--------|--------|---------|---------|--------|---------|---------|------------| | | | ω . | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | IG5 | 31:16 | _ | _ | 1 | _ | _ | _ | | | _ | - | | - | 1 | _ | - | | 0000 | | ı | | 15:0 | | | | • | | | | STRGCMP | <15:0> | | ' | | | | • | | 0000 | | A570 CAP5 | 5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | - | 0000 | | | | 15:0 | | | | | | | | CAP<15 | :0> | | | | | | | | 0000 | | A580 LEBC | CON5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | | _ | _ | _ | _ | | _ | _ | 0000 | | A590 LEBDI | DLY5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | _ | - | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | LEB• | <11:0> | | | | | | 0000 | | A5A0 AUXC | CON5 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOPS | EL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | A5B0 PTMR | R5 : | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | 0000 | | | | 15:0 | | • | | • | | | | TMR<15 | :0> | | | | | | • | | 0000 | | A5C0 PWM0 | ACON6 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | | _ | ECAM | <1:0> | ITB | _ | DTC< | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | | 0000 | | A5D0 IOCOI | ON6 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTS | RC<3:0> | | FLTPOL | FLTMO | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | T<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A5E0 PDC6 | 6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | 0000 | | | | 15:0 | | | | | | | | PDC<15 | :0> | | | | | | | | 0000 | | A5F0 SDC6 | 6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | _ | _ | | _ | _ | 0000 | | | | 15:0 | | | | | | | | SDC<15 | :0> | | | | | | | | 0000 | | A600 PHAS | SE6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PHASE<1 | 5:0> | | | | | | | | 0000 | | A610 DTR6 | 6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | | A620 ALTD | OTR6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | • | | | | | ALTDTR | <13:0> | | | | | • | | 0000 | | A630 DTCO | OMP6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | • | | | | | COMP | <13:0> | | | | | • | | 0000 | | A640 TRIGE | 36 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TRGCMP< | 15:0> | | ' | | | | | | 0000 | | A650 TRGC | CON6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | j | 15:0 | | TRGDIV | ′<3:0> | | TRGSE | L<1:0> | STRGS | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A660 STRIC | IG6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | j | 15:0 | | | | | | | | STRGCMP | <15:0> | | | | | | | | 0000 | | TABLE 31-1: MICHWIN REGISTER MAP (CONTINUEL | <b>TABLE 31-1:</b> | MCPWM REGISTER MAP | (CONTINUED | |---------------------------------------------|--------------------|--------------------|------------| |---------------------------------------------|--------------------|--------------------|------------| | sse | | | | | | | | | | Bits | | | | | | | | | | |-----------------------------|------------------|-----------|-------------|---------|--------|--------|----------|---------|--------|---------|--------|---------|--------|---------|---------|--------|---------|---------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | A670 | CAP6 | 31:16 | - | _ | _ | _ | _ | _ | _ | _ | | _ | _ | ı | ı | 1 | _ | _ | 0000 | | | | 15:0 | | | | | | | | CAP<15 | 5:0> | | | | | | | | 0000 | | A680 I | LEBCON6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | 1 | 1 | 1 | - | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | - | - | l | - | _ | _ | 0000 | | A690 I | LEBDLY6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | LEB | <11:0> | | | | | | 0000 | | A6A0 | AUXCON6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOPS | EL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | A6B0 F | PTMR6 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TMR<1 | 5:0> | | | | | | | | 0000 | | A6C0 F | PWMCON7 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | _ | DTC- | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | A6D0 I | OCON7 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTS | RC<3:0> | | FLTPOL | FLTMO | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | \T<1:0> | FLTDA | \T<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A6E0 F | PDC7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | • | | | PDC<15 | :0> | | | | | | | | 0000 | | A6F0 | SDC7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | SDC<15 | 5:0> | | | | | | | | 0000 | | A700 F | PHASE7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | • | • | • | • | | PHASE< | 5:0> | | • | | | | | • | 0000 | | A710 [ | DTR7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | • | • | • | | • | DTR< | 13:0> | • | | | | | • | 0000 | | A720 | ALTDTR7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | • | • | • | | • | ALTDTF | R<13:0> | • | | | | | • | 0000 | | A730 [ | DTCOMP7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | COMP | <13:0> | | | | | | | 0000 | | A740 | TRIG7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TRGCMP | :15:0> | | | | | | | | 0000 | | A750 | TRGCON7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | TRGDIV | /<3:0> | | TRGSE | L<1:0> | STRGS | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A760 S | STRIG7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | STRGCMP | <15:0> | | | | | | | | 0000 | | A770 | CAP7 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CAP<15 | 5:0> | | | | | | | | 0000 | | Legen | | | mented: rea | | | | | | | | | | | | | | | | 1 | '—' = unimplemented; read as '0'. Legend: | <b>TABLE 31-1:</b> | MCPWM REGISTER MAP | (CONTINUED) | |--------------------|--------------------|-------------| |--------------------|--------------------|-------------| | A790 LEBDLY7 A7A0 AUXCON7 A7B0 PTMR7 | 31:16<br>15:0<br>31:16<br>15:0<br>31:16<br>15:0<br>31:16<br>15:0<br>31:16 | 31/15 — PHR — — — — — — — — — — — — — — — — — — — | 30/14 — PHF — — — — — — — — — — — — — — — — — — — | 29/13 — PLR — — — — — — — — — — — — — — — — — — — | 28/12 — PLF — — — — — — — — — — — — — — — — — — — | 27/11 — FLTLEBEN — | <b>26/10</b> — CLLEBEN — | 25/9<br>—<br>— | <b>24</b> /8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | |------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|---------------------|--------------------------|----------------|--------------|--------|--------|--------|---------|---------|--------|---------|---------|------------| | A780 LEBCON7 A790 LEBDLY7 A7A0 AUXCON7 A7B0 PTMR7 | 15:0<br>31:16<br>15:0<br>31:16<br>15:0<br>31:16<br>15:0<br>31:16 | PHR — — — — — — — | PHF — — — — — — — | PLR — — — — — — | PLF — — — — | FLTLEBEN — | | | | | _ | | _ | _ | _ | _ | _ | 0000 | | A7A0 AUXCON7 A7B0 PTMR7 | 31:16<br>15:0<br>31:16<br>15:0<br>31:16<br>15:0<br>31:16 | | <br><br> | -<br>-<br>- | _<br>_<br>_ | _ | CLLEBEN<br>— | _ | | | | | | | | | | 0000 | | A7A0 AUXCON7 A7B0 PTMR7 | 15:0<br>31:16<br>15:0<br>31:16<br>15:0<br>31:16 | _<br>_<br>_ | _<br>_<br>_ | _<br>_<br>_ | _<br>_ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | A7B0 PTMR7 | 31:16<br>15:0<br>31:16<br>15:0<br>31:16 | _ | _<br>_ | _<br>_ | _ | | | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | A7B0 PTMR7 | 15:0<br>31:16<br>15:0<br>31:16 | _ | _ | _ | | | | | • | | LEB | <11:0> | • | | | | | 0000 | | | 31:16<br>15:0<br>31:16 | | | | | | - | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0<br>31:16 | _ | _ | _ | | _ | 1 | _ | _ | 1 | _ | | CHOPS | EL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | A7C0 PWMCON8 | 31:16 | | | | _ | _ | - | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | 0000 | | A7C0 PWMCON8 | | | | | | | | | TMR<15 | 5:0> | | | | | | | | 0000 | | | 4 - 0 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | 1 | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | 1 | 1 | 1 | 0000 | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM: | <1:0> | ITB | _ | DTC< | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | - | 0000 | | A7D0 IOCON8 | 31:16 | - | | | CLSR | C<3:0> | | CLPOL | CLMOD | I | | FLTSI | RC<3:0> | | FLTPOL | FLTMO | D<1:0> | 0078 | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | T<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A7E0 PDC8 | 31:16 | 1 | _ | _ | _ | _ | | _ | | | _ | | _ | | _ | _ | _ | 0000 | | | 15:0 | | | | | | | | PDC<15 | :0> | | | | | | | | 0000 | | A7F0 SDC8 | 31:16 | _ | _ | _ | _ | _ | - | _ | _ | | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | | | | | | | | SDC<15 | :0> | | | | | | | | 0000 | | A800 PHASE8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | | | | | | | | PHASE<1 | 5:0> | | | | | | | | 0000 | | A810 DTR8 | 31:16 | | _ | _ | _ | _ | _ | _ | | _ | _ | | _ | _ | _ | _ | _ | 0000 | | | 15:0 | - | _ | | | | | | | DTR< | 15:0> | | | | | | | 0000 | | A820 ALTDTR8 | 31:16 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | | _ | | | | | | | ALTDTR | <15:0> | | | | | | | 0000 | | A830 DTCOMP8 | 31:16 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | _ | _ | | | | | | | COMP | <13:0> | | | | | | | 0000 | | A840 TRIG8 | 31:16 | 1 | _ | _ | _ | _ | | _ | | | _ | | _ | | _ | _ | _ | 0000 | | | 15:0 | | | | | | | | TRGCMP< | :15:0> | | | | | | | | 0000 | | A850 TRGCON8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | | TRGDIV | ′<3:0> | | TRGSE | L<1:0> | STRGSE | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A860 STRIG8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | | | | • | | | | STRGCMP- | <15:0> | | | | | | | | 0000 | | A870 CAP8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | | | | | | | | CAP<15 | :0> | | | | | | | | 0000 | | A880 LEBCON8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | ▢ | |---------------| | ß | | ŏ | | 0 | | 0 | | 0 | | $\rightarrow$ | | 5 | | $\rightarrow$ | | 9 | | Ш | | Τ. | | 0 | | а | | 9 | | Œ | | | | $^{\circ}$ | | 9 | | 99 | | | | sse | | | Bits \$\frac{\psi}{\psi}\$ | | | | | | | | | | | | | | | | | |-----------------------------|------------------|----------------------|----------------------------|---------|--------|--------|----------|---------|--------|---------|--------|--------|--------|---------|----------------|--------|---------|---------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | | LEBDLY8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | | _ | | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | LEB | <11:0> | | | | | | 0000 | | 0A8A | AUXCON8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | 1 | _ | _ | _ | _ | _ | - | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | I | - | _ | | CHOPS | SEL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | A8B0 | PTMR8 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TMR<15 | 5:0> | | | | | | | | 0000 | | A8C0 | PWMCON9 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | <b>PWMHIEN</b> | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | - | DTC< | <1:0> | DTCP | PTDIR | MTBS | | XPRES | _ | 0000 | | A8D0 | IOCON9 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTS | RC<3:0> | | FLTPOL | FLTMO | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | \T<1:0> | CLDAT | <1:0> | SWAP | OSYNC | 0000 | | A8E0 | PDC9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PDC<15 | :0> | | | | | | | | 0000 | | A8F0 | SDC9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | SDC<15 | 5:0> | | | | | | | | 0000 | | A900 | PHASE9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | PHASE<1 | 15:0> | | | | | | | | 0000 | | A910 | DTR9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | | A920 | ALTDTR9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | ALTDTF | <13:0> | | | | | | | 0000 | | A930 | DTCOMP9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | COMP | <13:0> | | | | | | | 0000 | | A940 | TRIG9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TRGCMP< | :15:0> | | | | | | | | 0000 | | A950 | TRGCON9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | TRGDI\ | /<3:0> | | TRGSE | L<1:0> | STRGSI | EL<1:0> | DTM | STRGIS | _ | _ | _ | _ | _ | _ | 0000 | | A960 | STRIG9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | STRGCMP | <15:0> | | | | | | | | 0000 | | A970 | CAP9 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CAP<15 | | | | | | | | | 0000 | | A980 | LEBCON9 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | | _ | _ | _ | _ | _ | | _ | _ | 0000 | | A990 | LEBDLY9 | 31:16 | _ | | — | _ | _ | _ | _ | | | _ | _ | _ | _ | | _ | | 0000 | | . 1000 | | | | | | | | | | | | I FR | | | | | | | | | Legen | | 15:0 — — — LEB<11:0> | | | | | | | | | | | | | | | | | | '—' = unimplemented; read as '0'. Legend: TABLE 31-1: MCPWM REGISTER MAP (CONTINUED) | ess | | | Bits 5 4 5 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 | | | | | | | | | | | | | | | | | |-----------------------------|------------------|-----------|----------------------------------------------|---------|--------|--------|----------|---------|--------|---------|--------|---------|--------|---------|----------|--------|---------|---------|------------| | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | A9A0 | AUXCON9 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOP | SEL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | A9B0 | PTMR9 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | | _ | | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | TMR<15 | | | | | | | | | 0000 | | A9C0 | PWMCON10 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | | PWMHIEN | _ | _ | _ | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | _ | DTC- | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | A9D0 | IOCON10 | 31:16 | | _ | | | C<3:0> | | CLPOL | CLMOD | | | FLTS | RC<3:0> | | FLTPOL | FLTMC | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTD | AT<1:0> | CLDA | Γ<1:0> | SWAP | OSYNC | 0000 | | A9E0 | PDC10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | 1 | | • | | | PDC<15 | 5:0> | | | | | | | | 0000 | | A9F0 | SDC10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | • | I | | SDC<15 | 5:0> | | | • | | • | | | 0000 | | AA00 | PHASE10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | • | | | PHASE<1 | 15:0> | | | | | | | | 0000 | | AA10 | DTR10 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | • | I | | | DTR< | 13:0> | | • | | • | | | 0000 | | AA20 | ALTDTR10 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | 1 | I | | | ALTDTF | R<13:0> | | | | | | 1 | 0000 | | AA30 | DTCOMP10 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | _ | | | • | I | | | COMP | <13:0> | | • | | • | | | 0000 | | AA40 | TRIG10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | 1 | I | | TRGCMP< | :15:0> | | | | | | | 1 | 0000 | | AA50 | TRGCON10 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | _ | _ | 0000 | | | | 15:0 | | TRGDIV | /<3:0> | 1 | TRGSE | L<1:0> | STRGS | EL<1:0> | DTM | STRGIS | | _ | _ | _ | _ | _ | 0000 | | AA60 | STRIG10 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | 1 | I | | STRGCMP | <15:0> | | | | | | | 1 | 0000 | | AA70 | CAP10 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | • | | | CAP<15 | 5:0> | | | | | | | | 0000 | | AA80 | LEBCON10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | _ | _ | | _ | | _ | 0000 | | AA90 | LEBDLY10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | LEB | <11:0> | | | | | | 0000 | | AAA0 | AUXCON10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | | CHOP | SEL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | TABLE 31-1: MC | PWM REGISTER MAP | (CONTINUED) | |----------------|------------------|-------------| |----------------|------------------|-------------| | Register | | LE 31-1. | | | | | | | | | | | | | | | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------|-----------|---------|---------|--------|--------|----------|---------|--------|---------|--------|--------|----------|---------|---------|--------|---------|---------|------------| | AABO PTMR10 31-16 | ess | | | | | | | | | | | | | <b>"</b> | | | | | | | | AACO PWMCON1 31:16 | Virtual Addr<br>(BF82_#) | | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | AACO PWMCONT 31.16 | AAB0 | PTMR10 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | 0000 | | AADD OCON11 31:16 | | | 15:0 | | | | | | | | TMR<15 | 5:0> | | | | | | | | 0000 | | AADD OCON11 | AAC0 | PWMCON11 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | _ | _ | _ | 0000 | | 15:0 | | | 15:0 | FLTSTAT | CLTSTAT | _ | _ | ECAM | <1:0> | ITB | _ | DTC< | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | _ | 0000 | | AAE0 PDC11 31:16 | AAD0 | IOCON11 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | _ | | FLTSI | RC<3:0> | | FLTPOL | FLTMO | D<1:0> | 0078 | | 15:0 | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | T<1:0> | CLDAT | Γ<1:0> | SWAP | OSYNC | 0000 | | AAF0 SDC11 31:16 | AAE0 | PDC11 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | AB00 PHASE11 31:16 | | | 15:0 | | | | | | | | PDC<15 | 5:0> | | | | | | | | 0000 | | AB00 PHASE11 31:16 — — — — — — — — — — — — — — — — — — — | AAF0 | SDC11 | 31:16 | _ | _ | _ | - | _ | _ | _ | 1 | _ | _ | _ | _ | - | _ | _ | _ | 0000 | | AB10 DTR11 31:16 | | | 15:0 | | | | | | | | SDC<15 | 5:0> | | | | | | | | 0000 | | AB10 DTR11 31:16 | AB00 | PHASE11 | 31:16 | _ | _ | _ | I | | I | _ | I | 1 | _ | 1 | | I | _ | - | _ | 0000 | | 15.0 | | | 15:0 | | | | | | | | | | | | | | | | | | | AB20 ALTDTR11 31:16 | AB10 | DTR11 | 31:16 | _ | | | | | | | | | | | | | | | | | | 15:0 | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | | 0000 | | AB30 DTCOMP11 31:16 | AB20 | ALTDTR11 | 31:16 | _ | _ | _ | I | | I | _ | I | 1 | _ | 1 | | I | _ | - | _ | 0000 | | 15:0 | | | 15:0 | _ | _ | | | | | | | ALTDTF | <13:0> | | | | | | | 0000 | | AB40 TRIG11 31:16 — — — — — — — — — — — — — — — — — — — | AB30 | DTCOMP11 | 31:16 | _ | _ | _ | I | | I | _ | I | 1 | _ | 1 | | I | _ | - | _ | 0000 | | 15:0 | | | 15:0 | _ | _ | | | | | | | COMP | <13:0> | | | | | | | 0000 | | AB50 TRGCON11 31:16 — — — — — — — — — — — — — — — — — — — | AB40 | TRIG11 | 31:16 | _ | _ | _ | I | | | _ | I | - | _ | - | _ | 1 | _ | _ | _ | 0000 | | 15:0 | | | 15:0 | | | | | | | | TRGCMP< | :15:0> | | | | | | | | 0000 | | AB60 STRIG11 31:16 — — — — — — — — — — — — — — — — — — — | AB50 | TRGCON11 | 31:16 | _ | _ | _ | 1 | _ | | _ | 1 | | _ | - | _ | I | _ | _ | _ | 0000 | | 15:0 STRGCMP<15:0> 0000 | | | 15:0 | | TRGDIV | /<3:0> | | TRGSE | L<1:0> | STRGS | EL<1:0> | DTM | STRGIS | - | _ | 1 | _ | _ | _ | 0000 | | AB70 CAP11 31:16 — — — — — — — — — — — — — — — — — — — | AB60 | STRIG11 | 31:16 | _ | _ | _ | 1 | _ | | _ | 1 | | _ | - | _ | I | _ | _ | _ | 0000 | | 15:0 | | | 15:0 | | | | | | | ( | STRGCMP | <15:0> | | | | | | | | 0000 | | AB80 LEBCON11 31:16 — — — — — — — — — — — — — — — — — — — | AB70 | CAP11 | 31:16 | _ | _ | _ | - | _ | - | _ | 1 | _ | _ | _ | _ | - | _ | _ | _ | 0000 | | 15:0 | | | 15:0 | | | | | | | | CAP<15 | 5:0> | | | | | | | | 0000 | | AB40 LEBDLY11 31:16 — — — — — — — — — — — — — — — — — — — | AB80 | LEBCON11 | 31:16 | _ | _ | _ | 1 | _ | | | 1 | | _ | - | _ | I | _ | _ | _ | 0000 | | 15:0 | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | 1 | _ | _ | _ | _ | - | _ | _ | _ | 0000 | | ABA0 AUXCON11 31:16 — — — — — — — — — — — — — — — — — — — | AB90 | LEBDLY11 | 31:16 | _ | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | _ | 0000 | | 15:0 | | | 15:0 | _ | _ | _ | | | | | | | LEB | <11:0> | | | | | | 0000 | | ABB0 PTMR11 31:16 — — — — — — — — — — — — — — — — — — — | ABA0 | AUXCON11 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOPS | EL<3:0> | | CHOPHEN | CHOPLEN | 0000 | | 15:0 TMR<15:0> | ABB0 | PTMR11 | 31:16 | _ | _ | _ | | _ | | _ | | | | _ | _ | | _ | | _ | 0000 | | | | | 15:0 | | | | | | | | TMR<15 | 5:0> | | | | | | | | 0000 | TABLE 31-1: MCPWM REGISTER MAP (CONTINUED) | | LE 31-1. | | | | | | | | | | | | | | | | | | | |-----------------------------|------------------|-----------|---------|------------------|-------|--------|----------|---------|--------|---------|--------|--------|--------|---------|---------|--------|---------|---------|------------| | ess | | | | | | | | | | Bits | | | | | | | | | w | | Virtual Address<br>(BF82_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | ABC0 | PWMCON12 | 31:16 | FLTIF | CLIF | TRGIF | PWMLIF | PWMHIF | _ | _ | _ | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | _ | _ | - | 0000 | | | | 15:0 | FLTSTAT | CLTSTAT | I | I | ECAM | <1:0> | ITB | _ | DTC< | <1:0> | DTCP | PTDIR | MTBS | _ | XPRES | I | 0000 | | ABD0 | IOCON12 | 31:16 | _ | _ | | CLSR | C<3:0> | | CLPOL | CLMOD | I | | FLTS | RC<3:0> | | FLTPOL | FLTMO | D<1:0> | 0078 | | | | 15:0 | PENH | PENL | POLH | POLL | PMOD | <1:0> | OVRENH | OVRENL | OVRDA | T<1:0> | FLTDA | \T<1:0> | CLDAT | Γ<1:0> | SWAP | OSYNC | 0000 | | ABE0 | PDC12 | 31:16 | _ | _ | 1 | 1 | _ | _ | _ | _ | 1 | _ | _ | - | I | _ | _ | | 0000 | | | | 15:0 | | | | | | | | PDC<15 | :0> | | | | | | | | 0000 | | ABF0 | SDC12 | 31:16 | _ | _ | 1 | _ | _ | _ | _ | _ | - | _ | _ | _ | 1 | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | SDC<15 | :0> | | | | | | | | 0000 | | AC00 | PHASE12 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | PHASE<15:0> 0000 | | | | | | | | | | | | | | | | | AC10 | DTR12 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | DTR< | 13:0> | | | | | | 1 | 0000 | | AC20 | ALTDTR12 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | | | | ALTDTR | <13:0> | | | | | | | 0000 | | AC30 | DTCOMP12 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | | | | I | | I | COMP | | • | | | • | 1 | | 0000 | | AC40 | TRIG12 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | I | | TRGCMP< | :15:0> | 1 | • | | | 1 | 1 | | 0000 | | AC50 | TRGCON12 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | 0000 | | | | 15:0 | | TRGDIV | | | TRGSE | | STRGS | EL<1:0> | DTM | STRGIS | | _ | | _ | _ | | 0000 | | AC60 | STRIG12 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | 1 | | STRGCMP | <15:0> | 1 | 1 | | | 1 | | | 0000 | | AC70 | CAP12 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | | | | | | | | CAP<15 | :0> | | | | | | | | 0000 | | AC80 | LEBCON12 | 31:16 | | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | _ | _ | | 0000 | | | | 15:0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | AC90 | LEBDLY12 | 31:16 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | | | 15:0 | _ | _ | _ | _ | | | | | | | <11:0> | | | | | | 0000 | | ACA0 | AUXCON12 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | - | _ | 0000 | | | | 15:0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | | CHOPS | EL<3:0> | | CHOPHEN | CHOPLEN | | | ACB0 | PTMR12 | 31:16 | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | | _ | _ | | 0000 | | | | | | | | | | | | | | | | 0000 | | | | | | '—' = unimplemented; read as '0'. Legend: #### REGISTER 31-1: PTCON: PWM PRIMARY TIME BASE CONTROL REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-----------------------|----------------------|-------------------|-----------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | R/W-0 | U-0 | R/W-0 | HS/HC-0 | R/W-0 | HS/HC-0 | U-0 | U-0 | | 13.6 | PTEN | _ | PTSIDL | SESTAT <sup>(1)</sup> | SEIEN <sup>(3)</sup> | PWMRDY | _ | _ | | 7:0 | U-0 | R/W-0 | 7.0 | _ | PC | CLKDIV<2:0> | (2) | | SEVTPS | S<3:0> <sup>(2)</sup> | | Legend: bit 11 R = Readable bit U = Unimplemented bit, read as '0' W = Writable bit -n = Value at POR '0' = Bit is cleared '1' = Bit is set x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 PTEN: PWM Module Enable bit 1 = PWM module is enabled 0 = PWM module is disabled Many of the PWM registers and/or bits as designated, do not allow updates once a PWM module is enabled. Therefore, it is recommended that the user application initialize all required PWM registers before setting the PTEN bit equal to '1'. bit 14 Unimplemented: Read as '0' bit 13 PTSIDL: PWM Time Base Stop in Idle Mode bit 1 = PWM time base halts in CPU Idle mode 0 = PWM time base runs in CPU Idle mode **SESTAT:** Special Event Interrupt Status bit<sup>(1)</sup> bit 12 1 = Special Event Interrupt is pending 0 = Special Event Interrupt is not pending **SEIEN:** Special Event Interrupt Enable bit 1 = Special Event Interrupt is enabled 0 = Special Event Interrupt is disabled bit 10 **PWMRDY: PWM Module Status bit** 1 = PWM module is ready and operation has begun 0 = PWM module is not ready bit 9-7 Unimplemented: Read as '0' bit 6-4 PCLKDIV<2:0>: Primary PWM Input Clock Prescaler bits(2) 111 = Divide by 128, PWM resolution = 128/FSYSCLK 110 = Divide by 64, PWM resolution = 64/FSYSCLK 000 = Divide by 1, PWM resolution = 1/FSYSCLK (power-on default) - Note 1: The SESTAT bit is cleared by clearing the SEIEN bit and the corresponding bit in the IFSx register. - 2: The SEVTPS<3:0> bits should be changed only when the PTEN bit (PTCON<15>) = 0. - 3: To clear the Primary Special Event Interrupt the user application must do the following: - 1) Clear the SEIEN bit by setting it to '0'. - 2) Clear the Primary Special Event Interrupt flag by setting IFS5<11> = 0. - 3) Re-enabling the PTCON register by setting the SEIEN equal to '1' if desired. The user application will not be able to clear the Primary Special Event Interrupt flag as long as the SEIEN bit is equal to '1'. #### REGISTER 31-1: PTCON: PWM PRIMARY TIME BASE CONTROL REGISTER (CONTINUED) bit 3-0 **SEVTPS<3:0>:** PWM Special Event Trigger Output Postscaler Select bits<sup>(2)</sup> 1111 = 1:16 postscaler generates Special Event trigger at every 16th compare match event • 0001 = 1:2 postscaler generates Special Event trigger at every second compare match event 0000 = 1:1 postscaler generates Special Event trigger at every compare match event - Note 1: The SESTAT bit is cleared by clearing the SEIEN bit and the corresponding bit in the IFSx register. - 2: The SEVTPS<3:0> bits should be changed only when the PTEN bit (PTCON<15>) = 0. - 3: To clear the Primary Special Event Interrupt the user application must do the following: - 1) Clear the SEIEN bit by setting it to '0'. - 2) Clear the Primary Special Event Interrupt flag by setting IFS5<11> = 0. - 3) Re-enabling the PTCON register by setting the SEIEN equal to '1' if desired. The user application will not be able to clear the Primary Special Event Interrupt flag as long as the SEIEN bit is equal to '1'. #### REGISTER 31-2: PTPER: PRIMARY MASTER TIME BASE PERIOD REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |-----------|------------------------------|-------------------|-------------------|-------------------|------------------------|----------------------|----------------------|----------------------|--|--|--| | 31:24 | U-0 | | | | 31.24 | _ | _ | _ | _ | _ | | _ | _ | | | | | 23:16 | U-0 | | | | 23.10 | _ | _ | _ | _ | _ | | _ | _ | | | | | 15:8 | R/W-0 | | | | 15.6 | PTPER<15:8> <sup>(1,2)</sup> | | | | | | | | | | | | 7:0 | R/W-0 | R/W-0 | R/W-1 | R/W-0 | R/W-0 | R/W-0 <sup>(3)</sup> | R/W-0 <sup>(3)</sup> | R/W-0 <sup>(3)</sup> | | | | | /.0 | | | | PTPER• | <7:0> <sup>(1,2)</sup> | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 PTPER<15:0>: Primary Master Time Base Period Value bits(1,2,4) Note 1: Minimum LSb = 1/FSYSCLK. 2: Minimum value is 0x0008. **3:** If a period value is lesser than 0x0008 chosen, the internal hardware forcefully sets the period to a minimum value of 0x0008. 4: PTPER = (FSYSCLK/ (F<sub>PWM</sub> \* PTCON<PCLKDIV>)) F<sub>PWM</sub> = User Desired PWM Frequency #### REGISTER 31-3: SEVTCMP: PWM PRIMARY SPECIAL EVENT COMPARE REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|-------------------|-------------------|-------------------|-------------------------------|-------------------------|-------------------|------------------|------------------|--|--| | 31:24 | U-0 | | | 31.24 | _ | _ | | _ | _ | _ | _ | _ | | | | 23:16 | U-0 | | | 23.10 | _ | _ | | _ | _ | _ | _ | _ | | | | 15:8 | R/W-0 | | | 15.6 | | | | SEVTCMF | <15:8> <sup>(1,2)</sup> | | | | | | | 7:0 | R/W-0 | | | /.0 | | | | SEVTCMP<7:0> <sup>(1,2)</sup> | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 **SEVTCMP<15:0>:** Special Event Compare Count Value bits<sup>(1,2)</sup> The special event trigger allows analog-to-digital conversions to be synchronized to the master PWM time base. The analog-to-digital sampling and conversion time may be programmed to occur at any point within the PWM period. Note 1: Minimum LSb = 1/FSYSCLK. 2: To trigger at the period boundary, set the SEVTCMP bit to 0x0 and not the PTPER period value. #### REGISTER 31-4: PMTMR: PRIMARY MASTER TIME BASE TIMER REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-----------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | | _ | | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | R-0 | 15.6 | | | | PMTMR< | <15:8> <sup>(1)</sup> | | | | | 7:0 | R-0 | 7.0 | | | | PMTMR | <7:0> <sup>(1)</sup> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 **PMTMR<15:0>:** Primary Master Time Base Timer Value bits<sup>(1)</sup> This timer increments with each PWM clock until the PTPER value is reached. Note 1: LSb = 1/FSYSCLK. #### REGISTER 31-5: STCON: SECONDARY MASTER TIME BASE CONTROL REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|------------------------|-----------------------|-------------------|-----------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | | _ | _ | | | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | | | _ | | 15:8 | U-0 | U-0 | U-0 | HS/HC-0 | R/W-0 | U-0 | U-0 | U-0 | | 15.6 | _ | _ | _ | SSESTAT <sup>(1)</sup> | SSEIEN <sup>(3)</sup> | | | _ | | 7:0 | U-0 | R/W-0 | /.0 | _ | S | CLKDIV<2:0> | ,(2) | | SEVTPS | S<3:0> <sup>(2)</sup> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-13 Unimplemented: Read as '0' bit 12 SSESTAT: Secondary Special Event Interrupt Status bit<sup>(1)</sup> 1 = Secondary Special Event Interrupt is pending 0 = Secondary Special Event Interrupt is not pending bit 11 SSEIEN: Secondary Special Event Interrupt Enable bit (3) 1 = Secondary Special Event Interrupt is enabled 0 = Secondary Special Event Interrupt is disabled bit 10-7 Unimplemented: Read as '0' bit 6-4 SCLKDIV<2:0>: Secondary PWM Input Clock Prescaler<sup>(2)</sup> 111 = Divide by 128, PWM resolution = (128/FSYSCLK) 110 = Divide by 64, PWM resolution = (64/FSYSCLK) • • • 000 = Divide by 1, PWM resolution = 1/FSYSCLK (power-on default) bit 3-0 **SEVTPS<3:0>:** PWM Secondary Special Event Trigger Output Postscaler Select bits<sup>(2)</sup> 1111 = 1:16 Postscale • • • 0001 = 1:2 Postscale 0000 = 1:1 Postscale - Note 1: The SSESTAT bit is cleared by clearing the SSEIEN bit and corresponding bit in the IFSx register. - 2: These bits should be changed only when the PTEN bit (PTCON<15>) = 0. - 3: To clear the Secondary Special Event Interrupt, the user application must do the following: - 1) First, clear the SSEIEN bit by setting it to '0'. - 2) Next, clear the Secondary Special Event Interrupt flag, IFS5<12>, by setting it to '0'. - 3) Finally, re-enable the STCON register by setting the SSEIEN bit equal to '1', if desired. The user application will not be able to clear the Secondary Special Event Interrupt flag as long as the SSEIEN bit is equal to '1'. #### REGISTER 31-6: STPER: SECONDARY MASTER TIME BASE PERIOD REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | | |-----------|--------------------------------|-------------------|-------------------|-------------------|-------------------|----------------------|----------------------|----------------------|--|--|--|--| | 31:24 | U-0 | | | | | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | 23:16 | U-0 | | | | | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | 15:8 | R/W-0 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | | | | 15.6 | STPER<15:8> <sup>(1,2,4)</sup> | | | | | | | | | | | | | 7:0 | R/W-0 | R/W-0 | R/W-1 | R/W-0 | R/W-0 | R/W-0 <sup>(3)</sup> | R/W-0 <sup>(3)</sup> | R/W-0 <sup>(3)</sup> | | | | | | /.0 | STPER<7:0>(1,2,4) | | | | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 STPER<15:0>: Secondary Master Time Base Period Value bits(1,2,4) Note 1: Minimum LSb = 1/FSYSCLK. 2: Minimum value is 0x0008. **3:** If a period value lesser than 0x0008 is chosen, the internal hardware forcefully sets the period to a minimum value of 0x0008. 4: STPER = (FSYSCLK/ (F<sub>PWM</sub> \* PTCON<PCLKDIV>)) F<sub>PWM</sub> = User Desired PWM Frequency #### REGISTER 31-7: SSEVTCMP: PWM SECONDARY SPECIAL EVENT COMPARE REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|-------------------|------------------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 31:24 | U-0 | | | 31.24 | _ | _ | _ | _ | _ | | _ | _ | | | | 23:16 | U-0 | | | 23.10 | _ | _ | _ | _ | _ | | _ | _ | | | | 15:8 | R/W-0 | | | 15.6 | SSEVTCMP<15:8>(1) | | | | | | | | | | | 7:0 | R/W-0 | | | | | SSEVTCMP<7:0> <sup>(1)</sup> | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 **Unimplemented:** Read as '0' bit 15-0 SSEVTCMP<15:0>: Secondary Special Event Compare Value bits<sup>(1)</sup> The secondary special event trigger allows analog-to-digital conversions to be synchronized to the secondary master PWM time base. The analog-to-digital sampling and conversion time may be programmed to occur at any point within the PWM period. Note 1: To trigger at the period boundary, set the SSEVTCMP bit to 0x0 and not the PTPER period value. #### REGISTER 31-8: SMTMR: SECONDARY MASTER TIME BASE TIMER REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|----------------------------|-------------------|-------------------|-------------------|----------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | | _ | _ | | 15:8 | R-0 | | SMTMR<15:8> <sup>(1)</sup> | | | | | | | | | 7:0 | R-0 | | | | | SMTMR | <7:0> <sup>(1)</sup> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 SMTMR<15:0>: Secondary Master Time Base Timer Value bits<sup>(1)</sup> This timer increments with each PWM FSYSCLK until the STPER value is reached. Note 1: Min LSb = 1/FSYSCLK. #### REGISTER 31-9: CHOP: PWM CHOP CLOCK GENERATOR REGISTER | Bit Range | Bit<br>31/2 /15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|------------------------|-------------------|------------------|-------------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 15:8 | CHPCLKEN | _ | _ | _ | _ | _ | CHOPCLK | (<9:8> <sup>(2,3)</sup> | | 7:0 | R/W-0 | 7.0 | | | | CHOPCLK | <7:0> <sup>(2,3)</sup> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 CHPCLKEN: Enable Chop Clock Generator bit 1 = Chop clock generator is enabled<sup>(1)</sup> 0 = Chop clock generator is disabled bit 14-10 Unimplemented: Read as '0' bit 9-0 CHOPCLK<9:0>: Chop Clock Divider bits<sup>(2,3)</sup> Chop Frequency = (FSYSCLK/PCLKDIV) / (CHOPCLK<9:0>) Note 1: The chop clock generator operates with the PCLKDIV<2:0> bits (PTCON<6:4>). 2: Minimum values is 0x0002. A value of 0x0000 or 0x0001 will produce no chop clock. 3: These bits should only be changed when the PTEN bit (PTCON<15>) is clear. Note: The Chop Clock is a continuous high frequency signal (relative to PWM cycles) that is optionally gated with the PWM output signals to allow the PWM signals to pass through an external isolation barrier such as a pulse transformer or capacitor. The value of [CHOP<9:0> \* PWM clock duration] defines the high, and the low times of the Chop Clock. A value of '8' in the CHOP register yields a Chop Clock signal with a period of 16 PWM clock cycles as defined by the primary PWM clock prescaler PCLKDIV<2:0.> A Value of 0x0000 or 0x0001 will produce no Chop Clock #### REGISTER 31-10: PWMKEY: PWM UNLOCK REGISTER | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | 1 | | | _ | | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | W-0 | | PWMKEY<15:8> | | | | | | | | | 7:0 | W-0 | 7.0 | | | | PWMK | EY<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 **Unimplemented:** Read as '0' bit 15-0 **PWMKEY<15:0>:** PWM Unlock bits If the PWMLOCK Configuration bit is asserted (PWMLOCK = 0), the IOCONx registers are writable only after the proper sequence is written to the PWMKEY register. If the PWMLOCK Configuration bit is deasserted (PWMLOCK = 1), the IOCONx registers are writable at all times. For more information on the unlock sequence, refer to the **44.9** "Write Protection" in Section **44.** Motor Control PWM (MCPWM) (DS60001393) of the "PIC32 Family Reference Manual" for more information. This register is implemented only in devices where the PWMLOCK Configuration bit is present in the DEVCFG3 Configuration register. Note: The user must write two consecutive values of 0xABCD and 0x4321 to the PWMKEY register to perform an unlock operation if PWMLOCK = 0. Write access to any subsequent secure register must be the very next access following the unlock process. This is not an atomic operation and any CPU interrupts that occur during or immediately after an unlock sequence may cause writes to any PWM secure register to fail. #### REGISTER 31-11: PWMCONx: PWM CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|----------------------|---------------------|----------------------|-----------------------|----------------------------|----------------------|----------------------|------------------| | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | | 31:24 | FLTIF <sup>(1)</sup> | CLIF <sup>(1)</sup> | TRGIF <sup>(1)</sup> | PWMLIF <sup>(1)</sup> | PWM-<br>HIF <sup>(1)</sup> | _ | _ | _ | | 23:16 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | | 23.10 | FLTIEN | CLIEN | TRGIEN | PWMLIEN | PWMHIEN | _ | _ | _ | | 15:8 | HS/HC-0 | HS/HC-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | | 15.8 | FLTSTAT | CLTSTAT | _ | _ | ECAM• | <1:0> <sup>(1)</sup> | ITB <sup>(2)</sup> | _ | | 7:0 | R/W-0 | R/W-0 | R/W-0 | HS/HC/R-0 | R/W-0 | U-0 | R/W-0 | U-0 | | | DTC | <1:0> | DTCP <sup>(4)</sup> | PTDIR <sup>(6)</sup> | MTBS <sup>(7)</sup> | _ | XPRES <sup>(3)</sup> | 1 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 **FLTIF:** Fault Interrupt Flag bit<sup>(1)</sup> 1 = Fault interrupt has occurred 0 = Fault interrupt has not occurred bit 30 **CLIF:** Current-Limit Status bit<sup>(1)</sup> 1 = Current limit has occurred 0 = Current limit has not occurred bit 29 **TRGIF:** Trigger Interrupt Status bit<sup>(1)</sup> 1 = Trigger interrupt is pending 0 = Trigger interrupt is not pending bit 28 **PWMLIF:** PWML Interrupt Status bit<sup>(1)</sup> 1 = PWM Timer equal to 0x4 interrupt has occurred 0 = PWM Interrupt has not occurred bit 27 **PWMHIF:** PWMH Interrupt Status bit 1 = PWM period match interrupt has occurred 0 = PWM period match interrupt has not occurred bit 26-24 Unimplemented: Read as '0' bit 23 FLTIEN: Fault Interrupt Enable bit 1 = Fault interrupt is enabled. If FLTIF = 1, an interrupt event will be generated. 0 = Fault interrupt is disabled bit 22 CLIEN: Current-Limit Interrupt Enable bit 1 = Current-limit interrupt is enabled. If CLIF = 1, an interrupt event will be generated. 0 = Current-limit interrupt is disabled - Note 1: If PWM interrupts are enabled, software must clear the PWMCONx interrupt flags here first, followed second by the corresponding IFSx bit in the Interrupt controller. The corresponding PWM IFSx interrupt flag cannot be cleared if any of these local PWMCON interrupt bits are not cleared first. Failure to do so will result in an infinite interrupt loop. - 2: This bit should not be changed after the PWM is enabled (PTEN bit (PTCON<15>) = 1). - 3: To operate in External Period Reset mode, the ITB bit must be set to '1' and the CLMOD bit in the IOCONx register must be set to '0'. - **4:** For Dead Time Compensation (DTCP) to be effective, DTC<1:0> must be set to '11'; otherwise, DTCP is ignored. - 5: Negative dead time is only implemented for Edge-Aligned mode. - **6:** XPRES mode should only be used in Edge-Aligned mode with or without complimentary outputs. It does not support dead time compensation (i.e., duty cycle adjustment), which is selected when DTC<1:0> = 11. - 7: The clock source is one of the master time bases even if ITB = 1 is selected. ### REGISTER 31-11: PWMCONx: PWM CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) (CONTINUED) - bit 21 TRIGIEN: Primary Trigger Interrupt Enable bit - 1 = A primary trigger event generates an interrupt request - 0 = A primary trigger event interrupts request is disabled - bit 20 **PWMLIEN:** PWM Low Phase Interrupt Enable bit - 1 = When the PWM Timer is equal to 0x4, the PWMLIF flag = 1 and generates an interrupt request - 0 = PWM Period event interrupt request is disabled - bit 19 **PWMHIEN:** PWM High Phase Interrupt Enable bit - 1 = When the PWM Period matches the value in the PWM timer, an interrupt request is generated - 0 = PWM Period event interrupt request is disabled, and the PWMHIF bit is cleared - bit 18-16 **Unimplemented:** Read as '0' - bit 15 **FLTSTAT:** Fault Interrupt Status bit<sup>(1)</sup> - 1 = Fault interrupt is pending - 0 = No fault interrupt is pending - This bit is cleared by setting FLTIEN = 0. - bit 14 **CLTSTAT:** Current-Limit Interrupt Status bit<sup>(1)</sup> - 1 = Current-limit interrupt is pending - 0 = No current-limit interrupt is pending - This bit is cleared by setting CLIEN = 0. - bit 13-12 Unimplemented: Read as '0' - bit 11-10 **ECAM<1:0>:** Edge/Center-Aligned Mode Enable bits<sup>(1)</sup> - 11 = Asymmetric Center-Aligned mode with simultaneous update (PWM(min) Duty Cycle Resolution = (1/ FSYSCLK)) - 10 = Asymmetric Center-Aligned mode double update (PWM(min) Duty Cycle Resolution = (1/FSY-SCLK)) - 01 = Symmetric Center-Aligned mode (PWM(min) Duty Cycle Resolution = (2/FSYSCLK)) - 00 = Edge-Aligned mode (PWM(min) Duty Cycle Resolution = (1/FSYSCLK)) - bit 9 ITB: Independent Time Base Mode bit<sup>(2)</sup> - 1 = PHASEx registers provide time base period for this PWM generator - 0 = PTPER/STPER register provides timing for this PWM generator based on the MTBS bit - bit 8 **Unimplemented:** Read as '0' - bit 7-6 **DTC<1:0>:** Dead Time Control bits - 11 = Dead Time Compensation mode enabled - 10 = Dead time function is disabled - 01 = Negative dead time actively applied for Complementary Output mode (5) - 00 = Positive dead time actively applied for all output modes - bit 5 **DTCP:** Dead Time Compensation Polarity bit<sup>(5)</sup> - 1 = If the DTCMPx pin = 0, PWMxL is shortened, and PWMxH is lengthened If the DTCMPx pin = 1, PWMxH is shortened, and PWMxL is lengthened - 0 = If the DTCMPx pin = 0, PWMxH is shortened, and PWMxL is lengthened If the DTCMPx pin = 1, PWMxL is shortened, and PWMxH is lengthened - Note 1: If PWM interrupts are enabled, software must clear the PWMCONx interrupt flags here first, followed second by the corresponding IFSx bit in the Interrupt controller. The corresponding PWM IFSx interrupt flag cannot be cleared if any of these local PWMCON interrupt bits are not cleared first. Failure to do so will result in an infinite interrupt loop. - 2: This bit should not be changed after the PWM is enabled (PTEN bit (PTCON<15>) = 1). - 3: To operate in External Period Reset mode, the ITB bit must be set to '1' and the CLMOD bit in the IOCONx register must be set to '0'. - **4:** For Dead Time Compensation (DTCP) to be effective, DTC<1:0> must be set to '11'; otherwise, DTCP is ignored. - **5:** Negative dead time is only implemented for Edge-Aligned mode. - **6:** XPRES mode should only be used in Edge-Aligned mode with or without complimentary outputs. It does not support dead time compensation (i.e., duty cycle adjustment), which is selected when DTC<1:0> = 11. - 7: The clock source is one of the master time bases even if ITB = 1 is selected. ### REGISTER 31-11: PWMCONx: PWM CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) (CONTINUED) bit 4 **PTDIR:** PWM Timer Direction bit<sup>(6)</sup> 1 = PWM timer is decrementing 0 = PWM timer is incrementing bit 3 MTBS: Master Time Base Select bit<sup>(7)</sup> - $\ensuremath{\mathtt{1}}$ = Secondary master time base is the clock source for the MCPWM module - 0 = Primary master time base is the clock source for the MCPWM module - bit 2 Unimplemented: Read as '0' - bit 1 XPRES: External PWM Reset Control bit (3) - 1 = Current-limit source resets primary local time base for this PWM generator if it is in Independent Time Base mode and the PWM module enters the deassertion portion of the duty cycle - 0 = External pins do not affect PWM time base **Note:** If the Current-Limit Reset signal is asserted during the active assertion time of the duty cycle, the time base will not Reset until two PWM clock cycles after the duty cycle transition from assertion to deassertion phase of the duty cycle. bit 0 **Unimplemented:** Read as '0' - Note 1: If PWM interrupts are enabled, software must clear the PWMCONx interrupt flags here first, followed second by the corresponding IFSx bit in the Interrupt controller. The corresponding PWM IFSx interrupt flag cannot be cleared if any of these local PWMCON interrupt bits are not cleared first. Failure to do so will result in an infinite interrupt loop. - 2: This bit should not be changed after the PWM is enabled (PTEN bit (PTCON<15>) = 1). - 3: To operate in External Period Reset mode, the ITB bit must be set to '1' and the CLMOD bit in the IOCONx register must be set to '0'. - **4:** For Dead Time Compensation (DTCP) to be effective, DTC<1:0> must be set to '11'; otherwise, DTCP is ignored. - 5: Negative dead time is only implemented for Edge-Aligned mode. - **6:** XPRES mode should only be used in Edge-Aligned mode with or without complimentary outputs. It does not support dead time compensation (i.e., duty cycle adjustment), which is selected when DTC<1:0> = 11. - 7: The clock source is one of the master time bases even if ITB = 1 is selected. ### REGISTER 31-12: IOCONx: PWMX I/O CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |-----------|---------------------|-----------------------|------------------------------|------------------------|------------------------|------------------------|----------------------------|------------------|--| | | 31/23/13/1 | 30/22/14/0 | 29/21/13/3 | 20/20/12/4 | 21/19/11/3 | 20/10/10/2 | 23/11/3/1 | 24/10/0/0 | | | 31:24 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 31.24 | | | | CLSRC< | CLPOL <sup>(2,4)</sup> | CLMOD <sup>(2,4)</sup> | | | | | 22,16 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | | | 23:16 | _ | | FLTSRC<3:0> <sup>(2,4)</sup> | | | | FLTMOD<1:0> <sup>(4)</sup> | | | | 15:8 | R/W-0 | | 13.0 | PENH <sup>(1)</sup> | PENL <sup>(1)</sup> | POLH <sup>(2)</sup> | POLL <sup>(2)</sup> | PMOD- | <1:0> <sup>(2)</sup> | OVRENH | OVRENL | | | 7:0 | R/W-0 | | | OVRDA | T<1:0> <sup>(3)</sup> | FLTDAT- | <1:0> <sup>(2,3)</sup> | CLDA | T<1:0> | SWAP | OSYNC | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-30 Unimplemented: Read as '0' - Note 1: During PWM initialization, if the PWMLOCK fuse bit is 'enabled' (logic '0'), the control on the state of the PWMxL/PWMxH output pins rests solely with the PENH and PENL bits. However, these bits are at '0', which leaves the pin control with the I/O module. Care must be taken to not inadvertently set the TRIS bits to output, which could impose an incorrect output on the PWMxH/PWMxL pins even if there are external pull-up and pull-down resistors. The data direction for the pins must be set to input if tri-state behavior is desired or be driven to the appropriate logic states. The PENH and PENL bits must always be initialized prior to enabling the MCPWM module (PTEN bit = 1). - 2: These bits must not be changed after the MCPWM module is enabled (PTEN bit = 1). - 3: State represents Active/Inactive state of the PWM, depending on the POLH and POLL bits. For example, if FLTDAT<1> is set to '1' and POLH is set to '1', the PWMxH pin will be at logic level 0 (active level) when a Fault occurs. - **4:** If (PWMLOCK = 0), these bits are writable only after the proper sequence is written to the PWMKEY register. If (PWMLOCK = 1), these bits are writable at all times. The user application must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation for the IOCONx register if PWMLOCK = 1. Write access to a IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. This is not an atomic operation, and therefore, any CPU interrupts that occur during or immediately after an unlock sequence may cause the IOCONx SFR write access to fail. Note: Dead Time Compensation, Current-Limit, and Faults share common inputs on the FLTx inputs ('x' = 1-8, and 15). Therefore, it is not recommended that a user application assign these multiple functions on the same Fault FLTx pin. In addition, DTCMP functions are fixed to specific FLTx inputs, where Current-Limit, (CLSRC<3:0> bits) and Faults (FLTSRC<3:0> bits) can be assigned to any one of 15 unique and separate inputs. For example, if a user application was required to assign multiple simultaneous Fault, Current-Limit, DTCMP to a single PWM1. Refer to the following examples for both desirable and undesirable practices. ``` Desirable Example PWM1: (DTCMP1 = FLT3 pin, Current Limit = FLT7 pin, Fault = FLT8 pin) ``` ### REGISTER 31-12: IOCONx: PWMX I/O CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) CLSRC<3:0>: Current-Limit Control Signal Source select bit for PWM Generator 'x'(2,4) ``` These bits specify the current-limit control signal source. 1111 = FLT15 1110 = FLT17 ``` 1101 = FLT16 1100 = Comparator 5 1011 = Comparator 4 1010 = Comparator 3 1001 = Comparator 2 1000 = Comparator 1 0111 = FLT8 0110 = FLT7 0101 = FLT6 0100 = FLT5 0011 = FLT4 0010 = FLT3 0001 = FLT2 0000 **= FLT1** CLPOL: Current-Limit Polarity bits for PWM Generator 'x'(2,4) bit 25 - 1 = The selected current-limit source is active-low - 0 = The selected current-limit source is active-high - Note 1: During PWM initialization, if the PWMLOCK fuse bit is 'enabled' (logic '0'), the control on the state of the PWMxL/PWMxH output pins rests solely with the PENH and PENL bits. However, these bits are at '0', which leaves the pin control with the I/O module. Care must be taken to not inadvertently set the TRIS bits to output, which could impose an incorrect output on the PWMxH/PWMxL pins even if there are external pull-up and pull-down resistors. The data direction for the pins must be set to input if tri-state behavior is desired or be driven to the appropriate logic states. The PENH and PENL bits must always be initialized prior to enabling the MCPWM module (PTEN bit = 1). - 2: These bits must not be changed after the MCPWM module is enabled (PTEN bit = 1). - State represents Active/Inactive state of the PWM, depending on the POLH and POLL bits. For example, if FLTDAT<1> is set to '1' and POLH is set to '1', the PWMxH pin will be at logic level 0 (active level) when a Fault occurs. - 4: If (PWMLOCK = 0), these bits are writable only after the proper sequence is written to the PWMKEY register. If (PWMLOCK = 1), these bits are writable at all times. The user application must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation for the IOCONx register if PWMLOCK = 1. Write access to a IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. This is not an atomic operation, and therefore, any CPU interrupts that occur during or immediately after an unlock sequence may cause the IOCONx SFR write access to fail. Note: Dead Time Compensation, Current-Limit, and Faults share common inputs on the FLTx inputs ('x' = 1-8, and 15). Therefore, it is not recommended that a user application assign these multiple functions on the same Fault FLTx pin. In addition, DTCMP functions are fixed to specific FLTx inputs, where Current-Limit, (CLSRC<3:0> bits) and Faults (FLTSRC<3:0> bits) can be assigned to any one of 15 unique and separate inputs. For example, if a user application was required to assign multiple simultaneous Fault, Current-Limit, DTCMP to a single PWM1. Refer to the following examples for both desirable and undesirable practices. ``` Desirable Example PWM1: (DTCMP1 = FLT3 pin, Current Limit = FLT7 pin, Fault = FLT8 pin) ``` ``` //Enable DTCMP1 input on FLT3 function pin PWMCON1bits.DTC = 0b11; IOCON1bits.CLMOD = 1; //Enable PWM1 Current-Limit mode IOCON1bits.CLSRC = 0b0110; //Enable current limit for PWM1 on FLT7 pin IOCON1bits.FLTMOD = 1; //Enable PWM1 Fault mode IOCON1bits.FLTSRC = 0b0111; //Enable Fault for PWM1 on FLT8 pin ``` ``` PWMCON1bits.DTC = 0b11; //Enable DTCMP1 input on FLT3 function pin IOCON1bits.CLMOD = 1; //Enable PWM1 Current-Limit mode IOCON1bits.CLSRC = 0b0010; //Enable current limit for PWM1 on FLT3 pin IOCON1bits.FLTMOD = 1; //Enable PWM1 Fault mode IOCON1bits.FLTSRC = 0b0010; //Enable Fault for PWM1 on FLT3 pin ``` ### REGISTER 31-12: IOCONx: PWMX I/O CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) bit 24 **CLMOD:** Current-Limit Mode Enable bit for PWM Generator 'x'(2,4) - 1 = Current-limit function is enabled - 0 = Current-limit function is disabled, current-limit overrides disabled (current-limit interrupts can still be generated). If Faults are enabled, FLTMOD will override the CLMOD bit. Changes take effect on the next PWM cycle boundary following PWM being enabled, and subsequently on each PWM cycle boundary. When updating CLMOD from '1' to '0', if the current-limit input is still active, the current-limit override condition will not be removed. - bit 23 Unimplemented: Read as '0' - Note 1: During PWM initialization, if the PWMLOCK fuse bit is 'enabled' (logic '0'), the control on the state of the PWMxL/PWMxH output pins rests solely with the PENH and PENL bits. However, these bits are at '0', which leaves the pin control with the I/O module. Care must be taken to not inadvertently set the TRIS bits to output, which could impose an incorrect output on the PWMxH/PWMxL pins even if there are external pull-up and pull-down resistors. The data direction for the pins must be set to input if tri-state behavior is desired or be driven to the appropriate logic states. The PENH and PENL bits must always be initialized prior to enabling the MCPWM module (PTEN bit = 1). - 2: These bits must not be changed after the MCPWM module is enabled (PTEN bit = 1). - 3: State represents Active/Inactive state of the PWM, depending on the POLH and POLL bits. For example, if FLTDAT<1> is set to '1' and POLH is set to '1', the PWMxH pin will be at logic level 0 (active level) when a Fault occurs. - 4: If (PWMLOCK = 0), these bits are writable only after the proper sequence is written to the PWMKEY register. If (PWMLOCK = 1), these bits are writable at all times. The user application must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation for the IOCONx register if PWMLOCK = 1. Write access to a IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. This is not an atomic operation, and therefore, any CPU interrupts that occur during or immediately after an unlock sequence may cause the IOCONx SFR write access to fail. Note: Dead Time Compensation, Current-Limit, and Faults share common inputs on the FLTx inputs ('x' = 1-8, and 15). Therefore, it is not recommended that a user application assign these multiple functions on the same Fault FLTx pin. In addition, DTCMP functions are fixed to specific FLTx inputs, where Current-Limit, (CLSRC<3:0> bits) and Faults (FLTSRC<3:0> bits) can be assigned to any one of 15 unique and separate inputs. For example, if a user application was required to assign multiple simultaneous Fault, Current-Limit, DTCMP to a single PWM1. Refer to the following examples for both desirable and undesirable practices. #### Desirable Example PWM1: (DTCMP1 = FLT3 pin, Current Limit = FLT7 pin, Fault = FLT8 pin) ### REGISTER 31-12: IOCONx: PWMX I/O CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) bit 22-19 FLTSRC<3:0>: Fault Control Signal Source Select bits for PWM Generator 'x'(2,4) ``` These bits specify the Fault control source. 1111 = FLT15 1110 = FLT16 1101 = FLT17 1100 = Comparator 5 1011 = Comparator 4 1010 = Comparator 3 1001 = Comparator 2 1000 = Comparator 1 0111 = FLT8 0110 = FLT7 0101 = FLT6 0100 = FLT5 0011 = FLT4 0010 = FLT3 0001 = FLT2 ``` bit 18 **FLTPOL:** Fault Polarity bits for PWM Generator 'x'(2) 0000 **= FLT1** - 1 = The selected fault source is active-low - 0 = The selected fault source is active-high - Note 1: During PWM initialization, if the PWMLOCK fuse bit is 'enabled' (logic '0'), the control on the state of the PWMxL/PWMxH output pins rests solely with the PENH and PENL bits. However, these bits are at '0', which leaves the pin control with the I/O module. Care must be taken to not inadvertently set the TRIS bits to output, which could impose an incorrect output on the PWMxH/PWMxL pins even if there are external pull-up and pull-down resistors. The data direction for the pins must be set to input if tri-state behavior is desired or be driven to the appropriate logic states. The PENH and PENL bits must always be initialized prior to enabling the MCPWM module (PTEN bit = 1). - 2: These bits must not be changed after the MCPWM module is enabled (PTEN bit = 1). - 3: State represents Active/Inactive state of the PWM, depending on the POLH and POLL bits. For example, if FLTDAT<1> is set to '1' and POLH is set to '1', the PWMxH pin will be at logic level 0 (active level) when a Fault occurs. - 4: If (PWMLOCK = 0), these bits are writable only after the proper sequence is written to the PWMKEY register. If (PWMLOCK = 1), these bits are writable at all times. The user application must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation for the IOCONx register if PWMLOCK = 1. Write access to a IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. This is not an atomic operation, and therefore, any CPU interrupts that occur during or immediately after an unlock sequence may cause the IOCONx SFR write access to fail. Note: Dead Time Compensation, Current-Limit, and Faults share common inputs on the FLTx inputs ('x' = 1-8, and 15). Therefore, it is not recommended that a user application assign these multiple functions on the same Fault FLTx pin. In addition, DTCMP functions are fixed to specific FLTx inputs, where Current-Limit, (CLSRC<3:0> bits) and Faults (FLTSRC<3:0> bits) can be assigned to any one of 15 unique and separate inputs. For example, if a user application was required to assign multiple simultaneous Fault, Current-Limit, DTCMP to a single PWM1. Refer to the following examples for both desirable and undesirable practices. ``` Desirable Example PWM1: (DTCMP1 = FLT3 pin, Current Limit = FLT7 pin, Fault = FLT8 pin) ``` ### REGISTER 31-12: IOCONx: PWMX I/O CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) - bit 17-16 **FLTMOD<1:0>:** Fault Mode bits for PWM Generator 'x'(4) - 11 = Fault input is disabled, no fault overrides possible. (fault interrupts can still be generated) - 10 = Reserved - 01 = Selected fault source forces PWMxH, PWMxL pins to FLTDAT<1:0> values (cycle by cycle) - 00 = Selected fault source forces PWMxH, PWMxL pins to FLTDAT<1:0> values (Latched condition) Changes take effect on the next PWM cycle boundary following PWM being enabled, and subsequently on each PWM cycle boundary. When updating FLTMOD<1:0> from '00' or '01' to '11' (disabled), if the fault input is still active the fault override condition will not be removed. If enabled, Faults will override the CLMOD bit setting. - bit 15 **PENH:** PWMxH Output Pin Ownership bit<sup>(1)</sup> - 1 = PWM module controls PWMxH pin - 0 = GPIO module controls PWMxH pin - bit 14 **PENL:** PWMxL Output Pin Ownership bit<sup>(1)</sup> - 1 = PWM module controls PWMxL pin - 0 = GPIO module controls PWMxL pin - bit 13 **POLH:** PWMxH Output Pin Polarity bit<sup>(2)</sup> - 1 = PWMxH pin is active-low - 0 = PWMxH pin is active-high - Note 1: During PWM initialization, if the PWMLOCK fuse bit is 'enabled' (logic '0'), the control on the state of the PWMxL/PWMxH output pins rests solely with the PENH and PENL bits. However, these bits are at '0', which leaves the pin control with the I/O module. Care must be taken to not inadvertently set the TRIS bits to output, which could impose an incorrect output on the PWMxH/PWMxL pins even if there are external pull-up and pull-down resistors. The data direction for the pins must be set to input if tri-state behavior is desired or be driven to the appropriate logic states. The PENH and PENL bits must always be initialized prior to enabling the MCPWM module (PTEN bit = 1). - 2: These bits must not be changed after the MCPWM module is enabled (PTEN bit = 1). - 3: State represents Active/Inactive state of the PWM, depending on the POLH and POLL bits. For example, if FLTDAT<1> is set to '1' and POLH is set to '1', the PWMxH pin will be at logic level 0 (active level) when a Fault occurs. - **4:** If (PWMLOCK = 0), these bits are writable only after the proper sequence is written to the PWMKEY register. If (PWMLOCK = 1), these bits are writable at all times. The user application must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation for the IOCONx register if PWMLOCK = 1. Write access to a IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. This is not an atomic operation, and therefore, any CPU interrupts that occur during or immediately after an unlock sequence may cause the IOCONx SFR write access to fail. Note: Dead Time Compensation, Current-Limit, and Faults share common inputs on the FLTx inputs ('x' = 1-8, and 15). Therefore, it is not recommended that a user application assign these multiple functions on the same Fault FLTx pin. In addition, DTCMP functions are fixed to specific FLTx inputs, where Current-Limit, (CLSRC<3:0> bits) and Faults (FLTSRC<3:0> bits) can be assigned to any one of 15 unique and separate inputs. For example, if a user application was required to assign multiple simultaneous Fault, Current-Limit, DTCMP to a single PWM1. Refer to the following examples for both desirable and undesirable practices. ### Desirable Example PWM1: (DTCMP1 = FLT3 pin, Current Limit = FLT7 pin, Fault = FLT8 pin) ### REGISTER 31-12: IOCONx: PWMX I/O CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) ``` bit 12 POLL: PWMxL Output Pin Polarity bit<sup>(2)</sup> ``` 1 = PWMxL pin is active-low 0 = PWMxL pin is active-high bit 11-10 **PMOD<1:0>:** PWM 'x' I/O Pin Mode bits<sup>(2)</sup> 11 = PWMxL output is held at logic '0' (adjusted by the POLL bit) 10 = PWM I/O pin pair is in Push-Pull Output mode 01 = PWM I/O pin pair is in Redundant Output mode 00 = PWM I/O pin pair is in Complementary Output mode 00 = PWW I/O pin pair is in Complementary Output m bit 9 **OVRENH:** Override Enable for PWMxH Pin bit 1 = OVRDAT<1> provides data for output on PWMxH pin 0 = PWM generator provides data for PWMxH pin bit 8 **OVRENL:** Override Enable for PWMxL Pin bit 1 = OVRDAT<0> provides data for output on PWMxL pin 0 = PWM generator provides data for PWMxL pin bit 7-6 **OVRDAT<1:0>:** State<sup>(3)</sup> for PWMxH, PWMxL Pins if Override is Enabled bits If OVRENH = 1, OVRDAT<1> provides data for PWMxH If OVRENL = 1, OVRDAT<0> provides data for PWMxL - Note 1: During PWM initialization, if the PWMLOCK fuse bit is 'enabled' (logic '0'), the control on the state of the PWMxL/PWMxH output pins rests solely with the PENH and PENL bits. However, these bits are at '0', which leaves the pin control with the I/O module. Care must be taken to not inadvertently set the TRIS bits to output, which could impose an incorrect output on the PWMxH/PWMxL pins even if there are external pull-up and pull-down resistors. The data direction for the pins must be set to input if tri-state behavior is desired or be driven to the appropriate logic states. The PENH and PENL bits must always be initialized prior to enabling the MCPWM module (PTEN bit = 1). - 2: These bits must not be changed after the MCPWM module is enabled (PTEN bit = 1). - 3: State represents Active/Inactive state of the PWM, depending on the POLH and POLL bits. For example, if FLTDAT<1> is set to '1' and POLH is set to '1', the PWMxH pin will be at logic level 0 (active level) when a Fault occurs - 4: If (PWMLOCK = 0), these bits are writable only after the proper sequence is written to the PWMKEY register. If (PWMLOCK = 1), these bits are writable at all times. The user application must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation for the IOCONx register if PWMLOCK = 1. Write access to a IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. This is not an atomic operation, and therefore, any CPU interrupts that occur during or immediately after an unlock sequence may cause the IOCONx SFR write access to fail. Note: Dead Time Compensation, Current-Limit, and Faults share common inputs on the FLTx inputs ('x' = 1-8, and 15). Therefore, it is not recommended that a user application assign these multiple functions on the same Fault FLTx pin. In addition, DTCMP functions are fixed to specific FLTx inputs, where Current-Limit, (CLSRC<3:0> bits) and Faults (FLTSRC<3:0> bits) can be assigned to any one of 15 unique and separate inputs. For example, if a user application was required to assign multiple simultaneous Fault, Current-Limit, DTCMP to a single PWM1. Refer to the following examples for both desirable and undesirable practices. ### Desirable Example PWM1: (DTCMP1 = FLT3 pin, Current Limit = FLT7 pin, Fault = FLT8 pin) ### REGISTER 31-12: IOCONx: PWMX I/O CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) bit 5-4 FLTDAT<1:0>: State<sup>(3)</sup> for PWMxH and PWMxL Pins if FLTMOD is Enabled bits<sup>(2)</sup> If FLTMOD<1:0> (IOCONx<17:16>) = 00 or 01, one of the following Fault modes is enabled: If fault is active, FLTDAT<1> provides the state for PWMxH If fault is active, FLTDAT<0> provides the state for PWMxL If fault is inactive, FLTDAT<1:0> bits are ignored bit 3-2 CLDAT<1:0>: State for PWMxH and PWMxL Pins if CLMOD is Enabled bits<sup>(3)</sup> If CLMOD (IOCONx<24>) = 1, Current-Limit mode is enabled, as follows: If current limit is active, CLTDAT<1> provides the state for PWMxH If current limit is active, CLTDAT<0> provides the state for PWMxL If current limit is inactive, CLTDAT<1:0> bits are ignored - bit 1 **SWAP:** SWAP PWMxH and PWMxL Pins bit - 1 = PWMxH output signal is connected to PWMxL pin; PWMxL output signal is connected to PWMxH pin - 0 = PWMxH and PWMxL output signals pins are mapped to their respective pins - bit 0 **OSYNC:** Output Override Synchronization bit - 1 = Output overrides through the OVRDAT<1:0> bits are synchronized to the PWM time base - 0 = Output overrides through the OVRDAT<1:0> bits occur on next CPU clock boundary - Note 1: During PWM initialization, if the PWMLOCK fuse bit is 'enabled' (logic '0'), the control on the state of the PWMxL/PWMxH output pins rests solely with the PENH and PENL bits. However, these bits are at '0', which leaves the pin control with the I/O module. Care must be taken to not inadvertently set the TRIS bits to output, which could impose an incorrect output on the PWMxH/PWMxL pins even if there are external pull-up and pull-down resistors. The data direction for the pins must be set to input if tri-state behavior is desired or be driven to the appropriate logic states. The PENH and PENL bits must always be initialized prior to enabling the MCPWM module (PTEN bit = 1). - 2: These bits must not be changed after the MCPWM module is enabled (PTEN bit = 1). - 3: State represents Active/Inactive state of the PWM, depending on the POLH and POLL bits. For example, if FLTDAT<1> is set to '1' and POLH is set to '1', the PWMxH pin will be at logic level 0 (active level) when a Fault occurs. - 4: If (PWMLOCK = 0), these bits are writable only after the proper sequence is written to the PWMKEY register. If (PWMLOCK = 1), these bits are writable at all times. The user application must write two consecutive values of (0xABCD and 0x4321) to the PWMKEY register to perform the unlock operation for the IOCONx register if PWMLOCK = 1. Write access to a IOCONx register must be the next SFR access following the unlock process. There can be no other SFR accesses during the unlock process and subsequent write access. This is not an atomic operation, and therefore, any CPU interrupts that occur during or immediately after an unlock sequence may cause the IOCONx SFR write access to fail. Note: Dead Time Compensation, Current-Limit, and Faults share common inputs on the FLTx inputs ('x' = 1-8, and 15). Therefore, it is not recommended that a user application assign these multiple functions on the same Fault FLTx pin. In addition, DTCMP functions are fixed to specific FLTx inputs, where Current-Limit, (CLSRC<3:0> bits) and Faults (FLTSRC<3:0> bits) can be assigned to any one of 15 unique and separate inputs. For example, if a user application was required to assign multiple simultaneous Fault, Current-Limit, DTCMP to a single PWM1. Refer to the following examples for both desirable and undesirable practices. ### **Desirable Example PWM1:** (DTCMP1 = FLT3 pin, Current Limit = FLT7 pin, Fault = FLT8 pin) ### REGISTER 31-13: PDCx: PWM GENERATOR DUTY CYCLE REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | | 31.24 | | _ | _ | _ | _ | _ | _ | _ | | | 23:16 | U-0 | | 23.10 | | _ | _ | _ | _ | _ | _ | _ | | | 15:8 | R/W-0 | | 13.6 | | PDC<15:8> | | | | | | | | | 7:0 | R/W-0 | | 7.0 | | | | PDC | <7:0> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 **PDC<15:0>:** Primary PWM Generator 'x' Duty Cycle Value bits<sup>(2)</sup> If Edge-Aligned mode is enabled (ECAM<1:0> bits (PWMCONx<11:10>) = 00), these bits specify the trailing edge instance of the ON time and controls the duty cycle directly (PWM Resolution = (1/FSYCLK)). If one of the Center-Aligned mode is enabled (ECAM<1:0> (PWMCONx<11:10>) = 01, 10, or 11), these bits specify the compare instance for 'leading edge' level transition (PWM Resolution = (2/FSYCLK)). Note 1: In Independent PWM mode, PMOD<1:0> (IOCONx<11:10>) = 11, the PDCx register controls the PWMxH duty cycle only. In Complementary, Redundant and Push-Pull PWM modes (PMOD<1:0> = 00, 01, or 10), the PDCx register controls the duty cycle of both the PWMxH and PWMxL. 2: PDCx = ((FSYSCLK / (F<sub>PWM</sub> \* PTCON<PCLKDIV>)) \* Desired Duty Cycle) F<sub>PWM</sub> = User Desired PWM Frequency ### REGISTER 31-14: SDCx: PWM SECONDARY DUTY CYCLE REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 31:24 | U-0 | | | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | | | 23:16 | U-0 | | | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | | | 15:8 | R/W-0 | | | 13.6 | | SDC<15:8> | | | | | | | | | | 7:0 | R/W-0 | | | 7.0 | | | | SDC | <7:0> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 **SDC<15:0>:** Secondary Duty Cycle bits for PWMx output pin If Edge-Aligned mode is enabled (ECAM<1:0> (PWMCONx<11:10>) = 00) these bits are unused. If Symmetric Center-Aligned mode is enabled (ECAM<1:0> (PWMCONx<11:10>) = 01), these bits are updated transparently to the user. Loads to the PDCx register automatically copy over to the SDCx register. If Asymmetric Center-Aligned mode is enabled (ECAM<1:0> (PWMCONx<11:10>) = 10 or 11), these bits specify the compare instance for 'trailing edge' level transition (PWM Resolution = (2/FSYCLK)). #### REGISTER 31-15: PHASEx: PWM PRIMARY PHASE SHIFT REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | | 23:16 | U-0 | | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | | 15:8 | R/W-0 | | 13.6 | | PHASE<15:8> | | | | | | | | | 7:0 | R/W-0 | | 7.0 | | | | PHAS | E<7:0> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 PHASE<15:0>: PWM Phase Shift Value or Independent Time Base Period bits for the PWM Generator bits<sup>(6)</sup> Phase shifting is used to offset the start of a PWM Generator's time base period, relative to a master time base, as well as the generated duty cycle. Also, the effects on the operation of the PWM signals through any external control signals, such as current-limit, Fault, and dead time compensation, are also shifted in time. **Note 1:** If the ITB bit (PWMCONx<9>) = 0, the following applies based on the mode of operation: Complementary, Redundant and Push-Pull Output modes (PMOD<1:0> (IOCONx<11:10>) = 00, 01, or 10) PHASE<15:0> = Phase shift value for PWMxH and PWMxL outputs - **2:** If the ITB bit = 1, the following applies based on the mode of operation: - Complementary, Redundant, and Push-Pull Output modes (PMOD<1:0> = 00, 01, or 10) PHASE<15:0> = local time base period value for TMRx - 3: A Phase offset that exceeds the PWM period will lead to unpredictable results. - 4: The minimum period value is 0x0008. - 5: The SDCx register is used in Independent PWM mode only (PMOD<1:0> = 11). When used in Independent PWM mode, the SDCx register controls the PWMxL duty cycle. - **6:** PHASEx = (FSYSCLK / (F<sub>PWM</sub> \* PTCON<PCLKDIV>)) F<sub>PWM</sub> = User Desired PWM Frequency ### REGISTER 31-16: DTRx: PWM DEAD TIME REGISTER 'X' ('X' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | | 31.24 | _ | _ | _ | _ | _ | | _ | _ | | | 23:16 | U-0 | | 23.10 | _ | _ | _ | _ | _ | | _ | _ | | | 15:8 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 13.6 | _ | _ | DTR<13:8> | | | | | | | | 7:0 | R/W-0 | | 7.0 | | | | DTR | <7:0> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 DTR<13:0>: Unsigned 14-bit Dead Time Value for PWMxH Dead Time Unit bits These bits specify the leading edge dead time count between the PWMxH and PWMxL. The time base for the count is the same as for the PWM generator. The dead time period is typically set equal to the switching times of the power transistors in the application circuits. It is specifically intended for use in Complementary Output mode. The use of dead time in any other mode may generate unexpected or unpredictable results. If the duty cycle value in the DC register equals '0', or is greater than or equal to the Period, dead time compensation is ignored. The values for Duty Cycle + Dead Time + Dead Time Compensation must not exceed the value for the Period register minus 1. If the sum exceeds the Period Register minus 1, unexpected results may occur. The values for Duty Cycle + Dead Time - Dead Time Compensation must be greater than '0', or unexpected results may occur. **Note:** The DTR<13:0> and ALTDTR<13:0> bits must be ≥ 6 while using the Leading Edge Blanking (LEB). ### REGISTER 31-17: ALTDTRx: PWM ALTERNATE DEAD TIME REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-----------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | | _ | _ | _ | _ | _ | _ | _ | | 15.0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 13.6 | 15:8 — — ALTDTR<13:8> | | | | | | | | | 7:0 | R/W-0 | 7.0 | | | | ALTDT | R<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 ALTDTR<13:0>: Unsigned 14-bit Dead Time Value for PWMxL Dead Time Unit bits These bits specify the trailing edge dead time count between the PWMxH and PWMxL. The time base for the count is the same as for the PWM generator. The alternate dead time period is typically set equal to the switching times of the power transistors in the application circuits. It is specifically intended for use in Complementary Output mode. The use of dead time in any other mode may generate unexpected or unpredictable results. If the duty cycle value in the DC register equals '0', or is greater than or equal to the Period, alternate dead time compensation is ignored. The values for Duty Cycle + Dead Time + ALT Dead Time Compensation must not exceed the value for the Period Register minus 1. If the sum exceeds the Period Register -minus1, unexpected results may occur. The values for Duty Cycle + Dead Time minus Alternate Dead Time Compensation must be greater than '0', or unexpected results may occur. **Note:** The DTR<13:0> and ALTDTR<13:0> bits must be ≥ 6 while using the Leading Edge Blanking (LEB). ### REGISTER 31-18: DTCOMPx: DEAD TIME COMPENSATION REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |-----------|-------------------|-------------------|-----------------------------|-------------------|-----------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | | 23:16 | U-0 | | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | | 15:8 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | | 13.6 | _ | _ | COMP<13:8> <sup>(1,2)</sup> | | | | | | | | 7:0 | R-0 | | 7.0 | | | | COMP< | 7:0> <sup>(1,2)</sup> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 **COMP<13:0>:** Dead Time Compensation Value bits<sup>(1,2)</sup> Dead time compensation value if Dead Time compensation mode is enabled. - Note 1: COMP<13:0> Min LSb = 1 / FSYSCLK for ECAM<1:0> bits (PWMCONx<11:10>) = \0b00 Edge-Aligned mode; COMP<13:0> Min LSb = 2 / FSYSCLK for ECAM<1:0> bits (PWMCONx<11:10>)> \0b00 Center-Aligned mode. - 2: When Dead Time compensation mode is selected through the DTC<1:0> bits in the PWMCONx register, an external pin, CMPx (i.e., FLTx) connected to the Dead Time Compensation module input signals, cause the value in the COMPx register to be added to or subtracted from the PWMx duty cycle. The dead time compensation input signals are sampled at the end of a PWM cycle for use in the next PWM cycle. The modification of the duty cycle duration through the CMPx registers occurs during the end (trailing edge) of the duty cycle. Dead time compensation is available only for Positive Dead Time mode. The CMPx value must be less than one-half the value of the duty cycle register, PDCx; otherwise, unpredictable behavior will result. Dead time compensation will not apply for a duty cycle of zero. In this case, the PWM output will remain zero regardless of the state of the CMPx input pin. # REGISTER 31-19: TRIGx: PWM PRIMARY TRIGGER COMPARE VALUE REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | | _ | _ | | 15:8 | R/W-0 | 15.6 | TRGCMP<15:8> | | | | | | | | | 7:0 | R/W-0 | 7.0 | | | | TRGCN | /IP<7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 TRGCMP<15:0>: Trigger Compare Value bits These bits specify the value to match against the local time base register PTMR to generate a trigger to the ADC module and an interrupt if the TRGIEN bit (PWMCONx<21>) is set. **Note:** To trigger at the period boundary, set TRIGx to 0x0 and not the PTPER period value. ### REGISTER 31-20: TRGCONx: PWM TRIGGER CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|----------------------|-----------------------|-------------------|-------------------|-------------------|-----------------------|------------------|-----------------------| | 31:24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | R/W-0 | 15.6 | | TRGDI | V<3:0> | | TRGSEI | _<1:0> <sup>(1)</sup> | STRGSE | L<1:0> <sup>(1)</sup> | | 7:0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | | | DTM <sup>(1,2)</sup> | STRGIS <sup>(1)</sup> | - | | _ | | - | _ | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-12 TRGDIV<3:0>: Trigger 'x' Output Divider bits 1111 = Trigger output for every sixteenth trigger event • • 0010 = Trigger output for every third trigger event 0001 = Trigger output for every second trigger event 0000 = Trigger output for every trigger event bit 11-10 **TRGSEL<1:0>:** Trigger Cycle Selection for Dual Cycle PWM Cycles (Center-Aligned and Push-Pull)<sup>(1)</sup> This bit field has no effect on the raw trigger generation for single cycle PWM modes such as edgealigned PWM. Each time a raw comparison event occurs, the raw event is processed by the trigger divider. - 11 = Reserved, default to same behavior as TRGSEL<1:0> = 00. - 10 = When a trigger comparison match event occurs in the incrementing phase in the dual cycle PWM mode (PTDIR = 0), a trigger event output is generated if the trigger divider has counted the appropriate number of trigger events. - 01 = When a trigger comparison match event occurs in the decrementing phase in the dual cycle PWM mode (PTDIR = 1), a trigger event output is generated if the trigger divider has counted the appropriate number of trigger events. - 00 = When a trigger comparison match event occurs, generate a trigger event output if the trigger divider has counted the appropriate number of raw trigger events. For dual cycle PWM modes such as Center-Aligned mode and Push-Pull mode, the raw trigger event is generated twice every cycle. However, TRIGx/STRIGx compare values of '0' or equal to the PERIOD match register will only generate one interrupt even in the dual cycle modes. - Note 1: These bits must not be changed after the MCPWM module is enabled (PTEN bit (PTCON<15>) = 1). - 2: The secondary trigger event is generated regardless of the setting of the DTM bit. ### REGISTER 31-20: TRGCONx: PWM TRIGGER CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) bit 9-8 **STRGSEL<1:0>:** Secondary Trigger Cycle Selection bits for Dual Cycle PWM Cycles (Center-Aligned and Push-Pull)<sup>(1)</sup> These bits have no effect on the raw secondary PWM trigger generation for single cycle PWM modes such as edge aligned PWM. Each time a raw comparison event occurs, the raw event is processed by the secondary PWM trigger divider. - 11 = Reserved, default to same behavior as STRGSEL<1:0> = 00 - 10 = When a secondary PWM trigger comparison match event occurs in the second half of a dual cycle PWM mode (PTDIR = 0), generate a secondary PWM trigger event output if the secondary PWM trigger divider has counted the appropriate number of secondary PWM trigger events. - 01 = When a secondary PWM trigger comparison match event occurs in the first half of a dual cycle PWM mode (PTDIR = 1), generate a trigger event output if the secondary PWM trigger divider has counted the appropriate number of secondary PWM trigger events. - 00 = When a secondary PWM trigger comparison match event occurs, generate a secondary PWM trigger event output if the trigger divider has counted the appropriate number of raw secondary PWM trigger events. For two cycle PWM modes such as Center-Aligned mode and Push-Pull mode, the raw secondary PWM trigger event is generated twice. - bit 7 **DTM:** Dual ADC Trigger Mode<sup>(1, 2)</sup> - 1 = Secondary trigger event is combined with the primary trigger event for purposes of creating a combined ADC trigger - 0 = Secondary trigger event is not combined with the primary trigger event for purposes of creating a combined ADC trigger - bit 6 STRGIS: Secondary Trigger Interrupt Select<sup>(1)</sup> This bit should be changed by the user only when PTEN = 0. - 1 = Selects the Secondary Trigger Register (STRIGx) based events for interrupts - 0 = When the DTM bit (TRGCONx<7>) is clear (= 0), TRIGx-based events for interrupts are selected. When the DTM bit is set (= 1), the logical OR of both STRIGx and TRIGx based triggers for interrupts are selected. - bit 5-0 **Unimplemented:** Read as '0' - Note 1: These bits must not be changed after the MCPWM module is enabled (PTEN bit (PTCON<15>) = 1). - 2: The secondary trigger event is generated regardless of the setting of the DTM bit. # REGISTER 31-21: STRIGX: SECONDARY PWM TRIGGER COMPARE REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--| | 31:24 | U-0 | | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | | 23:16 | U-0 | | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | | 15:8 | R/W-0 | | 15.6 | STRGCMP<15:8> | | | | | | | | | | 7:0 | R/W-0 | | 7.0 | | | | STRGCI | MP<7:0> | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 STRGCMP<15:0>: Secondary Trigger Value Bits These bits store the 16-bit value to compare against the SMTMR to generate a trigger to the ADC module to initiate conversion, and an interrupt if the TRGIEN bit (PWMCONx<21>) and the DTM bit (TRIG-CONx<7>) are enabled. Note 1: Min LSb = 1/FSYSCLK. 2: To trigger at the period boundary, set STRIGx to 0x0 and not the PTPER period value. ### REGISTER 31-22: CAPx: PWM TIMER CAPTURE REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|---------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | R-0 | 15.6 | | | | CAP< | 5:8> <sup>(1)</sup> | | | | | 7:0 | R/W-0 | 7.0 | | | | CAP< | 7:0> <sup>(1)</sup> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15-0 CAP<15:0>: Captured Local PWM Timer Value bits<sup>(1)</sup> The value in this register represents the captured local PWM timer (PTMRx) value when a leading edge is detected on the current-limit input. Note 1: The feature is active only after LEB processing on the current-limit input signal is complete. ## REGISTER 31-23: LEBCONx: LEADING-EDGE BLANKING CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 21.24 | U-0 | 31:24 | _ | _ | _ | _ | _ | _ | | | | 23:16 | U-0 | 23.10 | _ | - | _ | _ | | - | - | _ | | 15:8 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | | 13.0 | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | - | _ | | 7:0 | U-0 | | _ | _ | _ | _ | _ | _ | _ | _ | Legend:R = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 PHR: PWMxH Rising Edge Trigger Enable bit 1 = Rising edge of PWMxH will trigger/retrigger the Leading-Edge Blanking counter ${\tt 0} = {\tt Rising\ edge\ of\ PWMxH\ will\ not\ trigger/retrigger\ the\ Leading-Edge\ Blanking\ counter}$ bit 14 PHF: PWMxH Falling Edge Trigger Enable bit 1 = Falling edge of PWMxH will trigger/retrigger the Leading-Edge Blanking counter 0 = Falling edge of PWMxH will not trigger/retrigger the Leading-Edge Blanking counter bit 13 PLR: PWMxL Rising Edge Trigger Enable bit 1 = Rising edge of PWMxL will trigger/retrigger the Leading-Edge Blanking counter 0 = Rising edge of PWMxL will not trigger/retrigger the Leading-Edge Blanking counter bit 12 PLF: PWMxL Falling Edge Trigger Enable bit 1 = Falling edge of PWMxL will trigger/retrigger the Leading-Edge Blanking counter 0 = Falling edge of PWMxL will not trigger/retrigger the Leading-Edge Blanking counter bit 11 FLTLEBEN: Fault Input Leading-Edge Blanking Enable bit 1 = Leading-Edge Blanking is applied to selected fault input 0 = Leading-Edge Blanking is not applied to selected fault input bit 10 CLLEBEN: Current-Limit Leading-Edge Blanking Enable bit 1 = Leading-Edge Blanking is applied to selected current-limit input 0 = Leading-Edge Blanking is not applied to selected current-limit input bit 9-0 Unimplemented: Read as '0' Note: The DTR<13:0> and ALTDTR<13:0> bits must be ≥ 6 while using the Leading Edge Blanking (LEB). ## REGISTER 31-24: LEBDLYx: LEADING-EDGE BLANKING DELAY REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | _ | | 23:16 | U-0 | 23.10 | 1 | | _ | | _ | | _ | _ | | 15:8 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 13.6 | _ | _ | _ | _ | | LEB< | :11:8> | | | 7:0 | R/W-0 | 7.0 | | | | LEB | <7:0> | | | • | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-12 Unimplemented: Read as '0' bit 11-0 LEB<11:0>: Leading-Edge Blanking Delay bits for Current-Limit and Fault Inputs bits These bits specify the time period for which the selected current limit and fault signals are blanked or delayed following the selected edge transition of the PWM signals. This retriggerable counter has the PWM module clock source (SYSCLK) as the time base. ### REGISTER 31-25: AUXCONx: PWM AUXILIARY CONTROL REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-----------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | _ | _ | | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 15:8 | U-0 | 15.6 | _ | _ | _ | _ | _ | _ | _ | _ | | 7:0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7.0 | _ | | | CHOPSE | L<3:0> <sup>(1)</sup> | | CHOPHEN | CHOPLEN | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-6 Unimplemented: Read as '0' bit 5-2 CHOPSEL<3:0>: PWM Chop Clock Source Select bits<sup>(1)</sup> The selected signal will enable and disable (CHOP) the selected PWM outputs. 1111 = Reserved. Do not use 1110 = Reserved. Do not use 1101 = Reserved. Do not use 1100 = PWM12H selected as CHOP clock source • • 0111 = PWM7H selected as CHOP clock source . • 0001 = PWM1H selected as CHOP clock source 0000 = Chop clock generator selected as CHOP clock source bit 1 **CHOPHEN:** PWMxH Output Chopping Enable bit 1 = PWMxH chopping function is enabled 0 = PWMxH chopping function is disabled bit 0 CHOPLEN: PWMxL Output Chopping Enable bit 1 = PWMxL chopping function is enabled 0 = PWMxL chopping function is disabled **Note 1:** This bit should be changed only when the PTEN bit (PTCON<15>) = 0. ### REGISTER 31-26: PTMRx: PWM TIMER REGISTER 'x' ('x' = 1 THROUGH 12) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | _ | _ | _ | _ | _ | | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | | _ | _ | | 15:8 | R/W-0 | 15.6 | | | | TMR< | <15:8> | | | | | 7:0 | R/W-0 | R/W-0 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7.0 | | | | TMR | <7:0> | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-16 **Unimplemented:** Read as '0' bit 15-0 **TMR<15:0>:** PWM Timer bits When the ECAM<1:0> bits (PWMCONx<11:10>) = 00, the counter counts upwards until a period match forces rollover. When the ECAM<1:0> bits (PWMCONx<11:10>) $\neq$ 00, the counter counts downwards starting with a master time base synchronization signal to 0 and then counts upwards until the next synchronization. | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 32.0 HIGH/LOW-VOLTAGE DETECT (HLVD) This Note: data sheet summarizes features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 38. "High/Low-Voltage Detect (HLVD)" (DS60001408), which available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The High/Low-Voltage Detect (HLVD) module is a programmable circuit that can be used to specify both the device voltage trip point and the direction of change. When enabled, a HLVD event will act to disable the Flash controller from executing a programming sequence. This module is used to ensure the supply voltage is sufficient for programming. The HLVD module is an interrupt-driven supply-level detection. The voltage detection monitors the internal power supply. The HLVD module provides the following key features: - · Detection hysteresis - Detection of low-to-high or high-to-low voltage changes - Generation of Non-Maskable Interrupts (NMI) - The LVDIN pin to provide external voltage trip point FIGURE 32-1: PROGRAMMABLE HLVD MODULE BLOCK DIAGRAM ### 32.1 Control Registers ### TABLE 32-1: HLVD REGISTER MAP | ess | | | | | | | | | | Bits | | | | | | | | | " | |----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|--------|--------|------|------|------|------|--------|-------|------|------------| | Virtual Addres<br>(BF80_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 4000 | LII VDCON | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 1800 | HLVDCON | 15:0 | ON | _ | _ | _ | VDIR | BGVST | _ | HLVDET | DISOUT | _ | _ | _ | | HLVDL- | <3:0> | | 0000 | Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: The register in this table has corresponding CLR, SET, and INV registers at their virtual addresses, plus offsets of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. ### REGISTER 32-1: HLVDCON: HIGH/LOW-VOLTAGE DETECT CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|---------------------|-------------------|---------------------|------------------| | 24.24 | U-0 | 31:24 | _ | _ | - | _ | | - | _ | _ | | 23:16 | U-0 | 23.10 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-1 | HS/HC, R/W-0 | | 15:8 | ON | _ | _ | _ | VDIR <sup>(1)</sup> | BGVST | _ | HLVDET | | 7.0 | R/S-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | DISOUT | _ | _ | _ | | HLVDL< | 3:0> <sup>(1)</sup> | | Legend:HS = Hardware SetHC = Hardware ClearS = Settable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-16 Unimplemented: Read as '0' bit 15 ON: HLVD Module Enable bit 1 = HLVD module is enabled0 = HLVD module is disabled bit 14-12 Unimplemented: Read as '0' bit 11 **VDIR:** Voltage Change Direction Select bit<sup>(1)</sup> 1 = Event occurs when voltage equals or exceeds trip point (HLVDL<3:0>) 0 = Event occurs when voltage equals or falls below trip point (HLVDL<3:0>) bit 10 BGVST: Band Gap Reference Voltages Stable Status bit 1 = Indicates internal band gap voltage references is stable 0 = Indicates internal band gap voltage reference is not stable **Note:** This bit is readable when the HLVD module is disabled (ON bit is equal to '0'). bit 9 **Unimplemented:** Read as '1' bit 8 **HLVDET:** High/Low-Voltage Detection Event Status bit 1 = Indicates HLVD Event interrupt is active 0 = Indicates HLVD Event interrupt is not active bit 7 DISOUT: Disable HLVD Output bit 1 = Enable output of HLVD Comparator. Once set, can only be cleared by setting the ON bit to '0'. 0 = Disable output of HLVD Comparator (default Reset value). Will be forced to '0' whenever the ON bit is equal to '0'. bit 6-4 Unimplemented: Read as '0' **Note 1:** To avoid false HLVD events, all HLVD module setting changes should occur only when the module is disabled (ON bit is equal to '0'). ### REGISTER 32-1: HLVDCON: HIGH/LOW-VOLTAGE DETECT CONTROL REGISTER - bit 3-0 **HLVDL<3:0>:** High/Low-Voltage Detection Limit Select bits<sup>(1)</sup> - 1111 = 1.2V (Selects external LVDIN pin) - 1110 = Reserved, do not use - 1101 = Reserved, do not use - 1100 = Reserved, do not use - 1011 = Reserved, do not use - 1010 **= 2.4V** - 1001 **= 2.5V** - 1000 = 2.697V - 0111 **= 2.791V** - 0110 = 3.0V - 0101 **= 3.288V** - 0100 **= 3.529V** - 0011 = Reserved; do not use - 0010 = Reserved; do not use - 0001 = Reserved; do not use - 0000 = Reserved; do not use - **Note 1:** To avoid false HLVD events, all HLVD module setting changes should occur only when the module is disabled (ON bit is equal to '0'). ### 33.0 POWER-SAVING FEATURES Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 10. "Power-Saving Features" (DS60001130), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). This section describes the power-saving features of the PIC32MK GPK/MCM with CAN FD family of devices. These devices have multiple power domains and offer various methods and modes that allow the user to balance the power consumption with device performance. ### 33.1 Power Saving with CPU Running When the CPU is running, power consumption can be controlled by reducing the CPU clock frequency or selecting a lower power clock source (i.e., LPRC or Sosc). In addition, the Peripheral Bus Scaling mode is available for each peripheral bus where peripherals are clocked at reduced speed by selecting a higher divider for the associated PBCLKx, or by disabling the clock completely. ### 33.2 Power-Saving with CPU Halted Peripherals and the CPU can be Halted or disabled to further reduce power consumption. #### 33.2.1 SLEEP MODE Sleep mode has the lowest power consumption of the device power-saving operating modes. The CPU and most peripherals are Halted and the associated clocks are disabled. Select peripherals can continue to operate in Sleep mode and can be used to wake the device from Sleep. See the individual peripheral module sections for descriptions of behavior in Sleep mode. Sleep mode includes the following characteristics: - There can be a wake-up delay based on the oscillator selection - The Fail-Safe Clock Monitor (FSCM) does not operate during Sleep mode - The BOR circuit remains operative during Sleep mode - The WDT, if enabled, is not automatically cleared prior to entering Sleep mode - Some peripherals can continue to operate at limited functionality in Sleep mode. These peripherals include I/O pins that detect a change in the input signal, WDT, ADC, UART and peripherals that use an external clock input or the internal LPRC oscillator (e.g., RTCC, Timer1 and Input Capture). - I/O pins continue to sink or source current in the same manner as they do when the device is not in Sleep The processor will exit, or 'wake-up', from Sleep on one of the following events: - On any interrupt from an enabled source that is operating in Sleep. The interrupt priority must be greater than the current CPU priority. - · On any form of device Reset - · On a WDT time-out If the interrupt priority is lower than or equal to the current priority, the CPU will remain Halted, but the peripheral bus clocks will start running and the device will enter into Idle mode. ### 33.2.2 IDLE MODE In Idle mode, the CPU is Halted; however, all clocks are still enabled. This allows peripherals to continue to operate. Peripherals can be individually configured to Halt when entering Idle by setting their respective SIDL bit. Latency, when exiting Idle mode, is very low due to the CPU oscillator source remaining active. The device enters Idle mode when the SLPEN bit (OSCCON<4>) is clear and a WAIT instruction is executed. The processor will wake or exit from Idle mode on the following events: - On any interrupt event for which the interrupt source is enabled. The priority of the interrupt event must be greater than the current priority of the CPU. If the priority of the interrupt event is lower than or equal to current priority of the CPU, the CPU will remain Halted and the device will remain in Idle mode. - · On any form of device Reset - · On a WDT time-out interrupt #### 33.2.3 POWER-SAVING MODES Figure 33-1 shows a block diagram and the related power-saving features. The various blocks are controlled by the following Configuration bit settings and SFRs: - RTCCLKSEL (RTCCON <9:8>) - SLPEN (OSCCON<4>) - VREGS (PWRCON<0>) **RTCDIS** RTCCLKSEL Timers Low-Power **LPRC** RTCC VREG sosc POR **BOR** MCLR MCLR Monitors Regulators SRAM Main VREG CPU Peripherals Flash VREG L Idle/Sleep (SLPEN) VRĖGS Program Flash RELEASE I/O Lock Logic Memory Peripheral I/O ### FIGURE 33-1: LOW-POWER DEVICE BLOCK DIAGRAM ### 33.3 Peripheral Module Disable The Peripheral Module Disable (PMD) registers provide a method to disable a peripheral module by stopping all clock sources supplied to that module. When a peripheral is disabled using the appropriate PMD control bit, the peripheral is in a minimum power consumption state. The control and status registers associated with the peripheral are also disabled, so writes to those registers do not have effect and read values are invalid. To disable a peripheral, the associated PMDx bit must be set to '1'. To enable a peripheral, the associated PMDx bit must be cleared (default). See Table 33-1 for more information. Note: Disabling a peripheral module while it's ON bit is set, may result in undefined behavior. The ON bit for the associated peripheral module must be cleared prior to disable a module via the PMDx bits. ### TABLE 33-1: PERIPHERAL MODULE DISABLE REGISTER SUMMARY | ess | | | | | | | | | | Bit | s | | | | | | | | £ | |-----------------------------|-----------------------|-----------|--------|--------|--------|--------|---------|---------|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|------------| | Virtual Address<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0040 | PMD1 <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | _ | | - | _ | _ | _ | - | _ | - | _ | | _ | 0000 | | 00.0 | | 15:0 | _ | _ | _ | _ | _ | _ | EEMD | CTMUMD | _ | DAC3MD | DAC2MD | DAC1MD | _ | _ | _ | ADCMD | 0000 | | 0050 | PMD2 <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | OPA5MD | _ | OPA3MD | OPA2MD | OPA1MD | 0000 | | 0050 | PIVIDZ., | 15:0 | _ | _ | _ | | _ | _ | | - | - | _ | | CMP5MD | C4MPMD | C3MPMD | CMP2MD | CMP1MD | 0000 | | 0060 | PMD3 <sup>(2)</sup> | 31:16 | OC16MD | OC15MD | OC14MD | OC13MD | OC12MD | OC11MD | OC10MD | OC9MD | OC8MD | OC7MD | OC6MD | OC5MD | OC4MD | OC3MD | OC2MD | OC1MD | 0000 | | 0000 | FINID3. | 15:0 | IC16MD | IC15MD | IC14MD | IC13MD | IC12MD | IC11MD | IC10MD | IC9MD | IC8MD | IC7MD | IC6MD | IC5MD | IC4MD | IC3MD | IC2MD | IC1MD | 0000 | | 0070 | PMD4 <sup>(2)</sup> | 31:16 | _ | _ | _ | | PWM12MD | PWM11MD | PWM10MD | PWM9MD | PWM8MD | PWM7MD | PWM6MD | PWM5MD | PWM4MD | PWM3MD | PWM2MD | PWM1MD | 0000 | | 0070 | FIVID4. | 15:0 | _ | _ | - | _ | - | - | | T9MD | T8MD | T7MD | T6MD | T5MD | T4MD | T3MD | T2MD | T1MD | 0000 | | 0000 | PMD5 <sup>(1,2)</sup> | 31:16 | CAN4MD | CAN3MD | CAN2MD | CAN1MD | _ | _ | USB2MD | USB1MD | _ | _ | _ | | I2C4MD | I2C3MD | I2C2MD | I2C1MD | 0000 | | 0800 | PINID5(**-/ | 15:0 | _ | _ | SPI6MD | SPI5MD | SPI4MD | SPI3MD | SPI2MD | SPI1MD | _ | _ | U6MD | U5MD | U4MD | U3MD | U2MD | U1MD | 0000 | | 0000 | PMD6 <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | QEI4MD | QEI3MD | QEI2MD | QEI1MD | _ | _ | _ | _ | QEI6MD | QEI5MD | _ | PMPMD | 0000 | | 0090 | PIVIDO - | 15:0 | _ | _ | _ | _ | REFO4MD | REFO3MD | REFO2MD | REFO1MD | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 0040 | PMD7 <sup>(2)</sup> | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | 00A0 | PIVID/\- | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | DMAMD | _ | _ | _ | _ | 0000 | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: Reset values are dependent on the device variant. 2: For any associated PMDx bit, '0' = clocks enabled to the peripheral; '1' = For associated peripheral, clocks are disabled, SFRs are reset, and CPU read/writes are invalid. TABLE 33-2: PERIPHERAL MODULE DISABLE BITS AND LOCATIONS | Peripheral | PMDx Bit Name <sup>(3)</sup> | Register Name and Bit Location | |------------------|------------------------------|--------------------------------| | ADC1-ADC7 | ADC1MD | PMD1<0> | | CDAC1 | DAC1MD | PMD1<4> | | CDAC2 | DAC2MD | PMD1<5> | | CDAC3 | DAC3MD | PMD1<6> | | CTMU | CTMU1MD | PMD1<8> | | Data EEPROM | EEMD | PMD1<9> | | Comparator 1 | C1MD | PMD2<0> | | Comparator 2 | C2MD | PMD2<1> | | Comparator 3 | C3MD | PMD2<2> | | Comparator 4 | C4MD | PMD2<3> | | Comparator 5 | C5MD | PMD2<4> | | Op amp 1 | OPA1MD | PMD2<16> | | Op amp 2 | OPA2MD | PMD2<17> | | Op amp 3 | OPA3MD | PMD2<18> | | Op amp 5 | OPA5MD | PMD2<20> | | Input Capture 1 | IC1MD | PMD3<0> | | Input Capture 2 | IC2MD | PMD3<1> | | Input Capture 3 | IC3MD | PMD3<2> | | Input Capture 4 | IC4MD | PMD3<3> | | Input Capture 5 | IC5MD | PMD3<4> | | Input Capture 6 | IC6MD | PMD3<5> | | Input Capture 7 | IC7MD | PMD3<6> | | Input Capture 8 | IC8MD | PMD3<7> | | Input Capture 9 | IC9MD | PMD3<8> | | Input Capture 10 | IC10MD | PMD3<9> | | Input Capture 11 | IC11MD | PMD3<10> | | Input Capture 12 | IC12MD | PMD3<11> | | Input Capture 13 | IC13MD | PMD3<12> | | Input Capture 14 | IC14MD | PMD3<13> | | Input Capture 15 | IC15MD | PMD3<14> | | Input Capture 16 | IC16MD | PMD3<15> | | Output Compare 1 | OC1MD | PMD3<16> | | Output Compare 2 | OC2MD | PMD3<17> | | Output Compare 3 | OC3MD | PMD3<18> | | Output Compare 4 | OC4MD | PMD3<19> | | Output Compare 5 | OC5MD | PMD3<20> | | Output Compare 6 | OC6MD | PMD3<21> | | Output Compare 7 | OC7MD | PMD3<22> | Note 1: The USB module must not be busy after clearing the associated ON bit and prior to setting the USBMD bit. <sup>2:</sup> This peripheral is not available on all devices. Refer to the pin feature tables (Table 2 through Table 4) to determine availability. **<sup>3:</sup>** For any associated PMDx bit, 0 = clocks enabled to the peripheral; 1 = For associated peripheral, clocks are disabled, SFRs are reset, and CPU read/write is invalid. If the associated peripheral PMD bit was previously = 1, subsequently clearing the bit will require the user to re-initialize the peripheral. The only exceptions to this are the DATA EEPROM and DMA modules. TABLE 33-2: PERIPHERAL MODULE DISABLE BITS AND LOCATIONS (CONTINUED) | Peripheral | PMDx Bit Name <sup>(3)</sup> | Register Name and Bit Location | |-------------------|------------------------------|--------------------------------| | Output Compare 8 | OC8MD | PMD3<23> | | Output Compare 9 | OC9MD | PMD3<24> | | Output Compare 10 | OC10MD | PMD3<25> | | Output Compare 11 | OC11MD | PMD3<26> | | Output Compare 12 | OC12MD | PMD3<27> | | Output Compare 13 | OC13MD | PMD3<28> | | Output Compare 14 | OC14MD | PMD3<29> | | Output Compare 15 | OC15MD | PMD3<30> | | Output Compare 16 | OC16MD | PMD3<31> | | Timer1 | T1MD | PMD4<0> | | Timer2 | T2MD | PMD4<1> | | Timer3 | T3MD | PMD4<2> | | Timer4 | T4MD | PMD4<3> | | Timer5 | T5MD | PMD4<4> | | Timer6 | T6MD | PMD4<5> | | Timer7 | T7MD | PMD4<6> | | Timer8 | T8MD | PMD4<7> | | Timer9 | T9MD | PMD4<8> | | PWM1 | PWM1MD | PMD4<16> | | PWM2 | PWM2MD | PMD4<17> | | PWM3 | PWM3MD | PMD4<18> | | PWM4 | PWM4MD | PMD4<19> | | PWM5 | PWM5MD | PMD4<20> | | PWM6 | PWM6MD | PMD4<21> | | PWM7 | PWM7MD | PMD4<22> | | PWM8 | PWM8MD | PMD4<23> | | PWM9 | PWM9MD | PMD4<24> | | PWM10 | PWM10MD | PMD4<25> | | PWM11 | PWM11MD | PMD4<26> | | PWM12 | PWM12MD | PMD4<27> | | Uart1 | U1MD | PMD5<0> | | Uart2 | U2MD | PMD5<1> | | Uart3 | U3MD | PMD5<2> | | Uart4 | U4MD | PMD5<3> | | Uart5 | U5MD | PMD5<4> | | Uart6 | U6MD | PMD5<5> | | SPI1 | SPI1MD | PMD5<8> | | SPI2 | SPI2MD | PMD5<9> | Note 1: The USB module must not be busy after clearing the associated ON bit and prior to setting the USBMD bit. <sup>2:</sup> This peripheral is not available on all devices. Refer to the pin feature tables (Table 2 through Table 4) to determine availability. **<sup>3:</sup>** For any associated PMDx bit, 0 = clocks enabled to the peripheral; 1 = For associated peripheral, clocks are disabled, SFRs are reset, and CPU read/write is invalid. If the associated peripheral PMD bit was previously = 1, subsequently clearing the bit will require the user to re-initialize the peripheral. The only exceptions to this are the DATA EEPROM and DMA modules. TABLE 33-2: PERIPHERAL MODULE DISABLE BITS AND LOCATIONS (CONTINUED) | Peripheral | PMDx Bit Name <sup>(3)</sup> | Register Name and Bit Location | |----------------------|------------------------------|--------------------------------| | SPI3 | SPI3MD | PMD5<10> | | SPI4 | SPI4MD | PMD5<11> | | SPI5 | SPI5MD | PMD5<12> | | SPI6 | SPI6MD | PMD5<13> | | I2C1 | I2C1MD | PMD<16> | | I2C2 | I2C2MD | PMD<17> | | I2C3 | I2C3MD | PMD<18> | | I2C4 | I2C4MD | PMD<19> | | USB1 | USB1MD | PMD5<24> | | USB2 | USB2MD | PMD5<25> | | CAN1 | CAN1MD | PMD5<28> | | CAN2 | CAN2MD | PMD5<29> | | CAN3 | CAN3MD | PMD5<30> | | CAN4 | CAN4MD | PMD5<31> | | Reference Clock 1 | REFO1MD | PMD6<8> | | Reference Clock 2 | REFO2MD | PMD6<9> | | Reference Clock 3 | REFO3MD | PMD6<10> | | Reference Clock 4 | REFO4MD | PMD6<11> | | Parallel Master Port | PMP1MD | PMD6<16> | | QEI5 | QEI5MD | PMD6<18> | | QEI6 | QEI6MD | PMD6<19> | | QEI1 | QEI1MD | PMD6<24> | | QEI2 | QEI2MD | PMD6<25> | | QEI3 | QEI3MD | PMD6<26> | | QEI4 | QEI4MD | PMD6<27> | | DMA | DMAMD | PMD7<4> | **Note 1:** The USB module must not be busy after clearing the associated ON bit and prior to setting the USBMD bit. <sup>2:</sup> This peripheral is not available on all devices. Refer to the pin feature tables (Table 2 through Table 4) to determine availability. **<sup>3:</sup>** For any associated PMDx bit, 0 = clocks enabled to the peripheral; 1 = For associated peripheral, clocks are disabled, SFRs are reset, and CPU read/write is invalid. If the associated peripheral PMD bit was previously = 1, subsequently clearing the bit will require the user to re-initialize the peripheral. The only exceptions to this are the DATA EEPROM and DMA modules. ## 33.3.1 CONTROLLING CONFIGURATION CHANGES Because peripherals can be disabled during run time, some restrictions on disabling peripherals are needed to prevent accidental configuration changes. PIC32MK GPK/MCM with CAN FD Family of devices include two features to prevent alterations to enabled or disabled peripherals: - · Control Register Lock Sequence - · Configuration Bit Select Lock ### 33.3.1.1 Control Register Lock Under normal operation, writes to the PMDx registers are not allowed. Attempted writes appear to execute normally, but the contents of the registers remain unchanged. To change these registers, they must be unlocked in hardware. The register lock is controlled by the PMDLOCK Configuration bit (CFGCON<12>). Setting the PMDLOCK bit prevents writes to the control registers and clearing the PMDLOCK bit allows writes. To set or clear the PMDLOCK bit, an unlock sequence must be executed. Refer to **Section 42. "Oscillators with Enhanced PLL"** (DS60001250) in the "PIC32 Family Reference Manual" for details. ### 33.3.1.2 Configuration Bit Select Lock As an additional level of safety, the device can be configured to prevent more than one write session to the PMDx registers. The PMDL1WAY Configuration bit (DEVCFG3<28>) blocks the PMDLOCK bit from being cleared after it has been set once. If the PMDLOCK bit remains set, the register unlock procedure does not execute, and the PPS control registers cannot be written to. The only way to clear the bit and re-enable PMD functionality is to perform a device Reset. ### 34.0 SPECIAL FEATURES Note: This data sheet summarizes the features of the PIC32MK GPK/MCM with CAN FD Family of devices. However, it is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 32. "Configuration" (DS60001124) and Section "Programming and Diagnostics" (DS60001129), which are available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). PIC32MK GPK/MCM with CAN FD Family of devices include several features intended to maximize application flexibility and reliability and minimize cost through elimination of external components. These are: - · Flexible device configuration - · Joint Test Action Group (JTAG) interface - In-Circuit Serial Programming™ (ICSP™) - · Internal temperature sensor ### 34.1 Configuration Bits PIC32MK GPK/MCM with CAN FD Family of devices contain two Boot Flash memories (Boot Flash 1 and Boot Flash 2), each with an associated configuration space. These configuration spaces can be programmed to contain various device configurations. Configuration space that is aliased by the Lower Boot Alias memory region is used to provide values for Configuration registers listed below. See 4.1.1 "Boot Flash Sequence and Configuration Spaces" for more information. - DEVSIGN0: Device Signature Word 0 Register - DEVCP0: Device Code-Protect 0 Register - DEVCFG0/ADEVCFG0: Device/Alternate Device Configuration Word 0 - DEVCFG1/ADEVCFG1: Device/Alternate Device Configuration Word 1 - DEVCFG2/ADEVCFG2: Device/Alternate Device Configuration Word 2 - DEVCFG3/ADEVCFG3: Device/Alternate Device Configuration Word 3 - DEVCFG4/ADEVCFG4: Device/Alternate Device Configuration Word 4 The following run-time programmable Configuration registers provide additional configuration control: - · CFGCON: Configuration Control Register - CFGPG: Permission Group Configuration Register - CFGCON2: EE Data Configuration Register In addition, the DEVID register (Register 34-11) provides device and revision information, the DEVADC1 through DEVADC5 registers (Register 34-12) provide ADC module calibration data, and the DEVSN0 and DEVSN3 registers contain a unique serial number of the device (Register 34-13). Note: Do not use Word program operation (NVMOP<3:0> = 0001) when programming the device Words that are described in this section. #### 34.2 Registers #### TABLE 34-1: DEVCFG: DEVICE CONFIGURATION WORD SUMMARY | s | | | | | | | | | | Bits | | | | | | | | | | |-----------------------------|------------------|-----------|-----------|-----------|------------|-----------|------------|-----------|-----------|-----------|----------|-----------|--------------|------------|-----------|----------|------------|--------|------------| | Virtual Address<br>(BFC0_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 3FBC | DEVCFG4 | 31:16 | A5DIFFPR1 | A5DIFFPR0 | A3DIFFPR1 | A3DIFFPR0 | A2DIFFPR1 | A2DIFFPR0 | A1DIFFPR1 | A1DIFFPR0 | _ | _ | _ | _ | _ | - | _ | _ | xxxx | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 3FC0 | DEVCFG3 | 31:16 | FVBUSIO1 | FUSBIDIO1 | IOL1WAY | PMDL1WAY | PGL1WAY | _ | _ | _ | FVBUSIO2 | FUSBIDIO2 | _ | PWMLOCK | _ | _ | _ | _ | xxxx | | | | 15:0 | | | | | | | | USERID< | 15:0> | | | | | _ | | | xxxx | | 3FC4 | DEVCFG2 | 31:16 | UPLLEN | _ | BORSEL | FDSEN | _ | _ | _ | _ | _ | _ | _ | _ | _ | FF | PLLODIV<2 | :0> | xxxx | | | | 15:0 | _ | | | | FPLLMULT<6 | 5:0> | | | FPLLICLK | | FPLLRNG<2:0> | | _ | F | PLLIDIV<2: | 0> | xxxx | | 3FC8 | DEVCFG1 | 31:16 | FDMTEN | | | DMTCNT<4 | :0> | | FWDTWI | NSZ<1:0> | FWDTEN | WINDIS | WDTSPGM | | WDT | PSR<4:0> | | | xxxx | | | | 15:0 | FCKSN | Л<1:0> | _ | _ | _ | OSCIOFNC | POSCM | OD<1:0> | IES0 | LPOSCEN | D | MTINTV<2:0 | > | F | NOSC<2:0 | )> | xxxx | | 3FCC | DEVCFG0 | 31:16 | _ | EJTAGBEN | _ | _ | POSCAGC | | POSCAGO | CDLY<1:0> | POSCFO | SAIN<1:0> | POSCBOOST | POSCO | SAIN<1:0> | sc | SCGAIN<2 | 2:0> | xxxx | | | | 15:0 | SMCLR | | DBGPER<2:0 | > | _ | FSLEEP | FECCC | ON<1:0> | _ | BOOTISA | TRCEN | ICESI | EL<1:0> | JTAGEN | DEBU | G<1:0> | xxxx | | 3FD0 | DEVCP3 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | | | 15:0 | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 3FD4 | DEVCP2 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | xxxx | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | xxxx | | 3FD8 | DEVCP1 | 31:16 | _ | | _ | _ | _ | | _ | _ | _ | _ | _ | _ | _ | _ | | | xxxx | | | | 15:0 | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 3FDC | DEVCP0 | 31:16 | _ | _ | _ | CP | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | xxxx | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | 3FF0 | DEVSEQ 3 | 31:16 | | | | | | | | CSEQ<1 | 5:0> | | | | | | | | xxxx | | | | 15:0 | | | | | | | | TSEQ<1 | 5:0> | | | | | | | 1 | xxxx | | 3FF4 | DEVSEQ 2 | 31:16 | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | | | | 15:0 | | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | | | xxxx | | 3FF8 | DEVSEQ 1 | 31:16 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | xxxx | | | | 15:0 | | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | | | xxxx | | 3FFC | DEVSEQ0 | 31:16 | | _ | _ | _ | _ | | _ | _ | _ | | _ | _ | _ | _ | | | xxxx | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset; See register description detail for more information. Reset values are shown in hexadecimal. | TABLE 31-2. | ADEVCEG: ALTERNATE DEVICE CONFIGURATION WORD SUMMARY | |-------------|----------------------------------------------------------| | IADLE 34-2. | ADEVICED. ALI ERNATE DEVICE CONFIGURATION WORD SUIVINART | | SPSC ADEVCEGN 31:16 ASDIFFPRI ASDIFFPRI ASDIFFPRO AZDIFFPRO AZ | ess | | o | | | | | | | | Bit | s | | | | | | | | ø | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------|--------------------------------------------------|-----------|-------------------|-----------|-----------|-----------|-----------|-----------|-----------|----------|-----------|-------|---------|---------|--------|-----------|--------|------------| | 150 | Virtual Addr | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | SF40 ADEVCEGS 31-16 FVBUSIO1 FUBIDIO1 IOLIWAY PMDLIWAY PGLIWAY PGLI | 3F3C | ADEVCFG4 | 31:16 | A5DIFFPR1 | A5DIFFPR0 | A3DIFFPR1 | A3DIFFPR0 | A2DIFFPR1 | A2DIFFPR0 | A1DIFFPR1 | A1DIFFPR0 | _ | _ | _ | _ | _ | _ | _ | - | xxxx | | 15.0 | | | | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | xxxx | | 3F44 ADEVCFG 2 31:16 UPLLEN | 3F40 | ADEVCFG3 | 31:16 | FVBUSIO1 | FUSBIDIO1 | IOL1WAY | PMDL1WAY | PGL1WAY | _ | _ | _ | FVBUSIO2 | FUSBIDIO2 | _ | PWMLOCK | _ | _ | _ | _ | xxxx | | 15.0 | | | 1 | | URLEN PARKET FROM | | | | | | | xxxx | | | | | | | | | | SF46 ADEVCFG 31:16 FDMTEN DMTCNT<-4:0> FWDTWINSZ<-1:0> FWDTWINSZ<-1:0> FWDTEN WINDIS WDTSPGM WDTSPGM WDTPSR<-4:0> SXXXX | 3F44 | ADEVCFG2 | 31:16 | UPLLEN | | | | | | _ | _ | _ | _ | _ | _ | _ | F | PLLODIV<2 | :0> | xxxx | | 15:0 FCKSM<1:0> | | | | | | | | | | 1 | | | | | 1 | | | | 0> | xxxx | | Section Sect | 3F48 | ADEVCFG1 | - | | | | DMTCNT<4 | :0> | | | | | | | | | | | | xxxx | | 15:0 SMCLR DBGPER<20> | | | | FCKS | | _ | _ | | OSCIOFNC | | | | | | | | | | | xxxx | | 3F50 ADEVCP3 31:16 — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | 3F4C | ADEVCFG0 | - | | | | | | | | | POSCFG | | | | | _ | | | XXXX | | 15:0 | | | | SMCLR | D | BGPER<2:0 | > | _ | FSLEEP | FECCC | ON<1:0> | | BOOTISA | TRCEN | ICESI | EL<1:0> | JTAGEN | DEBUG | G<1:0> | XXXX | | 3F54 ADEVCP2 31:16 — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | 3F50 | ADEVCP3 | | | _ | | _ | | _ | _ | | | | _ | | _ | | | | | | 15.0 | | | | | | | | | | | | | | | | | | | | + - | | 3F58 ADEVCP1 31:16 — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | 3F54 | ADEVCP2 | | | | | | | | | _ | | _ | | _ | | _ | | | | | 15:0 | 0550 | ADEL/OD4 | <del> </del> | | | | | | | | | | | | | | | | | + - | | 3F5C ADEVCP0 31:16 — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | 31-58 | ADEVCPT | | | | | | | | | | | _ | | | | | | | | | 15:0 | 2550 | ADEVCD0 | 1 | | | | | | | | _ | | _ | | | | | | | + - | | SF70 ADEVSEQ 3 31:16 | 3530 | ADEVCEO | | | | | | | | | | | | | | | | | | _ | | 15:0 TSEQ<15:0> XXX XX | 3570 | ADEVISEO 3 | | | _ | | _ | _ | _ | _ | CSEO | | _ | _ | _ | _ | _ | | | - | | 3F74 ADEVSEQ 2 31:16 — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | 31 70 | ADEVOLQ 3 | - | | | | | | | | | | | 1 | | | | | | | | 15:0 — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | 3F74 | ADEVSEO 2 | | | _ | _ | _ | _ | _ | _ | | | _ | _ | _ | _ | _ | _ | _ | 1 | | 3F78 ADEVSEQ 1 31:16 — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — <td>01 74</td> <td>/IDEVOLG 2</td> <td>-</td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td>_</td> <td>_</td> <td></td> <td>_</td> <td></td> <td></td> <td></td> <td>_</td> <td></td> <td></td> <td></td> | 01 74 | /IDEVOLG 2 | - | | | | | | | _ | _ | | _ | | | | _ | | | | | 15:0 — — — — — — — — — — — — — — — — — — — | 3F78 | ADEVSEO 1 | | | | | | | | | | | | | | | _ | | | + - | | 3F7C ADEVSEQU 31:16 — — — — — — — — — — — — — — — — — — — | | | - | | _ | _ | _ | _ | | _ | _ | _ | _ | | _ | _ | _ | _ | _ | 1 - | | | 3F7C | ADEVSEQ0 | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | xxxx | Legend: x = unknown value on Reset; See register description detail for more information. Reset values are shown in hexadecimal. #### TABLE 34-3: DEVICE ID, REVISION, AND CONFIGURATION SUMMARY | | | | | , | | <i>,</i> | | | | | | | | | | | | | | |----------------------------|------------------|-----------|------------------------------------------------------------------------|--------|-------|----------|-------|---------|-------|--------|--------------|----------|----------|----------|----------|----------|--------|--------|------------| | ess | | ۰ | | | | | | | | | Bits | | | | | | | | (3) | | Virtual Addres<br>(BF80_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 0000 | CFGCON | 31:16 | _ | | _ | _ | _ | ADCPRI | - | I | PWMAPIN6 | PWMAPIN5 | PWMAPIN4 | PWMAPIN3 | PWMAPIN2 | PWMAPIN1 | ICACLK | OCACLK | 0000 | | 0000 | CFGCON | 15:0 | IOLOCK PMDLOCK PGLOCK IOANCPEN - ECCCON<1:0> JTAGEN TROEN - TDOEN 00xx | | | | | | | | | | | | 00xx | | | | | | 0020 | DEVID | 31:16 | | VER< | :3:0> | | | | | | | DEVI | D<27:16> | | | | | | xxxx | | 0020 | DEVID | 15:0 | | | | | | | | D | EVID<15:0> | | | | | | | | xxxx | | 0030 | SYSKEY | 31:16 | | | | | | | | SV. | SKEY<31:0> | | | | | | | | 0000 | | 0030 | STORET | 15:0 | | | | | | | | 31 | OKL 1 -01.02 | | | | | | | | 0000 | | 00E0 | CFGPG | 31:16 | | | | | | | | | | | | 0000 | | | | | | | UUEU | CrGrG | 15:0 | CAN2P | G<1:0> | CAN1I | PG<1:0> | USB2F | PG<1:0> | USB1P | G<1:0> | _ | _ | DMAP | G<1:0> | CPUDSI | PG<1:0> | CPUP | G<1:0> | 0000 | | 0110 | CFGCON2 | 31:16 | | | _ | _ | _ | _ | _ | ı | _ | _ | _ | _ | _ | _ | ı | - | 0000 | | 0110 | CFGCONZ | 15:0 | _ | _ | _ | _ | _ | _ | _ | _ | | • | • | EEWS | <7:0> | • | | | 0000 | PIC32MK GPK/MCM with CAN FD Family Legend: x = unknown value on Reset; — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: This register has corresponding CLR, SET, and INV registers at its virtual address, plus an offset of 0x4, 0x8, and 0xC, respectively. See 13.2 "CLR, SET, and INV Registers" for more information. Reset values are dependent on the device variant. 3: This register is not available on 64-pin devices. | $\Box$ | |--------| | ഗ | | 0 | | 0 | | 2 | | Ų | | CD. | | Ξ. | | 9 | | Ш | | ᇂ | | ĕ | | ā | | Ø | | 652 | | 10 | | TABLE 34-4. | DEVICE | ADC CAL | <b>IRRATION</b> | SHMMARY | |-------------|--------|---------|-----------------|---------| | | | | | | | ess | | | | | | | | | | В | ts | | | | | | | | 3 | |-----------------------------|------------------------|-----------|-----------------------------------|-------|-------|-------|-------|-------|------|----------------|--------------|------|------|------|------|------|------|------|---------------------------| | Virtual Address<br>(BFC4_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets <sup>(1)</sup> | | 5000 | DEVADC0 <sup>(2)</sup> | 31:16 | | | | | | | AD | C Calibratio | n Data <31:1 | 16> | | | | | | | XXXX | | 3000 | DEVADOO | 15:0 | | | | | | | | | | | | | | | | | XXXX | | 5004 | DEVADC1 <sup>(2)</sup> | 31:16 | | | | | | | | | | | | | | | | XXXX | | | 3004 | DEVADOT | 15:0 | 1700 W . II . T | | | | | | | | | | | | | xxxx | | | | | 5000 | DEVADC2 <sup>(2)</sup> | 31:16 | | | | | | | | | | | | | | xxxx | | | | | 5006 | DEVADOZ | 15:0 | | | | | | | ΑI | OC Calibration | on Data <15: | :0> | | | | | | | xxxx | | 5000 | DEVADC3 <sup>(2)</sup> | 31:16 | | | | | | | AD | C Calibratio | n Data <31: | 16> | | | | | | | xxxx | | 300C | DEVADOS | 15:0 | | | | | | | ΑI | OC Calibration | on Data <15: | :0> | | | | | | | xxxx | | 5010 | DEVADC4 <sup>(2)</sup> | 31:16 | | | | | | | AD | C Calibratio | n Data <31:1 | 16> | | | | | | | xxxx | | 3010 | DEVADO4 | 15:0 | | | | | | | ΑI | OC Calibration | on Data <15: | :0> | | | | | | | XXXX | | E014 | DEVADC5 <sup>(2)</sup> | 31:16 | ADC Calibration Data <31:16> xxx. | | | | | | | | | | | | | xxxx | | | | | 5014 | DEVADOS | 15:0 | | | | | | | | | | | | | | | XXXX | | | | 5010 | DEVADC7 <sup>(2)</sup> | 31:16 | | | | | | | AD | C Calibratio | n Data <31:1 | 16> | | | | | | | xxxx | | 5016 | DEVADORY | 15:0 | | | | | | | A | OC Calibration | on Data <15: | :0> | | | | | | | xxxx | x = unknown value on Reset. Legend: Note 1: Reset values are dependent on the device variant. Before enabling the ADC, the user application must initialize the ADC calibration codes by copying them from the factory programmed DEVADCx Flash locations into the ADCxCFG special function registers, respec- PIC32MK GPK/MCM with CAN FD Family #### **TABLE 34-5: DEVICE EE DATA CALIBRATION SUMMARY** | ess | | ø | | | | | | | | В | its | | | | | | | | 3 | |-----------------------------|------------------|-----------|--------------------------------------|---------------------------------------|-------|-------|-------|-------|------|--------------|--------------|-------|------|------|------|------|------|------|---------------------------| | Virtual Address<br>(BFC4_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets <sup>(1)</sup> | | 5030 | DEVEE0 | 31:16 | | EE Data Calibration Data <31:16> xxxx | | | | | | | | | | | | | | XXXX | | | 5030 | DEVEE | 15:0 | | EE Data Calibration Data <15:0> xxxx | | | | | | | | | | | | | xxxx | | | | 5024 | DEVEE1 | 31:16 | | | | | | | EE C | ata Calibrat | ion Data <31 | I:16> | | | | | | | xxxx | | 5034 | DEVEET | 15:0 | | | | | | | EE I | Data Calibra | tion Data <1 | 5:0> | | | | | | | xxxx | | 5000 | DEVEE2 | 31:16 | | | | | | | EE C | ata Calibrat | ion Data <31 | I:16> | | | | | | | xxxx | | 5038 | DEVEEZ | 15:0 | EE Data Calibration Data <15:0> xxxx | | | | | | | | | | | | | xxxx | | | | | 503C | DEVEE3 | 31:16 | | | | | | | EE C | ata Calibrat | ion Data <31 | I:16> | | | | | | | xxxx | | 503C | DEVEES | 15:0 | | | | | | | | | | | | | | xxxx | | | | Legend: x = unknown value on Reset. Reset values are device dependent. This is a device by device unique permanent number programmed into the device by the factory before shipment. #### TABLE 34-6: DEVICE SERIAL NUMBER SUMMARY | ess | | 0 | | | | | | | | В | its | | | | | | | | (1) | |-----------------------------|------------------|-----------|-----------------------------------|-------|-------|-------|-------|-------|------|----------------|-------------|------|------|------|------|------|------|------|------------| | Virtual Address<br>(BFC4_#) | Register<br>Name | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1 | 16/0 | All Resets | | 5020 | DEVSN0 | 31:16 | | | | | | | | | | | | | | | | xxxx | | | 3020 | DEVSINO | 15:0 | | | | | | | | | | | | | | | | xxxx | | | 5004 | DEVSN1 | 31:16 | | | | | | | De | vice Serial N | lumber <31: | 16> | | | | | | | xxxx | | 5024 | DEVSIVI | 15:0 | | | | | | | De | evice Serial I | Number <15: | 0> | | | | | | | xxxx | | 5000 | DE) (ONO | 31:16 | | | | | | | De | vice Serial N | umber <31: | 16> | | | | | | | xxxx | | 5028 | DEVSN2 | 15:0 | | | | | | | | | | | | | | xxxx | | | | | 5000 | DEVCNO | 31:16 | Device Serial Number <31:16> xxxx | | | | | | | | | | | | | xxxx | | | | | 502C | DEVSN3 | 15:0 | | | | | | | De | evice Serial I | Number <15: | 0> | | | | | | | xxxx | PIC32MK GPK/MCM with CAN FD Family **Legend:** x = unknown value on Reset. Note 1: Reset values are dependent on the device variant. REGISTER 34-1: DEVSIGN0: DEVICE SIGNATURE WORD 0 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | r-0 | r-1 | 31:24 | _ | _ | _ | _ | _ | _ | _ | _ | | 00.46 | r-1 | 23:16 | _ | _ | _ | _ | _ | _ | _ | _ | | 45.0 | r-1 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7:0 | r-1 | 7:0 | _ | _ | _ | _ | _ | _ | _ | _ | **Legend:** r = Reserved bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31 **Reserved:** Write as '0' bit 30-0 **Reserved:** Write as '1' #### REGISTER 34-2: DEVCP0: DEVICE CODE-PROTECT 0 REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | r-1 | r-1 | r-1 | R/P | r-1 | r-1 | r-1 | r-1 | | 31.24 | _ | _ | _ | CP | _ | _ | _ | | | 23:16 | r-1 | 23:10 | _ | _ | _ | | _ | _ | _ | _ | | 45.0 | r-1 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7:0 | r-1 | 7:0 | _ | _ | _ | _ | _ | _ | _ | _ | **Legend:** r = Reserved bit P = Programmable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-29 **Reserved:** Write as '1' bit 28 CP: Code-Protect bit Prevents boot and program Flash memory from being read or modified by an external programming device. 1 = Protection is disabled0 = Protection is enabled bit 27-0 Reserved: Write as '1' ## REGISTER 34-3: DEVCFG0/ADEVCFG0: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 0 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | r-x | R/P | r-1 | r-1 | R/P | r | R/P | R/P | | 31.24 | _ | EJTAGBEN | _ | _ | POSCAGC | | POSCAGO | CDLY<1:0> | | 00:40 | R/P | 23:16 | POSCFO | GAIN<1:0> | POSCBOOST | POSCG | AIN<1:0> | SOSCBOOST | SOSCG | AIN<1:0> | | 45.0 | R/P | R/P | R/P | R/P | r-y | R/P | R/P | R/P | | 15:8 | SMCLR | | DBGPER<2:0> | | - | FSLEEP | FECCC | ON<1:0> | | 7.0 | r-1 | R/P | 7:0 | _ | BOOTISA | TRCEN | ICESE | L<1:0> | JTAGEN | DEBU | G<1:0> | Legend:r = Reserved bitP = Programmable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31 Reserved: The reset value of this bit is the same as DEVSIGN0<31>. bit 30 **EJTAGBEN:** EJTAG Boot Enable bit 1 = Normal EJTAG functionality0 = Reduced EJTAG functionality bit 29-28 Reserved: Write as '1' bit 27 **POSCAGC:** Primary Oscillator Automatic Gain Control bit 1 = Automatic gain control is enabled (default) 0 = Manual oscillator gain control When the POSCAGC bit is enabled and POSC HS mode is selected, DEVCFG1<9:8> = `0b10 (i.e., POSC-MOD), the Primary Oscillator will automatically do a linear search to find the lowest power/gain setting to guarantee oscillation with the users crystal. **Note:** If the POSCMOD<1:0> bits (DEVCFG1/ADEVCFG1<9:8>\_ = $^{\circ}0b00$ (i.e., POSCMOD = EC mode), the POSCAGC bit must be set to '0'. POSCMOD = EC mode with POSCAGC = 1 is not permitted and will result in no oscillation. bit 26 Reserved: Do not write a logic "0" to this bit. bit 25-24 POSCAGCDLY<1:0>: Primary Crystal AGC Gain Search Step Settling Time Control bits - 11 = Approximately (25 ms) (default) - 10 = Approximately (6.25 ms) - 01 = Approximately (400 ms) - 00 = Approximately (100 ms) - **Note 1:** When the POSCAGC bit (DEVCFG0<27>) = 0 (i.e., manual oscillator gain control), these bits are not used. They are only used when AGC is enabled. - 2: For POSC HS mode (DEVCFG1<9:8> = `0b10), the default setting should meet the user crystal requirements. Internally, there are a maximum of 16 and a minimum of one AGC linear gain search steps the logic may utilize before locking. A lock will occur when the crystal is oscillating and the amplitude of the crystal signal is between a max and min fixed internal threshold. The POSCAGCDLY is the time for each of the possible AGC search steps settling time to allow the crystal to startup and amplitude stabilize before determining if a lock is true or to continue to search for the required gain. The POSCAGCDLY<1:0> bits represent a balance between startup time and crystal power optimization. The lower the POSCAGCDLY delay time the faster the crystal start-up time but potentially at a higher crystal power level. The higher the POSCAGCDLY delay time the slower the crystal start-up time but with a better crystal power optimization level (i.e., less power). - **3:** Use of resonators with this product have not been confirmed -- use at your own discretion. When using a resonator, due to their long start-up times, it may be necessary to use a longer AGC gain step settling time. # REGISTER 34-3: DEVCFG0/ADEVCFG0: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 0 (CONTINUED) - bit 23-22 POSCFGAIN<1:0>: Primary Crystal Oscillator Fine Gain Control bits - 11 = Gain level 3 (highest, default) - 10 = Gain is G2 - 01 = Gain is G1 - 00 = Gain is G0 (Lowest) Note 1: G3 > G2 > G1 > G0. - 2: When the POSCAGC bit (DEVCFG0<27>) = 1 (i.e., automatic gain control), or the POSCMOD<1:0> bits (DEVCFG1/ADEVCFG1<9:8>) ≠ '0b10 (i.e., HS crystal mode), the POSC-GAIN<1:0> bits are not used. - 3: These bits are used in conjunction with DEVCFG0/ADEVCFG0<20:19>. In almost all cases, the crystal fine gain default setting of '0b11 will work with the users course gain setting selection. - bit 21 POSCBOOST: Primary Oscillator Boost bit - 1 = Uses internal XTAL feedback gain resistor (Default, in which case the user application should not use any external XTAL feedback resistor in the crystal circuit) - 0 = Disconnects the internal XTAL feedback resistor - bit 20-19 POSCGAIN<1:0>: Primary Crystal Oscillator Coarse Gain Control bits - 11 = Gain Level 3 (highest, default) - 10 = Gain Level 2 - 01 = Gain Level 1 - 00 = Gain Level 0 (lowest) Note 1: G3 > G2 > G1 > G0. - 2: When the POSCAGC bit (DEVCFG0<27>) = 1 (i.e., automatic gain control), or the POSCMOD<1:0> bits (DEVCFG1/ADEVCFG1<9:8>) ≠ '0b10 (i.e., HS crystal mode), the POSC-GAIN<1:0> bits are not used. - bit 18 SOSCBOOST: Secondary Oscillator Kick Start Programmability bit - 1 = Start up and operate with high-power SOSC internal buffer only. - 0 = Start up with internal SOSC high-power buffer, and then switch to low-power buffer when the SOSC is stable. - bit 17-16 SOSCGAIN<1:0>: Secondary Oscillator Gain Control bits #### If SOSCGAIN < 2 > = 0: - 11 = Gain is G3 (default) - 10 = Gain is G2 - 01 = Gain is G1 - 00 = Gain is G0 **Note:** G3 > G2 > G1 > G0. - bit 15 SMCLR: Soft Master Clear Enable bit - 1 = MCLR pin generates a normal system Reset - 0 = MCLR pin generates a POR Reset - bit 14-12 DBGPER<2:0>: Debug Mode CPU Access Permission bits - 1xx = Allow CPU access to Permission Group 2 permission regions - x1x = Allow CPU access to Permission Group 1 permission regions xx1 = Allow CPU access to Permission Group 0 permission regions - 0xx = Deny CPU access to Permission Group 2 permission regions - x0x = Deny CPU access to Permission Group 1 permission regions - xx0 = Deny CPU access to Permission Group 0 permission regions **Note:** When the CPU is in Debug mode and the CPU1PG<1:0> bits (CFGPG<1:0>) are set to a denied permission group as defined by DBGPER<2:0>, the transaction request is assigned Group 3 permissions bit 11 **Reserved:** This bit is controlled by debugger/emulator development tools and should not be modified by the user. # REGISTER 34-3: DEVCFG0/ADEVCFG0: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 0 (CONTINUED) - bit 10 FSLEEP: Flash Sleep Mode bit - 1 = Flash is powered down when the device is in Sleep mode - 0 = Flash power down is controlled by the VREGS bit (PWRCON<0>) - bit 9-8 **FECCON<1:0>:** Dynamic Flash ECC Configuration bits - 11 = ECC and dynamic ECC are disabled (ECCCON<1:0> bits are writable) - 10 = ECC and dynamic ECC are disabled (ECCCON<1:0> bits are locked) - 01 = Dynamic Flash ECC is enabled (ECCCON<1:0> bits are locked) - 00 = Flash ECC is enabled (ECCCON<1:0> bits are locked; disables word Flash writes) **Note:** Upon a device POR, the value of these bits are copied by hardware into CFGCON<5:4> bits, (i.e. ECCCON<1:0>. - bit 7 **Reserved:** Write as '1' - bit 6 BOOTISA: Boot ISA Selection bit - 1 = Boot code and Exception code is MIPS32 (ISAONEXC bit is set to '0' and the ISA<1:0> bits are set to '10' in the CP0 Config3 register) - 0 = Boot code and Exception code is microMIPS (ISAONEXC bit is set to '1' and the ISA<1:0> bits are set to '11' in the CP0 Config3 register) - bit 5 TRCEN: Trace Enable bit - 1 = Trace features in the CPU are enabled - 0 = Trace features in the CPU are disabled - bit 4-3 ICESEL<1:0>: In-Circuit Emulator/Debugger Communication Channel Select bits - 11 = PGEC1/PGED1 pair is used - 10 = PGEC2/PGED2 pair is used - 01 = PGEC3/PGED3 pair is used - 00 = Reserved - bit 2 JTAGEN: JTAG Enable bit - 1 = JTAG is enabled - 0 = JTAG is disabled - Note 1: On Reset, this Configuration bit is copied into JTAGEN (CFGCON<3>). If JTAGEN (DEVCFG0<2>) = 0, the JTAGEN bit cannot be set to '1' by the user application at run-time, as JTAG is always disabled. However, if JTAGEN (DEVCFG0<2>) = 1, the user application may enable/disable JTAG at run-time by simply writing JTAGEN (CFGCON<3> as required. - 2: This bit sets the value of the JTAGEN bit in the CFGCON register. - bit 1-0 **DEBUG<1:0>:** Background Debugger Enable bits (forced to '11' if code-protect is enabled) - 11 = 4-wire JTAG Enabled PGECx/PGEDx Disabled ICD module Disabled - 10 = 4-wire JTAG Enabled PGECx/PGEDx Disabled ICD module Enabled - 01 = PGECx/PGEDx Enabled 4-wire JTAG I/F Disabled ICD module Disabled - 00 = PGECx/PGEDx Enabled 4-wire JTAG I/F Disabled ICD module Enabled **Note:** When the FJTAGEN or JTAGEN bits are equal to '0', this prevents 4-wire JTAG debugging, but not PGECx/PGEDx debugging. # REGISTER 34-4: DEVCFG1/ADEVCFG1: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 1 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|------------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.04 | R/P | 31:24 | FDMTEN | DMTCNT<4:0> | | | | | FWDTWI | NSZ<1:0> | | 00:40 | R/P | 23:16 | FWDTEN | WINDIS | WDTSPGM | WDTPS<4:0> | | | | | | 45.0 | R/P | R/P | r-1 | r-1 | r-1 | R/P | R/P | R/P | | 15:8 | FCKSI | M<1:0> | _ | _ | _ | OSCIOFNC | POSCM | OD<1:0> | | 7.0 | R/P | 7:0 | IESO | FSOSCEN <sup>(1)</sup> | | OMTINV<2:0> | • | F | NOSC<2:0> | • | Legend:r = Reserved bitP = Programmable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31 FDMTEN: Deadman Timer enable bit 1 = Deadman Timer is enabled and *cannot* be disabled by software 0 = Deadman Timer is disabled and can be enabled by software bit 30-26 DMTCNT<4:0>: Deadman Timer Count Select bits 11111 **=** Reserved • 11000 **= Reserved** $10111 = 2^{31} (2147483648)$ $10111 = 2^{30} (1073741824)$ $10101 = 2^{29} (536870912)$ $10100 = 2^{28} (268435456)$ • $00001 = 2^9 (512)$ $00001 = 2^{8} (512)$ $00000 = 2^{8} (256)$ bit 25-24 FWDTWINSZ<1:0>: Watchdog Timer Window Size bits 11 = Window size is 25% 10 = Window size is 37.5% 01 = Window size is 50% 00 = Window size is 75% bit 23 FWDTEN: Watchdog Timer Enable bit 1 = Watchdog Timer is enabled and cannot be disabled by software 0 = Watchdog Timer is not enabled; it can be enabled in software bit 22 WINDIS: Watchdog Timer Window Enable bit 1 = Watchdog Timer is in non-Window mode 0 = Watchdog Timer is in Window mode bit 21 WDTSPGM: Watchdog Timer Stop During Flash Programming bit 1 = Watchdog Timer stops during Flash programming 0 = Watchdog Timer runs during Flash programming (for read/execute while programming Flash applications) **Note:** If using external clock oscillator for SOSC instead of crystal, FSOSEN bit must be "0" with clock oscillator input connected to SOSCO, SOSC output pin not the SOSCI input pin. This will free up SOSCI pin for use as an extra I/O pin. # REGISTER 34-4: DEVCFG1/ADEVCFG1: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 1 (CONTINUED) bit 20-16 WDTPS<4:0>: Watchdog Timer Postscale Select bits ``` 10100 = 1:1048576 10011 = 1:524288 10010 = 1:262144 10001 = 1:131072 10000 = 1:65536 01111 = 1:32768 01110 = 1:16384 01101 = 1:8192 01100 = 1:4096 01011 = 1:2048 01010 = 1:1024 01001 = 1:512 01000 = 1:256 00111 = 1:128 00110 = 1:64 00101 = 1:32 00100 = 1:16 00011 = 1:8 00010 = 1:4 00001 = 1:2 00000 = 1:1 ``` All other combinations not shown result in operation = 10100 - bit 15-14 FCKSM<1:0>: Clock Switching and Monitoring Selection Configuration bits - 11 = Software run-time clock switching is enabled and clock monitoring is enabled - 10 = Software run-time clock switching is disabled and clock monitoring is enabled - 01 = Software run-time clock switching is enabled and clock monitoring is disabled - 00 = Software run-time clock switching is disabled and clock monitoring is disabled - bit 13-11 Reserved: Write as '1' - bit 10 OSCIOFNC: CLKO Enable Configuration bit - 1 = CLKO output is disabled - 0 = CLKO output signal is active on the OSC2 pin; Primary Oscillator must be disabled or configured for the External Clock mode (EC) for the CLKO to be active (POSCMOD<1:0> = 11 or 00) - bit 9-8 **POSCMOD<1:0>:** Primary Oscillator Configuration Mode bits - 11 = Posc is disabled - 10 = HS Oscillator mode is selected - 01 = Reserved - 00 = EC mode is selected. This mode must not be selected if the POSCAGC bit (DEVCFG0/ADEVCFG0<27>) = 1. - bit 7 **IESO:** Internal External Switchover bit - 1 = Internal to External HDW Clock Switchover mode is enabled (Two-Speed Start-up is enabled) - 0 = Internal to External HDW Clock Switchover mode is disabled (Two-Speed Start-up is disabled) When IES0 is set, CPU hardware will start up executing code on FRC and automatically switch to the clock source defined by FNOSC when that oscillator source is ready and stable, regardless of whether or not FCKSM clock switching is enabled. - bit 6 FSOSCEN: Secondary Oscillator Enable bit - 1 = Enable Sosc - 0 = Disable Sosc **Note:** If using external clock oscillator for SOSC instead of crystal, FSOSEN bit must be "0" with clock oscillator input connected to SOSCO, SOSC output pin not the SOSCI input pin. This will free up SOSCI pin for use as an extra I/O pin. # REGISTER 34-4: DEVCFG1/ADEVCFG1: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 1 (CONTINUED) - bit 5-3 **DMTINV<2:0>:** Deadman Timer Count Window Interval bits - 111 = Window/Interval value is 127/128 counter value - 110 = Window/Interval value is 63/64 counter value - 101 = Window/Interval value is 31/32 counter value - 100 = Window/Interval value is 15/16 counter value - 011 = Window/Interval value is 7/8 counter value - 010 = Window/Interval value is 3/4 counter value - 001 = Window/Interval value is 1/2 counter value - 000 = Window/Interval value is zero - bit 2-0 FNOSC<2:0>: Oscillator Selection bits - 111 = Reserved - 110 = Backup Fast RC (BFRC) Oscillator - 101 = Low-Power RC Oscillator (LPRC) - 100 = Secondary Oscillator (Sosc) - 011 = USB PLL (UPLL Module) (input clock and divider set by UPLLCON) - 010 = Primary Oscillator (Posc) (HS, EC) - 001 = System PLL (SPLL Module) (input clock and divider set by SPLLCON) - 000 = Fast RC Oscillator (FRC) divided by the FRCDIV<2:0> bits (OSCCON<26:24>) (supports FRC / n, where n = 1, 2, 4, 8, 16, 32, 64, 256 # REGISTER 34-5: DEVCFG2/ADEVCFG2: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 2 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.04 | R/P | r-1 | R/P | R/P-0 | R/P-0 | R/P-0 | R/P-0 | R/P-0 | | | | 31:24 | UPLLEN | _ | BORSEL | _ | _ | _ | _ | _ | | | | 00.40 | R/P-0 | R/P-0 | R/P-0 | R/P-0 | r-1 | R/P | R/P | R/P | | | | 23:16 | _ | - | _ | _ | _ | FPLLODIV<2:0> | | | | | | 45.0 | r-1 | R/P | | | 15:8 | _ | FPLLMULT<6:0> | | | | | | | | | | 7.0 | R/P | R/P | R/P | R/P | r-1 | R/P | R/P | R/P | | | | 7:0 | FPLLICLK | F | PLLRNG<2:0 | > | _ | FPLLIDIV<2:0> | | | | | Legend:r = Reserved bitP = Programmable bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown ``` bit 31 UPLLEN: USB PLL Enable bit ``` 1 = USB PLL is disabled 0 = USB PLL is enabled bit 30 Reserved: Write as '1' bit 29 BORSEL: Brown-out Reset Select Trip Voltage bit 1 = BOR trip voltage 2.168V (non-Op amp device operation) 0 = BOR trip voltage 2.932V (Op amp device operation) **Note:** The user application should select the greatest BORSEL voltage to enable the highest trip volt- age possible that is still less than VDD application operating voltage. ``` bit 28-20 Reserved: Write as '0' bit 19 RESERVED: Write as '1' ``` bit 18-16 FPLLODIV<2:0>: Default System PLL Output Divisor bits 111 = PLL output divided by 32 110 = PLL output divided by 32 101 = PLL output divided by 32 100 = PLL output divided by 16 011 = PLL output divided by 8 010 = PLL output divided by 4 001 = PLL output divided by 2 000 = PLL output divided by 2 bit 15 **Reserved:** Write as '1' bit 14-8 FPLLMULT<6:0>: System PLL Feedback Divider bits 1111111 = Multiply by 128 1111110 = Multiply by **127** 1111101 = Multiply by 126 1111100 = Multiply by 125 • 0000000 = Multiply by 1 bit 7 FPLLICLK: System PLL Input Clock Select bit 1 = FRC is selected as input to the System PLL 0 = Posc is selected as input to the System PLL # REGISTER 34-5: DEVCFG2/ADEVCFG2: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 2 (CONTINUED) bit 6-4 FPLLRNG<2:0>: System PLL Divided Input Clock Frequency Range bits 111 = Reserved 110 = Reserved 101 = 34-64 MHz 100 = 21-42 MHz 011 = 13-26 MHz 010 = 8-16 MHz 001 = 5-10 MHz 000 = Bypass Note: Use the highest filter range that covers the input frequency to the VCO multiplier block that corresponds to the PLLIDIV output freq to minimize PLL system jitter (see **FIGURE 9-1: "PIC32MK GPK/MCM with CAN FD Family Oscillator Diagram"**). For example, Crystal = 20 MHz, PLLIDIV<2:0> = '0b1; therefore, the filter input frequency is equal to 10 MHz and SPLLRANGE FPLLRNG<2:0> = '0b010. bit 3 Reserved: Write as '1' bit 2-0 FPLLIDIV<2:0>: PLL Input Divider bits 111 = Divide by 8 110 = Divide by 7 101 = Divide by 6 100 = Divide by 5 011 = Divide by 4 010 = Divide by 3 001 = Divide by 2 000 = Divide by 1 ## REGISTER 34-6: DEVCFG3/ADEVCFG3: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 3 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--| | 24.04 | R/P | R/P | R/P | R/P | R/P | r-1 | r-1 | r-1 | | | | | 31:24 | FVBUSIO1 | FUSBIDIO1 | IOL1WAY | PMDL1WAY | PGL1WAY | _ | _ | _ | | | | | 00.46 | R/P | R/P | r-1 | R/P | r-1 | r-1 | r-1 | r-1 | | | | | 23:16 | FVBUSIO2 | FUSBIDIO2 | _ | PWMLOCK | _ | _ | _ | _ | | | | | 45.0 | R/P | | | | 15:8 | | USERID<15:8> | | | | | | | | | | | 7.0 | R/P | | | | 7:0 | | USERID<7:0> | | | | | | | | | | | Legend: | r = Reserved bit | P = Programmable bit | | |-------------------|------------------|----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented b | it, read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 31 FVBUSIO1: USB1 VBUSON Selection bit 1 = VBUSON pin is controlled by the USB1 module 0 = VBUSON pin is controlled by the port function bit 30 FUSBIDIO1: USB1 USBID Selection bit 1 = USBID pin is controlled by the USB module 0 = USBID pin is controlled by the port function bit 29 IOL1WAY: Peripheral Pin Select Configuration bit 1 = Allow only one reconfiguration0 = Allow multiple reconfigurations bit 28 PMDL1WAY: Peripheral Module Disable Configuration bit 1 = Allow only one reconfiguration0 = Allow multiple reconfigurations bit 27 PGL1WAY: Permission Group Lock One Way Configuration bit 1 = Allow only one reconfiguration0 = Allow multiple reconfigurations bit 26-24 Reserved: Write as '1' bit 23 FVBUSIO2: USB2 VBUSON Selection bit 1 = VBUSON pin is controlled by the USB2 module 0 = VBUSON pin is controlled by the port function bit 22 FUSBIDIO2: USB2 USBID Selection bit 1 = USBID pin is controlled by the USB2 module 0 = USBID pin is controlled by the port function bit 21 Reserved: Write as '1' bit 20 PWMLOCK: PWM Write Access Select bit 1 = Write accesses to the PWM IOCONx register are not locked or protected 0 = Write accesses to the PWM IOCONx register must use the PWMKEY unlock procedure bit 19-16 Reserved: Write as '1' bit 15-0 USERID<15:0>: This is a 16-bit value that is user-defined and is readable via ICSP™ and JTAG # REGISTER 34-7: DEVCFG4/ADEVCFG4: DEVICE/ALTERNATE DEVICE CONFIGURATION WORD 4 | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | R/P | 31.24 | A5DIFFPR<1:0> | | A3DIFF | PR<1:0> | A2DIFFF | PR<1:0> | A1DIFFI | PR<1:0> | | 22.46 | U-1 | 23:16 | _ | _ | _ | _ | _ | | _ | _ | | 15:8 | U-1 | 15.6 | _ | _ | _ | _ | _ | | _ | _ | | 7:0 | U-1 | U-1 | U-1 | r-1 | r-1 | r-1 | r-1 | r-1 | | 7.0 | _ | _ | | _ | _ | _ | _ | _ | Legend:r = Reserved bitP = Programmable bitR = Readable bitW = Writable bitU = Unimplemented bit-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 31-30 A5DIFFPR[1:0]:OP-Amp 5 differential input configuration 11 = uses both PMOS and NMOS differential pair 10 = Reserved 01 = Reserved 00 = uses both PMOS and NMOS differential pair bit 29-28 A3DIFFPR[1:0]:Op-Amp 3 differential input configuration bit 27-26 A2DIFFPR[1:0]:Op-Amp 2 differential input configuration bit 25-24 A1DIFFPR[1:0]:Op-Amp 1 differential input configuration bit 23-0 Unimplemented: Read as "0" #### REGISTER 34-8: CFGCON: CONFIGURATION CONTROL REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------------|-------------------|-----------------------|------------------------|-----------------------|-----------------------|-----------------------|-----------------------| | 24.24 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | r-0 | U-0 | | 31:24 | _ | _ | _ | _ | _ | ADCPRI <sup>(1)</sup> | _ | _ | | 00:40 | R/W-0 | 23:16 | PWMAPIN6 | PWMAPIN5 | PWMAPIN4 | PWMAPIN3 | PWMAPIN2 | PWMAPIN1 | ICACLK <sup>(1)</sup> | OCACLK <sup>(1)</sup> | | 45.0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | r-0 | r-0 | U-0 | | 15:8 | _ | _ | IOLOCK <sup>(1)</sup> | PMDLOCK <sup>(1)</sup> | PGLOCK <sup>(1)</sup> | _ | _ | _ | | 7.0 | R/W-0 | U-0 | R/W-y | R/W-y | R/W-y | R/W-0 | U-0 | R/W-1 | | 7:0 | IOANCPEN <sup>(1)</sup> | _ | ECCC | ON<1:0> | JTAGEN | TROEN | _ | TDOEN | Legend:r = Reserved bity = Value set from Configuration bits on PORR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown - bit 31-27 Unimplemented: Read as '0' - bit 26 **ADCPRI:** ADC Arbitration Priority to SRAM bit<sup>(1)</sup> - 1 = ADC gets High Priority access to SRAM - 0 = ADC uses Least Recently Serviced Arbitration (same as other initiators) - bit 25 Reserved: Write as '0' - bit 24 Unimplemented: Read as '0' - bit 23-18 PWMAPIN6: PWMAPIN1: PWM Alternate I/O Pin Selection bit - 1 = PWMxL ('x' = 1-6) functionality is replaced by PWMxH(x+6) functionality. Provides independent PWMH and PWML functionality. If PWMAPING5 or PWMAPING6 = 1, the dedicated PWM output pin functions, PWMH11 and PWMH12, respectively, will be disabled and rerouted to PWML5 and PWML6. - 0 = PWMxL functionality remains on pins. Provides complimentary PWMH and PWML functionality. - bit 17 ICACLK: Input Capture Alternate Clock Selection bit (1) - 1 = Input Capture modules use an alternative Timer pair as their timebase clock - 0 = All Input Capture modules use Timer2/3 as their timebase clock - bit 16 OCACLK: Output Compare Alternate Clock Selection bit (1) - 1 = Output Compare modules use an alternative Timer pair as their timebase clock - 0 = All Output Compare modules use Timer2/3 as their timebase clock - bit 15-14 Unimplemented: Read as '0' - bit 13 IOLOCK: Peripheral Pin Select Lock bit (1) - 1 = Peripheral Pin Select is locked. Writes to PPS registers are not allowed - 0 = Peripheral Pin Select is not locked. Writes to PPS registers are allowed - bit 12 **PMDLOCK:** Peripheral Module Disable bit<sup>(1)</sup> - 1 = Peripheral module is locked. Writes to PMD registers are not allowed - 0 = Peripheral module is not locked. Writes to PMD registers are allowed - bit 11 **PGLOCK:** Permission Group Lock bit<sup>(1)</sup> - 1 = Permission Group registers are locked. Writes to PG registers are not allowed - 0 = Permission Group registers are not locked. Writes to PG registers are allowed - bit 10-9 Reserved: Write as '0' - bit 8 Unimplemented: Read as '0' - Note 1: To change this bit, the unlock sequence must be performed. Refer to Section 42. "Oscillators with Enhanced PLL" (DS60001250) in the "PIC32 Family Reference Manual" for details. REGISTER 34-8: CFGCON: CONFIGURATION CONTROL REGISTER (CONTINUED) - bit 7 **IOANCPEN:** I/O Analog Charge Pump Enable bit (1) - 1 = Charge pump is enabled - 0 = Charge pump is disabled (default) - **Note 1:** For proper analog operation if VDD is less than 2.5V, the AICPMPEN bit (ADCCON1<12>) must be = 1 and the IOANCPEN bit must be set to '1'; however, the charge pumps will consume additional current. These bits should never be set if the VDD operating voltage is greater than 2.5V. - 2: ADC throughput rate performance is reduced, as defined in the following table, if AICPMPEN = 1 or IOANCPEN (CFGCON<7) = 1. | ADC0 | ADC1 | ADC2 | ADC3 | ADC4 | ADC5 | ADC7 | Maximum Sum of Total ADC Throughputs | |------|------|------|------|------|------|------|--------------------------------------| | ON | OFF | OFF | OFF | OFF | OFF | OFF | 2 Msps | | ON | ON | OFF | OFF | OFF | OFF | OFF | 4 Msps | | ON | ON | ON | OFF | OFF | OFF | OFF | 5 Msps | | OFF | OFF | OFF | ON | OFF | OFF | OFF | 2 Msps | | OFF | OFF | OFF | ON | ON | OFF | OFF | 4 Msps | | OFF | OFF | OFF | ON | ON | ON | OFF | 5 Msps | | OFF | OFF | OFF | ON | ON | ON | ON | 5 Msps | | ON | ON | ON | ON | OFF | OFF | OFF | 7 Msps | | ON | ON | ON | ON | ON | OFF | OFF | 9 Msps | | ON | ON | ON | ON | ON | ON | OFF | 10 Msps | | ON | OFF | OFF | ON | ON | ON | ON | 7 Msps | | ON | ON | OFF | ON | ON | ON | ON | 9 Msps | | ON 10 Msps | - bit 6 Unimplemented: Read as '0' - bit 5-4 **ECCCON<1:0>:** Flash ECC Configuration bits - 11 = ECC and dynamic ECC are disabled (ECCCON<1:0> bits are writable) - 10 = ECC and dynamic ECC are disabled (ECCCON<1:0> bits are locked) - 01 = Dynamic Flash ECC is enabled (ECCCON<1:0> bits are locked) - 00 = Flash ECC is enabled (ECCCON<1:0> bits are locked; disables word Flash writes) **Note:** These bits are loaded from DEVCFG0<9:8>, (i.e. FECCCON<1:0>), configuration word fuse bits on POR power on reset - bit 3 JTAGEN: JTAG Port Enable bit - 1 = Enable the JTAG port - 0 = Disable the JTAG port Note: The reset value of this bit is the value of the JTAGEN Configuration Word setting in the DEVCFG0 register. If JTAGEN (DEVCFG0<2>) = 0, this bit cannot be set to '1' by the user application at runtime. If JTAGEN (DEVCFG0<2>) = 1, the user application may enable/disable JTAG at run-time by writing this bit to the desired value. - bit 2 TROEN: Trace Output Enable bit - 1 = Enable trace outputs and start trace clock (trace probe must be present) - 0 = Disable trace outputs and stop trace clock **Note:** When the user Configuration Word, TRCEN in the DEVCFG0 register is equal to '0', the value of this bit is ignored, but has the effect of being '0'. - bit 1 Unimplemented: Read as '0' - Note 1: To change this bit, the unlock sequence must be performed. Refer to **Section 42. "Oscillators with Enhanced PLL"** (DS60001250) in the *"PIC32 Family Reference Manual"* for details. REGISTER 34-8: CFGCON: CONFIGURATION CONTROL REGISTER (CONTINUED) bit 0 TDOEN: TDO Enable for 2-Wire JTAG 1 = 2-wire JTAG protocol uses TDO 0 = 2-wire JTAG protocol does not use TDO Note: Implementing the JTAG protocol over the 2-wire interface requires four 2-wire clocks for each TCK if TDO is required. However, if the values shifted out TDO are predetermined, TDO can be disabled. Note 1: To change this bit, the unlock sequence must be performed. Refer to **Section 42. "Oscillators with Enhanced PLL"** (DS60001250) in the *"PIC32 Family Reference Manual"* for details. #### REGISTER 34-9: CFGPG: PERMISSION GROUP CONFIGURATION REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 24.24 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | | 31:24 | _ | _ | JTAGPG<1:0> | | _ | — ADCPG<1:0> | | G<1:0> | | 00.46 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 23:16 | FCPG<1:0> | | | | CAN4P | G<1:0> | CAN3P | G<1:0> | | 45.0 | R/W-0 | 15:8 | CAN2PG<1:0> | | CAN1PG<1:0> | | USB2P | G<1:0> | USB1P | G<1:0> | | 7.0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | | 7:0 | _ | _ | DMAP | G<1:0> | CPUDSPG<1:0> | | CPUPG<1:0> | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared bit 31-30 Unimplemented: Read as '0' bit 29-28 JTAGPG<1:0>: JTAG Permission Group bits Same definition as bits 25-24. bit 27-26 Unimplemented: Read as '0' bit 25-24 ADCPG<1:0>: ADC Permission bits The Bus Initiator has access to access controlled memory regions as defined by the bus structure's permission group SFRs for RDPER and WRPER. 11 = Read access if RDPER<3> = 1; write access if WRPER<3> = 1 10 = Read access if RDPER<2> = 1; write access if WRPER<2> = 1 01 = Read access if RDPER<1> = 1; write access if WRPER<1> = 1 00 = Read access if RDPER<0> = 1; write access if WRPER<0> = 1 bit 23-22 FCPG<1:0>: Flash Control Permission Group bits Same definition as bits 25-24. bit 21-20 Unimplemented: Read as '0' bit 19-18 **CAN4G<1:0>:** CAN4 Module Permission Group bits Same definition as bits 25-24. bit 17-16 **CAN3PG<1:0>:** CAN3 Module Permission Group bits Same definition as bits 25-24. bit 15-14 **CAN2PG<1:0>:** CAN2 Module Permission Group bits Same definition as bits 25-24. bit 13-12 **CAN1PG<1:0>:** CAN1 Module Permission Group bits Same definition as bits 25-24. bit 11-10 **USB2PG<1:0>:** USB2 Module Permission Group bits Same definition as bits 25-24. bit 9-8 **USB1PG<1:0>:** USB1 Module Permission Group bits Same definition as bits 25-24. bit 7-6 Unimplemented: Read as '0' bit 5-4 **DMAPG<1:0>:** DMA Module Permission Group bits Same definition as bits 25-24. bit 3-2 **CPUDSPG<1:0>:** CPU Data Space Permission Group bits Same definition as bits 25-24. bit 1-0 **CPUPG<1:0>:** CPU Instruction Space Permission Group bits Same definition as bits 25-24. Note: CPUPG<1:0> automatically reverts to `0b00 when the CPU acknowledges entry into a NMI exception as indicated by the GNMI bit (RNMICON<19>). The effective value of CPUPG<1:0> when the CPU is in Debug Mode is controlled by the DRGPER bit in the DEVCEGO(ADEVCEGO) when the CPU is in Debug Mode is controlled by the DBGPER bit in the DEVCFG0/ADEVCFG0 register. If DBGPER denies access to the Group CPUPG selects, the effective value selects Group3. **REGISTER 34-10: CFGCON2: EE DATA CONFIGURATION REGISTER** | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | |--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------| | 31:24 | U-0 | 31.24 | | _ | _ | _ | _ | _ | _ | | | 00:40 | U-0 | 23:16 | <del>_</del> | _ | _ | _ | _ | _ | _ | - | | 45.0 | U-0 | 15:8 | _ | _ | _ | _ | _ | _ | _ | _ | | 7.0 | R/W-0 | 7:0 | | | | EEWS< | <7:0> | | | | Legend: r = Reserved bit P = Programmable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-8 Unimplemented: Read as '0' bit 7-0 EEWS<7:0>: Read Access Count bits These bits indicate the number of clock cycles for a read access. The EEWS<7:0> bits must be initialized before any user application EEDATA accesses are attempted. Refer to the following table. | DATA EE Wait States<br>EEWS<7:0> bits are equal to: | PBCLK2 =<br>(FSYSCLK / PBDIV<6:0> (PB2DIV<6:0>) | |-----------------------------------------------------|-------------------------------------------------| | 0 | 0-39 MHz | | 1 | 40-59 MHz | | 2 | 60-79 MHz | | 3 | 80-97 MHz | | 4 | 98-117 MHz | | 5 | 118-120 MHz | #### REGISTER 34-11: DEVID: DEVICE AND REVISION ID REGISTER | Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |--------------|-----------------------------|-------------------|---------------------|-------------------|---------------------|-------------------|-----------------------|------------------|--|--| | 24.24 | R | R | R | R | R | R | R | R | | | | 31:24 | | VER<3 | 3:0> <sup>(1)</sup> | | | DEVID<2 | 27:24> <sup>(1)</sup> | - | | | | 00:40 | R | R | R | R | R | R | R | R | | | | 23:16 | DEVID<23:16> <sup>(1)</sup> | | | | | | | | | | | 45.0 | R | R | R | R | R | R | R | R | | | | 15:8 | | | | DEVID<1 | 5:8> <sup>(1)</sup> | | | | | | | 7.0 | R | R | R | R | R | R | R | R | | | | 7:0 | | | | DEVID< | 7:0> <sup>(1)</sup> | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 31-28 VER<3:0>: Revision Identifier bits(1) bit 27-0 **DEVID<27:0>:** Device ID<sup>(1)</sup> Note 1: See the "PIC32 Flash Programming Specification" (DS60001145) for a list of Revision and Device ID values. #### REGISTER 34-12: DEVADCx: DEVICE ADC CALIBRATION REGISTER 'x' ('x' = 0-5, 7) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 24.24 | R | R | R | R | R | R | R | R | | | | 31:24 | ADCAL<31:24> | | | | | | | | | | | 22.46 | R | R | R | R | R | R | R | R | | | | 23:16 | ADCAL<23:16> | | | | | | | | | | | 15:8 | R | R | R | R | R | R | R | R | | | | 15.6 | ADCAL<15:8> | | | | | | | | | | | 7:0 | R | R | R | R | R | R | R | R | | | | 7.0 | | • | • | ADCA | L<7:0> | | | • | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 ADCAL<31:0>: Calibration Data for the ADC Module bits Before enabling the ADC, the user application must initialize the ADC calibration values by copying them from the factory programmed DEVADCx Flash locations starting at 0xBFC45000 into the ADCxCFG registers starting at 0xBF887D00, respectively. Refer to **25.0** "12-bit High-Speed Successive Approximation Register (SAR) Analog-to-Digital Converter (ADC)" for more information. #### REGISTER 34-13: DEVSNx: DEVICE SERIAL NUMBER REGISTER 'x' ('x' = 0-3) | Bit Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 | | | |-----------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--| | 31:24 | R | R | R | R | R | R | R | R | | | | 31.24 | | | | SN<3 | 31:24> | | | | | | | 23:16 | R | R | R | R | R | R | R | R | | | | 23.10 | | | | SN<2 | 23:16> | | | | | | | 15:8 | R | R | R | R | R | R | R | R | | | | 15.6 | | | | SN< | 15:8> | | | | | | | 7:0 | R | R | R | R | R | R | R | R | | | | 7.0 | | SN<7:0> | | | | | | | | | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 31-0 **SN<31:0>:** Device Unique Serial Number bits These registers contain a value, programmed during factory production test, that is unique to each unit and are user read only. These values are persistent and not erased even when a new application code is programmed into the device. These values can be used if desired as an encryption key in combination with the Microchip encryption library. #### 34.3 On-Chip Voltage Regulator The core and digital logic for all PIC32MK GPK/MCM with CAN FD Family devices is designed to operate at a nominal 1.2V. To simplify system designs, devices in the PIC32MK GPK/MCM with CAN FD Family incorporate an on-chip regulator providing the required core logic voltage from VDD. #### 34.3.1 ON-CHIP REGULATOR AND POR It takes a fixed delay for the on-chip regulator to generate an output. During this time, designated as TPU, code execution is disabled. TPU is applied every time the device resumes operation after any power-down, including Sleep mode. #### 34.3.2 ON-CHIP REGULATOR AND BOR PIC32MK GPK/MCM with CAN FD Family devices also have a simple brown-out capability. If the voltage supplied to the regulator is inadequate to maintain a regulated level, the regulator Reset circuitry will generate a Brown-out Reset. This event is captured by the BOR flag bit (RCON<1>). The brown-out voltage levels are specific in 37.1 "DC Characteristics". #### 34.4 On-chip Temperature Sensor PIC32MK GPK/MCM with CAN FD Family devices include a temperature sensor that provides accurate measurement of a device's junction temperature (see 37.2 "AC Characteristics and Timing Parameters" for more information). The temperature sensor is connected to the ADC module and can be measured using the shared S&H circuit (see 25.0 "12-bit High-Speed Successive Approximation Register (SAR) Analog-to-Digital Converter (ADC)" for more information). #### 34.5 Programming and Diagnostics PIC32MK GPK/MCM with CAN FD Family devices provide a complete range of programming and diagnostic features that can increase the flexibility of any application using them. These features allow system designers to include: - Simplified field programmability using two-wire In-Circuit Serial Programming™ (ICSP™) interfaces - · Debugging using ICSP - Programming and debugging capabilities using the EJTAG extension of JTAG - JTAG boundary scan testing for device and board diagnostics PIC32MK devices incorporate two programming and diagnostic modules, and a trace controller, that provide a range of functions to the application developer. FIGURE 34-1: BLOCK DIAGRAM OF PROGRAMMING, DEBUGGING AND TRACE | | | - aiiiiy | | |--------|--|----------|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 35.0 INSTRUCTION SET The PIC32MK GPK/MCM with CAN FD Family instruction set complies with the MIPS32® Release 5 instruction set architecture. The PIC32MK GPK/MCM with CAN FD Family of device family *does not* support the following features: - · Core extend instructions - · Coprocessor 1 instructions - · Coprocessor 2 instructions Note: Refer to "MIPS32® Architecture for Programmers Volume II: The MIPS32® Instruction Set" at www.imgtec.com for more information. | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 36.0 DEVELOPMENT SUPPORT The PIC® microcontrollers (MCU) and dsPIC® digital signal controllers (DSC) are supported with a full range of software and hardware development tools: - · Integrated Development Environment - MPLAB® X IDE Software - · Compilers/Assemblers/Linkers - MPLAB XC Compiler - MPASM<sup>TM</sup> Assembler - MPLINK<sup>TM</sup> Object Linker/ MPLIB<sup>TM</sup> Object Librarian - MPLAB Assembler/Linker/Librarian for Various Device Families - Simulators - MPLAB X SIM Software Simulator - Emulators - MPLAB REAL ICE™ In-Circuit Emulator - · In-Circuit Debuggers/Programmers - MPLAB ICD 3 - PICkit™ 3 - · Device Programmers - MPLAB PM3 Device Programmer - Low-Cost Demonstration/Development Boards, Evaluation Kits and Starter Kits - · Third-party development tools # 36.1 MPLAB X Integrated Development Environment Software The MPLAB X IDE is a single, unified graphical user interface for Microchip and third-party software, and hardware development tool that runs on Windows<sup>®</sup>, Linux and Mac OS<sup>®</sup> X. Based on the NetBeans IDE, MPLAB X IDE is an entirely new IDE with a host of free software components and plug-ins for high-performance application development and debugging. Moving between tools and upgrading from software simulators to hardware debugging and programming tools is simple with the seamless user interface. With complete project management, visual call graphs, a configurable watch window and a feature-rich editor that includes code completion and context menus, MPLAB X IDE is flexible and friendly enough for new users. With the ability to support multiple tools on multiple projects with simultaneous debugging, MPLAB X IDE is also suitable for the needs of experienced users. #### Feature-Rich Editor: - · Color syntax highlighting - Smart code completion makes suggestions and provides hints as you type - Automatic code formatting based on user-defined rules - · Live parsing User-Friendly, Customizable Interface: - Fully customizable interface: toolbars, toolbar buttons, windows, window placement, etc. - · Call graph window Project-Based Workspaces: - · Multiple projects - · Multiple tools - · Multiple configurations - · Simultaneous debugging sessions File History and Bug Tracking: - · Local file history feature - · Built-in support for Bugzilla issue tracker #### 36.2 MPLAB XC Compilers The MPLAB XC Compilers are complete ANSI C compilers for all of Microchip's 8, 16, and 32-bit MCU and DSC devices. These compilers provide powerful integration capabilities, superior code optimization and ease of use. MPLAB XC Compilers run on Windows, Linux or MAC OS X. For easy source level debugging, the compilers provide debug information that is optimized to the MPLAB X IDE. The free MPLAB XC Compiler editions support all devices and commands, with no time or memory restrictions, and offer sufficient code optimization for most applications. MPLAB XC Compilers include an assembler, linker and utilities. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. MPLAB XC Compiler uses the assembler to produce its object file. Notable features of the assembler include: - · Support for the entire device instruction set - · Support for fixed-point and floating-point data - · Command-line interface - · Rich directive set - · Flexible macro language - · MPLAB X IDE compatibility #### 36.3 MPASM Assembler The MPASM Assembler is a full-featured, universal macro assembler for PIC10/12/16/18 MCUs. The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel® standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code, and COFF files for debugging. The MPASM Assembler features include: - · Integration into MPLAB X IDE projects - User-defined macros to streamline assembly code - Conditional assembly for multipurpose source files - Directives that allow complete control over the assembly process #### 36.4 MPLINK Object Linker/ MPLIB Object Librarian The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler. It can link relocatable objects from precompiled libraries, using directives from a linker script. The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications. The object linker/library features include: - Efficient linking of single libraries instead of many smaller files - Enhanced code maintainability by grouping related modules together - Flexible creation of libraries with easy module listing, replacement, deletion and extraction # 36.5 MPLAB Assembler, Linker and Librarian for Various Device Families MPLAB Assembler produces relocatable machine code from symbolic assembly language for PIC24, PIC32 and dsPIC DSC devices. MPLAB XC Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include: - · Support for the entire device instruction set - · Support for fixed-point and floating-point data - · Command-line interface - · Rich directive set - · Flexible macro language - MPLAB X IDE compatibility #### 36.6 MPLAB X SIM Software Simulator The MPLAB X SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers. The MPLAB X SIM Software Simulator fully supports symbolic debugging using the MPLAB XC Compilers, and the MPASM and MPLAB Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool. #### 36.7 MPLAB REAL ICE In-Circuit Emulator System The MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs all 8, 16 and 32-bit MCU, and DSC devices with the easy-to-use, powerful graphical user interface of the MPLAB X IDE. The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with in-circuit debugger systems (RJ-11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5). The emulator is field upgradable through future firmware downloads in MPLAB X IDE. MPLAB REAL ICE offers significant advantages over competitive emulators including full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, logic probes, a ruggedized probe interface and long (up to three meters) interconnection cables. # 36.8 MPLAB ICD 3 In-Circuit Debugger System The MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost-effective, high-speed hardware debugger/programmer for Microchip Flash DSC and MCU devices. It debugs and programs PIC Flash microcontrollers and dsPIC DSCs with the powerful, yet easy-to-use graphical user interface of the MPLAB IDE. The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers. #### 36.9 PICkit 3 In-Circuit Debugger/ Programmer The MPLAB PICkit 3 allows debugging and programming of PIC and dsPIC Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB IDE. The MPLAB PICkit 3 is connected to the design engineer's PC using a full-speed USB interface and can be connected to the target via a Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the Reset line to implement in-circuit debugging and In-Circuit Serial Programming™ (ICSP™). #### 36.10 MPLAB PM3 Device Programmer The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features a large LCD display (128 x 64) for menus and error messages, and a modular, detachable socket assembly to support various package types. The ICSP cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in this mode. The MPLAB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized algorithms for quick programming of large memory devices, and incorporates an MMC card for file storage and data applications. # 36.11 Demonstration/Development Boards, Evaluation Kits, and Starter Kits A wide variety of demonstration, development and evaluation boards for various PIC MCUs and dsPIC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification. The boards support a variety of features, including LEDs, temperature sensors, switches, speakers, RS-232 interfaces, LCD displays, potentiometers and additional EEPROM memory. The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications. In addition to the PICDEM™ and dsPICDEM™ demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for analog filter design, KEELoQ® security ICs, CAN, IrDA®, PowerSmart battery management, SEEVAL® evaluation system, Sigma-Delta ADC, flow rate sensing, plus many more. Also available are starter kits that contain everything needed to experience the specified device. This usually includes a single application and debug capability, all on one board. Check the Microchip web page (www.microchip.com) for the complete list of demonstration, development and evaluation kits. #### 36.12 Third-Party Development Tools Microchip also offers a great collection of tools from third-party vendors. These tools are carefully selected to offer good value and unique functionality. - Device Programmers and Gang Programmers from companies, such as SoftLog and CCS - Software Tools from companies, such as Gimpel and Trace Systems - Protocol Analyzers from companies, such as Saleae and Total Phase - Demonstration Boards from companies, such as MikroElektronika, Digilent<sup>®</sup> and Olimex - Embedded Ethernet Solutions from companies, such as EZ Web Lynx, WIZnet and IPLogika<sup>®</sup> #### 37.0 ELECTRICAL CHARACTERISTICS This section provides an overview of the PIC32MK GPK/MCM with CAN FD Family electrical characteristics. Additional information will be provided in future revisions of this document as it becomes available. Absolute maximum ratings for the PIC32MK GPK/MCM with CAN FD Family devices are listed below. Exposure to these maximum rating conditions for extended periods may affect device reliability. Functional operation of the device at these or any other conditions, above the parameters indicated in the operation listings of this specification, is not implied. # Absolute Maximum Ratings (See Note 1) | Ambient temperature under bias | < -40°C or > +125°C | |----------------------------------------------------------------------------------|----------------------------| | Storage temperature | | | Voltage on VDD with respect to Vss | | | Voltage on VDD with respect to VUSB3V3 | | | Voltage on any pin that is not 5V tolerant, with respect to Vss (Note 3) | 0.3V to (VDD +0.3V) | | Voltage on any 5V tolerant pin with respect to Vss when VDD $\geq$ 2.3V (Note 3) | 0.3V to +5.5V | | Voltage on any 5V tolerant pin with respect to Vss when VDD < 2.3V (Note 3) | -0.3V to +3.6V | | Voltage on D+ or D- pin with respect to VUSB3V3 | Vss -0.3V to VUSB3V3 +0.3V | | Voltage on VBUS with respect to VSS | 0.3V to +5.5V | | Maximum current out of Vss pin(s) | 200 mA | | Maximum current into VDD pin(s) (Note 2) | 200 mA | | Maximum current sunk/sourced by any 4x I/O pin (Note 4) | 15 mA | | Maximum current sunk/sourced by any 8x I/O pin (Note 4) | 25 mA | | Maximum current sunk by all ports | 150 mA | | Maximum current sourced by all ports (Note 2) | 150 mA | | ESD qualification: | | | Human Body Model (HBM) per JESD22-A114 | | | Machine Model (MM) per JESD22-A115 | 200 V | | Charged Device Model (CDM) AEC Q100-011 (ANSI/ ESD STM 5.3.1) | | - **Note 1:** Stresses above those listed under "**Absolute Maximum Ratings**" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions, above those indicated in the operation listings of this specification, is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. - 2: Maximum allowable current is a function of device maximum power dissipation (see Table 37-2). - 3: See the pin name tables (Table 3 and Table 5) for the 5V tolerant pins. - 4: Characterized, but not tested. Refer to parameters DO10, DO20, and DO20a for the 4x and 8x I/O pin lists. #### 37.1 DC Characteristics TABLE 37-1: OPERATING MIPS VERSUS VOLTAGE | | Von Bonge | Town Bongs | Max. Frequency | | | |----------------|-------------------------|------------------------|--------------------------------------------|------------|--| | Characteristic | VDD Range<br>(in Volts) | Temp. Range<br>(in °C) | PIC32MK GPK/MCM with CAN FD Family Devices | Comment | | | DC5a | 2.3V-3.6V(1,2) | -40°C to +85°C | 120 MHz | Industrial | | | DC5b | 3.0V-3.6V(1,3) | -40 C to +65 C | 120 IVITZ | muusmai | | | DC5c | 2.3V-3.6V(1,2) | -40°C to +125°C | 80 MHz | Extended | | | DC5d | 3.0V-3.6V(1,3) | -40 C to +125 C | OU IVIHZ | Extended | | - **Note 1:** Overall functional device operation at VBORMIN < VDD < VDDMIN is guaranteed, but not characterized. All device analog modules, such as ADC, etc., will function, but with degraded performance below VDDMIN. Refer to parameter BO10 in Table 37-5 for BOR values. - 2: If DEVCFG2<BORSEL> = 1, (Set to "1" if Op-Amps are not being utilized in application, VDD(min) = 2.3V) - 3: If DEVCFG2<BORSEL> = 0 (Required if Op-Amps are being utilized in application, VDD(min) = 3.0v) #### **TABLE 37-2: THERMAL OPERATING CONDITIONS** | Rating | Symbol | Min. | Тур. | Max. | Unit | |-----------------------------------------------------------------------------------------------|--------|---------------|-------------|------|------| | Industrial Temperature Devices | | | | | | | Max allowed Operating Junction Temperature Range | TJ | -40 | _ | +140 | °C | | Operating Ambient Temperature Range | TA | -40 | _ | +85 | °C | | Extended Temperature Devices | | | | | | | Max allowed Operating Junction Temperature Range | TJ | -40 | _ | +140 | °C | | Operating Ambient Temperature Range | TA | -40 | _ | +125 | °C | | Power Dissipation: Internal Chip Power Dissipation: PINT = VDD x (IDD – Σ IOH) | PD | PINT + PI/O W | | | W | | I/O Pin Power Dissipation:<br>$PI/O = \Sigma ((\{VDD - VOH\} \times IOH) + (VOL \times IOL))$ | | | | | | | Maximum Allowed Power Dissipation | PDMAX | ( | ΓJ – TA)/θ、 | JA | W | #### **TABLE 37-3: THERMAL PACKAGING CHARACTERISTICS** | Characteristics | Symbol | Тур. | Max. | Unit | Notes | |-------------------------------------------------------|--------|------|------|------|-------| | Package Thermal Resistance, 64-pin VQFN (9x9x0.9 mm) | θЈА | 23.9 | _ | °C/W | 1 | | Package Thermal Resistance, 64-pin TQFP (10x10x1 mm) | θЈА | 38.7 | _ | °C/W | 1 | | Package Thermal Resistance, 100-pin TQFP (12x12x1 mm) | θЈА | 44.2 | _ | °C/W | 1 | **Note 1:** Junction to ambient thermal resistance, Theta-JA ( $\theta$ JA) numbers are achieved by package simulations. TABLE 37-4: DC TEMPERATURE AND VOLTAGE SPECIFICATIONS | DC CHA | ARACTER | ISTICS | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | |---------------|----------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|-------|-------------------------------------------------------| | Param.<br>No. | Symbol | Characteristics | Min. | Тур. | Max. | Units | Conditions | | Operati | ng Voltag | e | | | | | | | DC10a | VDD <sup>(1,4)</sup> | Supply Voltage | 2.3 | _ | 3.6 | V | DEVCFG2 <borsel> = 1</borsel> | | DC10b | VDD <sup>(1,5)</sup> | | 3.0 | _ | 3.6 | V | DEVCFG2 <borsel> = 0</borsel> | | DC12 | VDR | RAM Data Retention Voltage (Note 2) | 1.75 | _ | | ٧ | _ | | DC16 | VPOR | VDD Start Voltage<br>to Ensure Internal<br>Power-on Reset Signal (Note 3) | _ | _ | Vss +<br>0.3V | V | Non-compliance can<br>cause indeterminate<br>behavior | | DC17 | SVDD | VDD Rise Rate<br>to Ensure Internal<br>Power-on Reset Signal | 0.000011 | _ | 0.33 | V/µs | 300 ms to 10µs | - Note 1: Overall functional device operation at VBORMIN < VDD < VDDMIN is guaranteed, but not characterized. All device Analog modules, such as ADC, etc., will function, but with degraded performance below VDDMIN. Refer to parameter BO10 in Table 37-5 for BOR values. - 2: This is the limit to which VDD can be lowered without losing RAM data. - 3: This is the limit to which VDD must be lowered to ensure Power-on Reset. - 4: If DEVCFG2<BORSEL> = 1, (Set to "1" if Op-Amps are not being utilized in application, VDD(min) = 2.3V) - 5: If DEVCFG2<BORSEL> = 0 (Required if Op-Amps are being utilized in application, VDD(min) = 3.0v) #### TABLE 37-5: ELECTRICAL CHARACTERISTICS: BOR | DC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | |--------------------|--------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------|-------------------------------| | Param.<br>No. | Symbol | Characteristics | Min. <sup>(1)</sup> | Тур. | Max. | Units | Conditions | | BO10a | _ | BOR Event on VDD transition high-to-low (Note 2) | 2.638 | _ | 2.942 | ٧ | DEVCFG2 <borsel> = 0</borsel> | | | | | 1.928 | | 2.172 | V | DEVCFG2 <borsel> = 1</borsel> | - Note 1: Parameters are for design guidance only and are not tested in manufacturing. - 2: Overall functional device operation at VBORMIN < VDD < VDDMIN is tested, but not characterized. All device Analog modules, such as ADC, etc., will function, but with degraded performance below VDDMIN. TABLE 37-6: DC CHARACTERISTICS: OPERATING CURRENT (IDD RUN CURRENT WITH PERIPHERAL CLOCKS ENABLED)(1,2) | DC CHARA | ACTERISTIC | :s | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | |------------------|--------------------------|-------------------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--|--| | Parameter<br>No. | Typical <sup>(3,4)</sup> | <b>Maximum</b><br>(-40°C ≤ TA<br>≤ +85°C) | <b>Maximum</b><br>(-40°C ≤ TA<br>≤ +125°C) | Units | Conditions | | | | Operating | Current (IDE | Run Curre | nt With Per | ipheral Clo | cks Enabled) (Note 1,2) | | | | DC20 | 4.5 | 20 | 58 | mA | 4 MHz (Note 2,4) | | | | DC21 | 7 | 22 | 60 | mA | 10 MHz (Note 2,4) | | | | DC22 | 22 | 45 | 76 | mA | 60 MHz (Note 2,4) | | | | DC23 | 29 | 55 | 83 | mA | 80 MHz (Note 2) | | | | DC25 | 42 | 70 | 92 | mA | 120 MHz (Note 2) | | | | Operating | Current (IDE | CPU Only | Run Currer | nt With Peri | pheral Clocks Disabled) (Note 1,2) | | | | DC20A | 4 | 19 | 55 | mA | 4 MHz (Note 4,5) | | | | DC21A | 5.5 | 21 | 58 | mA | 10 MHz (Note 4,5) | | | | DC22A | 17 | 38 | 70 | mA | 60 MHz (Note 4,5) | | | | DC23A | 21 | 44 | 73 | mA | 80 MHz (Note 4,5) | | | | DC25A | 29 | 58 | 82 | mA | 120 MHz (Note 4,5) | | | - **Note 1:** A device's IDD supply current is mainly a function of the operating voltage and frequency. Other factors, such as PBCLK (Peripheral Bus Clock) frequency, number of peripheral modules enabled, internal code execution pattern, I/O pin loading and switching rate, oscillator type, as well as temperature, can have an impact on the current consumption. - 2: The test conditions for IDD measurements are as follows: - Oscillator mode is EC (for 8 MHz and below) and EC+PLL (for above 8 MHz) with OSC1 driven by external square wave from rail-to-rail, (OSC1 input clock input over/undershoot < 100 mV required) - OSC2/CLKO is configured as an I/O input pin - USB PLL is disabled, VusB3v3 is connected to VDD - PBCLKx divisor = 1:2 ('x' =/= 1,7), PBCLK6 = 1:4, PBCLK1 = 1:1 - CPU, Program Flash, and SRAM data memory are operational, Program Flash memory Wait states are equal to seven (default) - · Prefetch module is enabled - No peripheral modules are operating, (ON bit = 0), and the associated PMD bit is '0' (clocks enabled) - WDT, DMT, Clock Switching, Fail-Safe Clock Monitor, and Secondary Oscillator are disabled - · All I/O pins are configured as inputs and pulled to Vss - MCLR = VDD - CPU executing while (1) statement from Flash - · RTCC and JTAG are disabled - IOANCPEN (CFGCON<7>) = 0, I/O Analog Charge Pump disabled - AICPMPEN (ADCCON1><12>) = 0, ADC Input Charge Pump disabled - **3:** Data in the "Typ" column is at 3.3V, +25°C at specified operating frequency unless otherwise stated. Parameters are for design guidance only and are not tested. - **4:** This parameter is characterized, but not tested in manufacturing. - 5: Note 2 applies with the following exceptions: - · Prefetch disabled - · Prefetch cache disabled - PMDx = 1 (all bits set) - PB2, 3, 4, 5, 6 = OFF - PB1 = 1:128 TABLE 37-7: DC CHARACTERISTICS: IDLE CURRENT (IDLE) | TABLE 31-1. DO STAKASTERISTICS. IDEE CORREINT (IIDEE) | | | | | | | | | |-------------------------------------------------------|--------------------------|-----------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--| | DC CHARACTERISTICS | | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | Parameter<br>No. | Typical <sup>(2,3)</sup> | <b>Maximum</b><br>-40°C ≤ TA<br>≤ +85°C | <b>Maximum</b><br>-40°C ≤ TA<br>≤ +125°C | Units | Conditions | | | | | Idle Current | t (IIDLE): Core | Off, Clock | on Base Cu | rrent (Not | re 1) | | | | | DC30a | 3.5 | 23 | 55 | mA | 4 MHz (Note 3) | | | | | DC31a | 5 | 25 | 58 | mA | 10 MHz | | | | | DC32a | 12 | 35 | 65 | mA | 60 MHz (Note 3) | | | | | DC33a | 21 | 50 | 75 | mA | 120 MHz | | | | - Note 1: The test conditions for IIDLE current measurements are as follows: - Oscillator mode is EC (for 8 MHz and below) and EC+PLL (for above 8 MHz) with OSC1 driven by external square wave from rail-to-rail, (OSC1 input clock input over/undershoot < 100 mV required)</li> - · OSC2/CLKO is configured as an I/O input pin - USB PLL is disabled, VusB3v3 is connected to VDD - PBCLKx divisor = 1:2 ('x' =/= 1,6,7), PBCLK6 = 1:4, PBCLK1 = 1:1 - CPU is in Idle mode (CPU core Halted) - · Prefetch module is disabled - No peripheral modules are operating, (ON bit = 0), and the associated PMD bit is '0' (i.e., clocks enabled) - · WDT, DMT, Clock Switching, Fail-Safe Clock Monitor, and Secondary Oscillator are disabled - · All I/O pins are configured as inputs and pulled to Vss - MCLR = VDD - · RTCC and JTAG are disabled - IOANCPEN (CFGCON<7>) = 0, I/O Analog Charge Pump disabled - AICPMPEN (ADCCON1><12>) = 0, ADC Input Charge Pump disabled - **2:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: This parameter is characterized, but not tested in manufacturing. TABLE 37-8: DC CHARACTERISTICS: POWER-DOWN CURRENT (IPD) | DC CHARA | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | | | | |---------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------------|-------------------------------------------------|--|--|--|--|--|--|--| | Param.<br>No. | Typical <sup>(2)</sup> | Maximum | Units | Inits Conditions | | | | | | | | | | Power-Do | Power-Down Current (IPD) (Note 1) | | | | | | | | | | | | | DC40k | 0.5 | 5 | mA | -40°C | | | | | | | | | | DC40I | 1 | 5 | mA | +25°C | -<br>- Base Power-Down Sleep | | | | | | | | | DC40m | 8 | 28 | mA | +85°C | - Base Fower-Down Sleep | | | | | | | | | DC40o | 10 | 48 | mA | +125°C | | | | | | | | | | Module Di | fferential Curr | ent | | | • | | | | | | | | | DC41e | 5 | _ | μΑ | 3.6V | Watchdog Timer Current: ∆IWDT (Note 3) | | | | | | | | | DC42e | 25 | _ | μΑ | 3.6V | RTCC + Timer1 w/32 kHz Crystal: ΔIRTCC (Note 3) | | | | | | | | | DC43d | 4 | 6 | mA | 3.6V | ADC: ΔIADC (Notes 3, 4) | | | | | | | | Note 1: The test conditions for IPD current measurements are as follows: #### Sleep: - Oscillator mode is EC (for 8 MHz and below) and EC+PLL (for above 8 MHz) with OSC1 driven by external square wave from rail-to-rail, (OSC1 input clock input over/undershoot < 100 mV required)</li> - · OSC2/CLKO is configured as an I/O input pin - USB PLL is disabled, VUSB3V3 is connected to VDD - PBCLKx divisor = 1:2 ('x' =/= 1,6,7), PBCLK6 = 1:4, PBCLK1 = 1:1 - · CPU is in Sleep mode - · Prefetch module is disabled - No peripheral modules are operating, (ON bit = 0), and the associated PMD bit is '0' (i.e., clocks enabled) - WDT, DMT, Clock Switching, Fail-Safe Clock Monitor, and Secondary Oscillator are disabled - · All I/O pins are configured as inputs and pulled to Vss - MCLR = VDD - · RTCC and JTAG are disabled - Voltage regulator is in Stand-by mode (VREGS = 0) - IOANCPEN (CFGCON<7>) = 0, I/O Analog Charge Pump disabled - AICPMPEN (ADCCON1><12>) = 0, ADC Input Charge Pump disabled - 2: Data in the "Typical" column is at 3.3V, 25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: The $\Delta$ current is the additional current consumed when the module is enabled. This current should be added to the base IPD current. - 4: Voltage regulator is operational (VREGS = 1) TABLE 37-9: DC CHARACTERISTICS: I/O PIN INPUT SPECIFICATIONS | | | | • | ting Condit | ions: 2.3V | to 3.6V | (unless otherwise | |---------------|--------|---------------------------------------------------------|-------------------------|---------------------|-------------|---------|-----------------------------------------------------------------------------------------------------------------| | DC CHA | RACTER | RISTICS | stated) Operating tempe | raturo | 10°C < T₄ < | - ±85°C | for Industrial | | | | | Operating tempe | | | | C for Extended | | Param.<br>No. | Symbol | Characteristics | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | DI10 | VIL | Input Low Voltage | | | | | | | | | I/O Pins with PMP | Vss | _ | 0.15 VDD | V | | | | | I/O Pins | Vss | _ | 0.2 VDD | V | | | | | SDAx, SCLx | Vss | _ | 0.3 VDD | V | SMBus disabled | | | | SDAx, SCLx | Vss | _ | 0.8 | V | SMBus enabled | | DI20 | VIH | Input High Voltage | | | | | | | | | I/O Pins not 5V-tolerant <sup>(5)</sup> | 0.65 VDD | _ | VDD | V | (Note 6) | | | | I/O Pins 5V-tolerant with PMP <sup>(5)</sup> | 0.25 VDD + 0.8V | _ | 5.5 | V | (Note 6) | | | | I/O Pins 5V-tolerant <sup>(5)</sup> | 0.65 VDD | | 5.5 | V | | | | | SDAx, SCLx | 0.65 VDD | | (Note 7) | V | SMBus disabled | | | | SDAx, SCLx | 2.1 | _ | (Note 7) | V | SMBus enabled,<br>2.3V = < VPIN = < 5.5 | | DI30 | ICNPU | Change Notification Pull-up Current | -450 | _ | -120 | μA | VDD = 3.3V, VPIN = VSS (Note 3, 6) | | DI31 | ICNPD | Change Notification<br>Pull-down Current <sup>(4)</sup> | 50 | _ | 450 | μΑ | VDD = 3.3V, VPIN = VDD | | | liL | Input Leakage Current (Note 3) | | | | | | | DI50 | | I/O Ports | -1 | _ | 1 | μΑ | Vss ≤ Vpin ≤ Vdd,<br>Pin at high-impedance | | DI51 | | ADC and VREF Input Pins | -1 | _ | 1 | μA | VSS ≤ VPIN ≤ VDD,<br>Pin at high-impedance | | DI53 | | Op amp Input Shared Pins | -35 | | 35 | μΑ | | | DI55 | | MCLR <sup>(2)</sup> | -1 | _ | 1 | μA | $Vss \le Vpin \le Vdd$ | | DI56 | | OSC1 | -1 | _ | 1 | μA | $\label{eq:VSS} \begin{aligned} &V\text{SS} \leq V\text{PIN} \leq V\text{DD}, \\ &\text{HS mode} \end{aligned}$ | - **Note 1:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. - 3: Negative current is defined as current sourced by the pin. - **4:** This parameter is characterized, but not tested in manufacturing. - 5: See the pin name tables (Table 3 and Table 5) for the 5V-tolerant pins. - **6:** The VIH specifications are only in relation to externally applied inputs, and not with respect to the user-selectable internal pull-ups. External open drain input signals utilizing the internal pull-ups of the PIC32 device are guaranteed to be recognized only as a logic "high" internally to the PIC32 device, provided that the external load does not exceed the minimum value of ICNPU. For External "input" logic inputs that require a pull-up source, to guarantee the minimum VIH of those components, it is recommended to use an external pull-up resistor rather than the internal pull-ups of the PIC32 device. - 7: VIH(max) for Non-5v tolerant I<sup>2</sup>C pin is VDD. VIH(max) for 5v tolerant I<sup>2</sup>C pins is 5.5v. TABLE 37-10: DC CHARACTERISTICS: I/O PIN INPUT INJECTION CURRENT SPECIFICATIONS | DC CHA | ARACTER | RISTICS | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) | | | | | | |---------------|---------|-----------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------|---------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Param.<br>No. | Symbol | Characteristics | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | DI60a | licl | Input Low Injection<br>Current | 0 | _ | <sub>-5</sub> (2,5) | mA | This parameter applies to all pins, with the exception of RB10. Maximum IICH current for this exception is 0 mA. | | | DI60b | ІІСН | Input High Injection<br>Current | 0 | _ | +5(3,4,5) | mA | This parameter applies to all pins, with the exception of all 5V tolerant pins, SOSCI, SOSCO, OSC1, OSC2, D-, D+, RTCC, and RB10. Maximum IICH current for these exceptions is 0 mA. | | | DI60c | ∑lict | Total Input Injection<br>Current (sum of all I/O<br>and control pins) | -20 <sup>(6)</sup> | _ | +20 <sup>(6)</sup> | mA | Absolute instantaneous sum of all $\pm$ input injection currents from all I/O pins ( IICL + IICH ) $\leq \sum$ IICT | | **Note 1:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 2: VIL source < (Vss 0.3). Characterized but not tested. - 3: VIH source > (VDD + 0.3) for non-5V tolerant pins only. - **4:** Digital 5V tolerant pins do not have an internal high side diode to VDD, and therefore, cannot tolerate any "positive" input injection current. - 5: Injection currents > | 0 | can affect the ADC results by approximately 4 to 6 counts (i.e., VIH Source > (VDD + 0.3) or VIL source < (Vss 0.3)). - **6:** Any number and/or combination of I/O pins not excluded under IICL or IICH conditions are permitted provided the "absolute instantaneous" sum of the input injection currents from all pins do not exceed the specified limit. If **Note 2**, IICL = (((Vss 0.3) VIL source) / Rs). If **Note 3**, IICH = ((IICH source (VDD + 0.3)) / RS). RS = Resistance between input source voltage and device pin. If (Vss 0.3) ≤ VSOURCE ≤ (VDD + 0.3), injection current = 0. ### TABLE 37-11: DC CHARACTERISTICS: I/O PIN OUTPUT SPECIFICATIONS | DC CHA | ARACT | ERISTICS | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | | |---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|-------------------------------------|--| | Param. | Sym. | Characteristic | Min. | Тур. | Max. | Units | Conditions | | | DO10 | Vol | Output Low Voltage I/O Pins 4x Sink Driver Pins - RA0, RA4, RA11, RA12, RA14, RA15 RB0-RB3, RB8, RB9 RC0, RC1, RC2, RC10, RC12, RC13 RD8, RD12-RD15 RE0, RE1, RE8, RE9 RF5, RF6, RF7, RF9, RF10, RF12, RF13 RG0, RG1, RG6-RG15 | _ | _ | 0.4 | V | IOL ≤ 10 mA, VDD = 3.3V | | | | | Output Low Voltage I/O Pins: 8x Sink Driver Pins - RA1, RA7, RA8, RA10 RB4-RB7, RB10-RB15 RC6, RC7, RC8, RC9, RC11, RC15 RD1-RD6 RE12-RE15 RF0, RF1 | _ | _ | 0.4 | V | $IOL \le 15 \text{ mA}, VDD = 3.3V$ | | | DO20 Vo | Vон | Output High Voltage I/O Pins: 4x Source Driver Pins - RA0, RA4, RA11, RA12, RA14, RA15 RB0-RB3, RB8, RB9 RC0, RC1, RC2, RC10, RC12, RC13 RD8, RD12-RD15 RE0, RE1, RE8, RE9 RF5, RF6, RF7, RF9, RF10, RF12, RF13 RG0, RG1, RG6-RG15 | 2.4 | | | > | Iон ≥ -10 mA, VDD = 3.3V | | | | | Output High Voltage I/O Pins: 8x Source Driver Pins - RA1, RA7, RA8, RA10 RB4-RB7, RB10-RB15 RC6, RC7, RC8, RC9, RC11, RC15 RD1-RD6 RE12-RE15 RF0, RF1 | 2.4 | _ | _ | V | IOH ≥ -15 mA, VDD = 3.3V | | ### TABLE 37-11: DC CHARACTERISTICS: I/O PIN OUTPUT SPECIFICATIONS (CONTINUED) | DC CHA | DC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | |-------------------------------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------|--------------------------|--| | Param. Sym. Characteristic Min. Typ. Max. Units | | | | | Conditions | | | | | | | Output High Voltage I/O Pins: 4x Source Driver Pins - | 1.5 | _ | _ | > | IOH ≥ -14 mA, VDD = 3.3V | | | | | RA0, RA4, RA11, RA12, RA14, RA15<br>RB0-RB3, RB8, RB9<br>RC0, RC1, RC2, RC10, RC12, RC13<br>RD8, RD12-RD15<br>RE0, RE1, RE8, RE9<br>RF5, RF6, RF7, RF9, RF10, RF12, RF13<br>RG0, RG1, RG6-RG15 | 2.0 | _ | _ | V | IOH ≥ -12 mA, VDD = 3.3V | | | DO20a | Vон1 | | 3.0 | _ | _ | > | IOH ≥ -7 mA, VDD = 3.3V | | | DO20a | VOHI | Output High Voltage I/O Pins: 8x Source Driver Pins - 8x Source Driver Pins - RA1, RA7, RA8, RA10 RB4-RB7, RB10-RB15 RC6, RC7, RC8, RC9, RC11, RC15 RD1-RD6 RE12-RE15 RF0, RF1 | 1.5 | | | ٧ | IOH ≥ -22 mA, VDD = 3.3V | | | | | | 2.0 | _ | _ | \<br>\ | IOH ≥ -18 mA, VDD = 3.3V | | | | | | 3.0 | _ | _ | ٧ | IOH ≥ -10 mA, VDD = 3.3V | | TABLE 37-12: DC CHARACTERISTICS: PROGRAM MEMORY(3) | DC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------------|-------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------|------------|------------|--|--| | Param.<br>No. | Sym. | Characteristics | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | D130 | ЕР | Cell Endurance | 20,000 | _ | _ | E/W | _ | | | | D131 | VPR | VDD for Read | VDDMIN | _ | VDDMAX | V | _ | | | | D132 | VPEW | VDD for Erase or Write | VDDMIN | _ | VDDMAX | V | _ | | | | D134 | TRETD | Characteristic Retention | 20 | _ | _ | Year | _ | | | | D135 | IDDP | Supply Current during<br>Programming | _ | _ | 30 | mA | _ | | | | D136 | Trw | Row Write Cycle Time (Note 2) | 16000 | _ | 20800 | FRC Cycles | _ | | | | D137 | Tqww | Quad Word Write Cycle Time | 650 | _ | 777 | FRC Cycles | _ | | | | D138 | Tww | Word Write Cycle Time | 265 | _ | 297 | FRC Cycles | _ | | | | D139 | TCE | Chip Erase Cycle Time | 384000 | _ | 480000 | FRC Cycles | _ | | | | D140 | TPFE | Combined Upper Plus Lower Flash<br>Panels Erase Cycle Time (both Boot<br>Flash excluded) | 256000 | | 320000 | FRC Cycles | - | | | | D141 | Трве | Single Panel Flash Erase Cycle<br>Time (either Upper or Lower Panel,<br>excluding both Boot Flash) | 128000 | _ | 160000 | FRC Cycles | _ | | | | D142 | TPGE | Page Erase Cycle Time | 32000 | _ | 160000 | FRC Cycles | _ | | | | D143 | TFLPU | NVM Power-up Delay | _ | _ | 10 | μs | _ | | | **Note 1:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. TABLE 37-13: DC CHARACTERISTICS: PROGRAM FLASH MEMORY WAIT STATES FOR ACTIVE HIGH-POWER MODE | DC CHARACTERISTICS | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | | |---------------------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Required Flash Wait DEVCFG0<9:8> States PFMWS<3:0> bits | | SYSCLK (MHz) | | | | | | | FECCCON<1:0> bits | 1 - Wait State | 0 < SYSCLK ≤ 110 MHz | | | | | | | (DEVCFG0<9:8>) = 0x1x<br>with ECC disabled | 2 - Wait State | 110 MHz < SYSCLK ≤ 120 MHz | | | | | | | FECCCON<1:0> bits | 1 - Wait State | 0 < SYSCLK ≤ 96 MHz | | | | | | | (DEVCFG0<9:8>) = 0x0x<br>with ECC enabled | 2 - Wait State | 96 MHz < SYSCLK ≤ 120 MHz | | | | | | <sup>2:</sup> The minimum SYSCLK for row programming is 4 MHz. **<sup>3:</sup>** Refer to the "PIC32 Flash Programming Specification" (DS60001145) for operating conditions during programming and erase cycles. # 37.2 AC Characteristics and Timing Parameters The information contained in this section defines PIC32MK GPK/MCM with CAN FD Family device AC characteristics and timing parameters. ### FIGURE 37-1: LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS ### TABLE 37-14: CAPACITIVE LOADING REQUIREMENTS ON OUTPUT PINS | IADEL . | IABLE 07-14: CAI ACTIVE ECADING REGUINENTO ON COTT OTT INC | | | | | | | | | | | |--------------------|------------------------------------------------------------|-----------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|--|--|--|--| | AC CHARACTERISTICS | | | (unles | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | | Param.<br>No. | Symbol | Characteristics | Min. Typ. <sup>(1)</sup> Max. Units Conditions | | | | | | | | | | DO56 | CL | All I/O pins | _ | _ | 50 | pF | _ | | | | | **Note 1:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. ### FIGURE 37-2: EXTERNAL CLOCK TIMING TABLE 37-15: EXTERNAL CLOCK TIMING REQUIREMENTS | AC CHA | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | |---------------|--------------------|--------------------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|-------------------------------------------------------|--|--|--|--| | Param.<br>No. | Symbol | Characteristics | Minimum | Typical <sup>(1)</sup> | Maximum | Units | Conditions | | | | | | OS10 | Fosc | External CLKI Frequency<br>(External clocks allowed only<br>in EC and ECPLL modes) | DC | 1 | 64 | MHz | EC (Note 2,3) | | | | | | OS13 | | Oscillator Crystal Frequency | 4 | _ | 32 | MHz | HS (Note 2,3) | | | | | | OS15 | | | 32 | 32.768 | 100 | kHz | SOSC crystal<br>ESR must be ≤<br>80K ohms (Note<br>2) | | | | | | OS20 | Tosc | Tosc = 1/Fosc | _ | | | | See parameter<br>OS10 for Fosc<br>value | | | | | | OS30 | TosL,<br>TosH | External Clock In (OSC1)<br>High or Low Time | 0.375 x Tosc | _ | 0.675 x Tosc | ns | EC (Note 2) | | | | | | OS31 | TosR,<br>TosF | External Clock In (OSC1)<br>Rise or Fall Time | _ | _ | 7.5 | ns | EC (Note 2) | | | | | | OS40 | Тоѕт | Oscillator Start-up Timer Period<br>(Only applies to HS, HSPLL,<br>and Sosc Clock Oscillator<br>modes) | _ | 1024 | _ | Tosc | (Note 2) | | | | | | OS41 | TFSCM | Primary Clock Fail Safe<br>Time-out Period | _ | 2 | _ | ms | (Note 2) | | | | | | OS42 | Gм | External Oscillator<br>Transconductance | _ | 16 | _ | mA/V | VDD = 3.3V,<br>TA = +25°C, HS<br>(Note 2) | | | | | Note 1: Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are characterized but are not tested. <sup>2:</sup> This parameter is characterized, but not tested in manufacturing. **<sup>3:</sup>** See parameter OS50 for PLL input frequency limitations. #### **TABLE 37-16: SYSTEM PLL TIMING REQUIREMENTS** | AC CHA | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | | |---------------|--------------------|----------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|----------------------------------------------|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Тур. | Max. | Units | Conditions | | | | OS50 | FIN | PLL Input Frequency Range | 5 | _ | 64 | MHz | _ | | | | OS51 | Fsys | System Frequency | DC | _ | 120 | MHz | USB module disabled | | | | | | | 30 | _ | 120 | MHz | USB module enabled | | | | OS52 | TLOCK | PLL Start-up Time (Lock Time) | _ | _ | 100 | μs | _ | | | | OS53 | DCLK | CLKO Stability <sup>(2)</sup><br>(Period Jitter or Cumulative) | -0.25 | _ | +0.25 | % | Measured over 100 ms period | | | | OS54 | FVco | PLL Vco Frequency Range | 350 | _ | 700 | MHz | FVco output frequency to PLLODIV output | | | | OS54a | FPLL | PLL Output Frequency Range | 10 | _ | 120 | MHz | PLLODIV output frequency range | | | | OS54b | FPLLI | VCO Input Frequency Range | 5 | | 64 | MHz | PLLIDIV output frequency range to FVco input | | | | OS55a | FPB | Peripheral Bus Frequency | DC | _ | 120 | MHz | For PBCLKx, 'x' ≠ 6 | | | | OS55b | | | DC | _ | 30 | MHz | For PBCLK6 | | | - Note 1: These parameters are characterized, but not tested in manufacturing. - 2: This jitter specification is based on clock-cycle by clock-cycle measurements. To get the effective jitter for individual time-bases on communication clocks, use the following formula: $$Effective Jitter = \frac{D_{CLK}}{\sqrt{\frac{PBCLKx}{CommunicationClock}}}$$ For example, if PBCLKx = 100 MHz and SPI bit rate = 50 MHz, the effective jitter is as follows: $$Effective Jitter = \frac{D_{CLK}}{\sqrt{\frac{100}{50}}} = \frac{D_{CLK}}{1.41}$$ ### **TABLE 37-17: INTERNAL FRC ACCURACY** | AC CHARACTERISTICS | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | |------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|---------------------|------------------|--|--|--| | Param.<br>No. | Characteristics | Min. | Тур. | Max. | Units | Conditions | | | | | Internal | FRC Accuracy @ 8.00 MH | z <sup>(1)</sup> | | | | | | | | | F20 | FRC | -4 | _ | +4 | % | 0°C ≤ TA ≤ +85°C | | | | | -5 — +5 % -40°C ≤ TA ≤ +125° | | | | | -40°C ≤ TA ≤ +125°C | | | | | Note 1: Frequency calibrated at 25°C and 3.3V. The TUN bits can be used to compensate for temperature drift. ### **TABLE 37-18: INTERNAL LPRC ACCURACY** | AC CHA | RACTERISTICS | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | |---------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|---|-------------------------------------------------------------|--|--|--| | Param.<br>No. | Characteristics | Min. Typ. Max. Units Conditions | | | | | | | | | Internal | LPRC @ 32.768 kHz <sup>(1)</sup> | | | | | | | | | | F21 | LPRC | -8 | _ | +8 | % | $0^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C}$ | | | | | | | -25 — +25 % -40°C ≤ TA ≤ +125°C | | | | | | | | Note 1: Change of LPRC frequency as VDD changes. ### **TABLE 37-19: INTERNAL BFRC ACCURACY** | AC CHARACTERISTICS | | (unless | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------------|-----------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|---------------------|--|--|--| | Param.<br>No. | Characteristics | Min. | Тур. | Max. | Units | Conditions | | | | | BF1 | BFRC | -20 | _ | 20 | % | -40°C ≤ Ta ≤ +125°C | | | | **Note 1:** These parameters are characterized but not tested. **TABLE 37-20: DATA EEPROM MEMORY** | AC CHA | ARACTERI | STICS | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |---------------|----------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--------|--------------------------------------------|--|--|--| | Param.<br>No. | Sym. | Characteristics <sup>(1)</sup> | Min. | Max. | Units | Comments | | | | | DE10 | ЕР | Effective Write/Erase Cell<br>Endurance | 160K | _ | Cycles | Specified at TA = +125° C | | | | | DE11 | TRETD | Characteristic Retention | 20 | _ | Year | _ | | | | | DE12 | TACC | Read Access Time | _ | 176 / PBCLK2<br>Frequency | ns | PBCLK2 =<br>(FSYSCLK / PBDIV<br>(PB2DIV<>) | | | | | DE13 | TDPD | Wake-up Time From Deep<br>Power-down to Any Operation | 10 | _ | μs | _ | | | | | DE14 | TPROG | Program Time | 20 | 53 | μs | _ | | | | | DE15 | TRCV | Program Recovery Time | 5 | _ | μs | _ | | | | | | | Page Erase Recovery Time | 50 | _ | μs | _ | | | | | DE16 | TERASE | Page Erase Time | _ | 20 | ms | _ | | | | | DE17 | TSCE | Bulk Erase Time | | 20 | ms | _ | | | | | DE18 | Trw | Latency to Next Operation After Program/Erase | 2 | _ | μs | _ | | | | | DE19 | TPUWRITE | Power-up to Read/Program/<br>Erase Operation | 12 | _ | μs | _ | | | | Note 1: Timings are for reference only and are not user-configurable. All timing is enforced by hardware. **TABLE 37-21: DATA EEPROM WAIT STATES** | DATA EE Wait States<br>EEWS<7:0> (CFGCON<7:0>) bits are Equal to: | PBCLK2<6:0> = (FSYSCLK / PB2DIV<6:0>) | |-------------------------------------------------------------------|---------------------------------------| | 0 | 0-39 MHz | | 1 | 40-59 MHz | | 2 | 60-79 MHz | | 3 | 80-97 MHz | | 4 | 98-117 MHz | | 5 | 118-120 MHz | **TABLE 37-22: COMPARATOR SPECIFICATIONS** | AC CHA | ARACTERIS | STICS | Standard Operating Conditions (Note 2): 3.0V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |---------------|-----------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|----------------------------------------------------------------------|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Тур. | Max. | Units | Comments | | | | CM30 | Vioff | Input Offset Voltage | -15 | _ | +15 | mV | _ | | | | CM31 | VICM | Input Common Mode<br>Voltage | AVss | _ | AVDD | V | _ | | | | CM36a | VHYST_01 | Input Hysteresis Voltage | 10 | 15 | 30 | mV | HYSSEL<1:0> (CMxCON<25:24>) = 10001 (Lowest) | | | | CM36b | VHYST_10 | Input Hysteresis Voltage | 15 | 30 | 45 | mV | HYSSEL<1:0> (CMxCON<25:24>) = '0b10 | | | | CM36c | VHYST_11 | Input Hysteresis Voltage | 25 | 45 | 65 | mV | HYSSEL<1:0> (CMxCON<25:24>) = '0b11 (Highest) | | | | CM37 | TRESP | Large Signal Response<br>Time | _ | _ | 50 | ns | _ | | | | CM38 | TSRESP | Small Signal Response<br>Time | _ | _ | 70 | ns | V <sub>CM</sub> = V <sub>DD</sub> /2; 100 mV step | | | | CM41 | VIN | Input Voltage Range | AVss | _ | AVDD | V | _ | | | | CM43 | Ton | Comparator Enabled to<br>Output Valid | _ | 10 | _ | μs | Comparator module is configured before setting the Comparator ON bit | | | | CM44 | TOFF | Disable to outputs disabled | _ | 100 | _ | ns | _ | | | | CM47 | CMRR | Common Mode Rejection Ratio | 39 | _ | _ | _ | _ | | | **Note 1:** These parameters are characterized but not tested. ### FIGURE 37-3: I/O TIMING CHARACTERISTICS TABLE 37-23: I/O TIMING REQUIREMENTS | IABLE 3 | ABLE 37-23: I/O TIMING REQUIREMENTS | | | | | | | | | | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|-------|------------|---------------|--|--| | AC CHAI | RACTERIS | STICS | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | | Param.<br>No. | Symbol | Characteris | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | | DO31 | TioR | Port Output Rise Time I/O Pins: 4x Source Driver Pins - RA0, RA4, RA11, RA12, R | A14, RA15, | l | _ | 9.5 | ns | CLOAD = 50 pF | | | | | RB0-RB3, RB8, RB9 RC0, RC1, RC2, RC10, RC RD8, RD12-RD15 RE0, RE1, RE8, RE9 RF5-RF7, RF9, RF10, RF1 RG0, RG1, RG6-RG15 Port Output Rise Time I/O Pins: 8x Source Driver Pins - Replace 8x Source Driver p RA1, RA7, RA8, RA10 RB4-RB7, RB10-RB15 RC6-RC9, RC11, RC15 RD1-RD6 RE12-RE15 RF0, RF1 | | | ı | _ | 6 | ns | CLOAD = 20 pF | | | | | | | pins with: | _ | _ | 8 | ns | CLOAD = 50 pF | | | | | | | | | _ | 6 | ns | CLOAD = 20 pF | | | **Note 1:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. 2: This parameter is characterized, but not tested in manufacturing. ### TABLE 37-23: I/O TIMING REQUIREMENTS (CONTINUED) | | - ( - / | | | | | | |--------------------|---------------------------------------------------------|--|--|--|--|--| | | Standard Operating Conditions: 2.3V to 3.6V | | | | | | | AC CHARACTERISTICS | (unless otherwise stated) | | | | | | | AC CHARACTERISTICS | Operating temperature -40°C ≤ TA ≤ +85°C for Industrial | | | | | | | | -40°C ≤ TA ≤ +125°C for Extended | | | | | | | Param.<br>No. | Symbol | Characteristics <sup>(2)</sup> | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | |---------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|------|---------------------|------|-------|---------------| | DO32 | TioF | Port Output Fall Time I/O Pins: 4x Source Driver Pins - RA0, RA4, RA11, RA12, RA14, RA15, | 1 | | 9.5 | ns | CLOAD = 50 pF | | | RB0-RB3, RB8, RB9<br>RC0, RC1, RC2, RC10, RC12, RC13<br>RD8, RD12-RD15<br>RE0, RE1, RE8, RE9<br>RF5-RF7, RF9, RF10, RF12, RF13<br>RG0, RG1, RG6-RG15 | | | | 6 | ns | CLOAD = 20 pF | | | | Port Output Fall Time<br>I/O Pins:<br>8x Source Driver Pins -<br>RA1, RA7, RA8, RA10<br>RB4-RB7, RB10-RB15 | | | 8 | ns | CLOAD = 50 pF | | | | RC6-RC9, RC11, RC15<br>RD1-RD6<br>RE12-RE15<br>RF0, RF1 | _ | | 6 | ns | CLOAD = 20 pF | | DI35 | TINP | INTx Pin High or Low Time | 5 | _ | _ | ns | _ | | DI40 | TRBP | CNx High or Low Time (input) | 5 | _ | _ | ns | _ | **Note 1:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. <sup>2:</sup> This parameter is characterized, but not tested in manufacturing. #### FIGURE 37-4: POWER-ON RESET TIMING CHARACTERISTICS Internal Voltage Regulator Enabled Clock Sources = (FRC, FRCDIV, FRCDIV16, FRCPLL, EC, ECPLL and LPRC) Internal Voltage Regulator Enabled Clock Sources = (HS, HSPLL, and Sosc) - Note 1: The power-up period will be extended if the power-up sequence completes before the device exits from BOR (VDD < VDDMIN). - 2: Includes interval voltage regulator stabilization delay. FIGURE 37-5: EXTERNAL RESET TIMING CHARACTERISTICS **TABLE 37-24: RESETS TIMING** | AC CHARACTERISTICS | | | | | | | | | | |--------------------|---------|--------------------------------------------------------------------------------------------------------------------------------|---|------------------------------|-----|----|------------|--|--| | Param.<br>No. | Symbol | pol Characteristics <sup>(1)</sup> Min. Typ. <sup>(2)</sup> Max. Units | | | | | Conditions | | | | SY00 | TPU | Power-up Period<br>Internal Voltage Regulator Enabled | _ | 400 | 600 | μS | _ | | | | SY02 | Tsysdly | System Delay Period: Time Required to Reload Device Configuration Fuses plus SYSCLK Delay before First instruction is Fetched. | _ | 1 μs +<br>8 SYSCLK<br>cycles | _ | _ | _ | | | | SY20 | TMCLR | MCLR Pulse Width (low) | 2 | _ | | μs | _ | | | | SY30 | TBOR | BOR Pulse Width (low) | _ | 1 | _ | μS | _ | | | **Note 1:** These parameters are characterized, but not tested in manufacturing. 2: Data in "Typ" column is at 3.3V, 25°C unless otherwise stated. Characterized by design but not tested. ### FIGURE 37-6: TIMER1-TIMER9 EXTERNAL CLOCK TIMING CHARACTERISTICS ### TABLE 37-25: TIMER1 EXTERNAL CLOCK TIMING REQUIREMENTS<sup>(1)</sup> | AC CHA | ARACTERIS' | TICS | (un | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | |---------------|---------------------------------|------------------------------------------------------------------------------------------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|------|----------------------------------------|----------------------------------------|---------------------------------------------|----|----------------------------------------| | Param.<br>No. | Symbol | Characteristics <sup>(2)</sup> | | Min. | | Тур. | Max. | Units | Conditions | | | | TA10 | ТтхН | TxCK<br>High Time | Synchronous, with prescaler | | | | [(12.5 ns or 1 TPBCLK3)<br>/N] + 20 ns | 1 | _ | ns | Must also meet parameter TA15 (Note 3) | | | | | Asynchronous, with prescaler | | 10 | _ | _ | ns | _ | | | | TA11 | TTXL TXCK Synchrono with presca | | | [(12.5 ns or 1 TPBCLK3)<br>/N] + 20 ns | | _ | ns | Must also meet parameter TA15 (Note 3) | | | | | | | Asynchror with presc | | | 10 | _ | _ | ns | _ | | | | TA15 | ТтхР | TxCK<br>Input Period | Synchrono with presc | | [(Greater of 20 ns or 2 TPBCLK3)/N] + 30 ns | _ | _ | ns | V <sub>DD</sub> > 2.7V<br>( <b>Note 3</b> ) | | | | | | | | | [(Greater of 20 ns or 2 TPBCLK3)/N] + 50 ns | _ | _ | ns | V <sub>DD</sub> < 2.7V<br>( <b>Note 3</b> ) | | | | | | | Asynchron | | 20 | _ | _ | ns | VDD > 2.7V | | | | | | | with presc | aler | 50 | _ | _ | ns | VDD < 2.7V | | | | OS60 | Fт1 | SOSCO/T1CK Oscillator<br>Input Frequency Range<br>(oscillator enabled by sett<br>TCS bit (T1CON<1>)) | | | 32 | _ | 50 | kHz | _ | | | | TA20 | TCKEXTMRL | Delay from E<br>Clock Edge t<br>Increment | | CK | _ | | 1 | TPBCLK3 | _ | | | Note 1: Timer1 is a Type A. 2: This parameter is characterized, but not tested in manufacturing. 3: N = Prescale Value (1, 8, 64, 256). TABLE 37-26: TIMER2-TIMER9 EXTERNAL CLOCK TIMING REQUIREMENTS Standard Operating Conditions: 2.3Vto 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | | Min. | Max. | Units | Cond | ditions | |---------------|-----------|--------------------------------|----------------------------------|-----------------------------------------------|------|---------|----------------------------------------|------------------------------------------------------| | TB10 | ТтхН | TxCK<br>High Time | Synchronous, with prescaler | [(12.5 ns or 1 TPBCLK3)<br>/N] + 25 ns | _ | | Must also<br>meet<br>parameter<br>TB15 | N = prescale<br>value<br>(1, 2, 4, 8,<br>16, 32, 64, | | TB11 | TTXL | TxCK<br>Low Time | Synchronous, with prescaler | [(12.5 ns or 1 TPBCLK3)<br>/N] + 25 ns | _ | ns | Must also<br>meet<br>parameter<br>TB15 | 256) | | TB15 | ТтхР | TxCK<br>Input | Synchronous, with prescaler | [(Greater of [(25 ns or 2 TPBCLK3)/N] + 30 ns | | ns | VDD > 2.7V | | | | | Period | | [(Greater of [(25 ns or 2 TPBCLK3)/N] + 50 ns | _ | ns | VDD < 2.7V | | | TB20 | TCKEXTMRL | - | External TxCK to Timer Increment | I | 1 | TPBCLK3 | - | | Note 1: These parameters are characterized, but not tested in manufacturing. ### FIGURE 37-7: INPUT CAPTURE (CAPx) TIMING CHARACTERISTICS ### TABLE 37-27: INPUT CAPTURE MODULE TIMING REQUIREMENTS AC CHARACTERISTICS Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Max. | Units | Coi | nditions | |---------------|--------|--------------------------------|-----------------------|------|-------|--------------------------------|----------------------------------------------------------------| | IC10 | TccL | ICx Input Low<br>Time | ((TPBCLKx/N) + 25 ns) | | ns | Must also meet parameter IC15. | x = 2 for IC1-IC9<br>x = 3 for IC10-IC16<br>N = prescale value | | IC11 | TccH | ICx Input High<br>Time | ((TPBCLKx/N) + 25 ns) | _ | ns | Must also meet parameter IC15. | (1, 4, 16) | | IC15 | TccP | ICx Input Period | ((TPBCLKx/N) + 50 ns) | _ | ns | _ | | Note 1: These parameters are characterized, but not tested in manufacturing. ### FIGURE 37-8: OUTPUT COMPARE MODULE (OCx) TIMING CHARACTERISTICS ### TABLE 37-28: OUTPUT COMPARE MODULE TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------------|--------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|-------|--------------------|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | OC10 | TccF | OCx Output Fall Time | | _ | _ | ns | See parameter DO32 | | | | OC11 | TccR | OCx Output Rise Time | _ | _ | _ | ns | See parameter DO31 | | | Note 1: These parameters are characterized, but not tested in manufacturing. 2: Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. #### FIGURE 37-9: OCx/PWM MODULE TIMING CHARACTERISTICS ### TABLE 37-29: SIMPLE OCx/PWM MODE TIMING REQUIREMENTS | AC CHAF | RACTERIST | rics | (unless | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated)<br>Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------|-----------|--------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|--|--|--| | Param<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min Typ. <sup>(2)</sup> Max Units Condition | | | | | | | | | OC15 | TFD | Fault Input to PWM I/O Change | _ | _ | 50 | ns | _ | | | | | OC20 | TFLT | Fault Input Pulse Width | 50 | _ | _ | ns | _ | | | | Note 1: These parameters are characterized, but not tested in manufacturing. **2:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. **TABLE 37-30: OP AMP SPECIFICATIONS** | AC CHA | RACTER | ISTICS | Standard Operating Conditions (see Note 2): 3.0V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | | |---------------|---------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--------------------------|----------------|-----------------------------------------------------------|--|--|--|--| | Param.<br>No. | Symbol | Characteristics | Min. | Typ. <sup>(1)</sup> | Max. | Units | Comments | | | | | | OA1 | VCMR | Common Mode Input<br>Voltage Range | AVss | _ | AVDD | V | _ | | | | | | OA2 | CMRR | Common Mode<br>Rejection Ratio | _ | 45 | _ | dB | VCM = AVDD/2 | | | | | | OA3 | Voffset | Op amp Offset Voltage | -5 | _ | +5 | mV | _ | | | | | | OA5 | ILKG | Input leakage current | _ | _ | See IIL in<br>Table 37-9 | nA | _ | | | | | | OA6 | Psrr | Power Supply Rejection<br>Ratio | 40<br>38<br>30 | 52<br>49<br>42 | _<br>_<br>_ | dB<br>dB<br>dB | @ 10 kHz<br>@ 100 kHz<br>@ 1 MHz | | | | | | OA7 | TDRIFT | Amplifier Input Offset<br>Drift | -15 | _ | +15 | μV/ºC | With temperature | | | | | | | | Amandifian Outrout | AVss - 0.300 | _ | _ | V | ISOURCE ≤ 10 mA | | | | | | OA8 | Vон | Amplifier Output<br>Voltage High | AVss - 0.1 | _ | _ | V | ISOURCE ≤ 500 µA | | | | | | | | Voltage Flight | AVss - 0.05 | _ | _ | V | ISOURCE ≤ 200 µA | | | | | | | | A 116 O 1 1 | _ | _ | AVDD + 0.300 | V | ISINK ≤ 10 mA | | | | | | OA9 | Vol | Amplifier Output<br>Voltage Low | _ | _ | AVDD + 0.1 | V | Isink ≤ 500 µA | | | | | | | | Voltage Low | _ | _ | AVDD -+0.05 | V | Isink ≤ 200 µA | | | | | | OA10 | Ton | Enable to Valid Output | _ | 10 | _ | μs | _ | | | | | | OA11 | Toff | Disable to Outputs<br>Disabled | _ | 100 | _ | ns | _ | | | | | | OA12 | los | Input Offset Current | | See IIL in<br>Table 37-9 | _ | _ | _ | | | | | | OA13 | lв | Input Bias Current | | See I <sub>I</sub> L in Table 37-9 | _ | _ | _ | | | | | | OA14 | SR | Slew Rate (Non-Low-<br>power mode) | 40.0 | _ | _ | V/µs | @ VOUT = 1.0 VPP,<br>VCM = AVDD/2,<br>AVDD = 3.3V | | | | | | OA14a | SR | Slew Rate (Low-power mode) | 3.7 | _ | _ | V/µs | @ VOUT = 1.0 VPP,<br>VCM = AVDD/2,<br>AVDD = 3.3V | | | | | | OA15 | Gвw | Gain Bandwidth | 48.4 | _ | _ | MHz | @ Vсм = AVDD/2<br>and AVDD > 3.0V | | | | | | OA15A | GBWLP | Gain Bandwidth Low-<br>power | 7.97 | _ | _ | MHz | @ Vcm = AVDD/2<br>and AVDD > 3.0V | | | | | | OA16 | Av | Gain | 2 | _ | _ | V/V | Minimum Op amp<br>stable gain in non-<br>unity gain mode. | | | | | | OA17 | Рм | Phase Margin | 34 | _ | _ | Degree<br>s | _ | | | | | **Note 1:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. <sup>2:</sup> Device is functional at VBORMIN < VDD < VDDMIN, but will have degraded performance. Device functionality is tested, but not characterized. Analog modules: ADC, Op amp/Comparator, and Comparator voltage reference, will have degraded performance. Refer to parameter BO10 in Table 37-5 for the minimum and maximum BOR values. TABLE 37-31: UNITY GAIN OP AMP TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------------|------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|--------|-----------------------------|--|--| | Param<br>No. | Symbol | Characteristics <sup>(2)</sup> | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | UG10 | SR | Slew Rate | 50 | _ | _ | V/µs | From 0.5V to 2.5V | | | | UG20 | Рм | Phase Margin | 65 | _ | l | Degree | | | | | UG30 | Gм | Gain Margin | 5.3 | _ | I | dB | | | | | UG40 | G <sub>B</sub> W | Gain Bandwidth | 29 | _ | _ | MHz | _ | | | | UG50 | VOFFSET | Opamp Offset Voltage | -8 | _ | 8 | mV | | | | | UG60 | PSRR | Power Supply Rejection Ratio | | 59 | | dB | Specified at 0 Hz | | | | UG70 | PEAK | Peak Gain | _ | _ | 1.1 | dB | Gain in excess of 1 (@6Mhz) | | | Note 1: Data in "Typ" column is at 3.3V, +25°C unless otherwise stated. <sup>2:</sup> All other specifications are identical to the regular op amp mode operation. <sup>3:</sup> Device is functional at VBORMIN < VDD < VDDMIN, but will have degraded performance. Device functionality is tested, but not characterized. Analog modules: ADC, op amp/Comparator, and Comparator voltage reference, will have degraded performance. Refer to parameter BO10 in Table 36-5 for the minimum and maximum BOR values. ### FIGURE 37-10: SPIX MODULE HOST MODE (CKE = 0) TIMING CHARACTERISTICS TABLE 37-32: SPIx HOST MODE (CKE = 0, SMP = 1) TIMING REQUIREMENTS | AC CHA | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |---------------|--------------------|--------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | | SP9a | Тѕск | SCKx Period (SPI1-2 only) | 22.7 | _ | _ | ns | (VDD = 3.3V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 0, SRCON1x.y = 0.<br>Dedicated SCK1 and SCK2 on<br>RB7 and RB6, respectively or PPS<br>remappable SPI onto pins RB5,<br>RA1, and RB15. | | | | | | | | _ | 35 | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 1, SRCON1x.y = 0.<br>Dedicated SCK1 and SCK2 on<br>RB7 and RB6, respectively or PPS<br>remappable SPI onto pins RB5,<br>RA1, and RB15. | | | | | | | | _ | 41 | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 0, SRCON1x.y = 1.<br>Dedicated SCK1 and SCK2 on<br>RB7 and RB6, respectively or PPS<br>remappable SPI onto pins RB5,<br>RA1, and RB15. | | | | | | | | _ | 47 | _ | ns | (VDD ≥ 3.0V and the SMP bit (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 1. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | Note 1: These parameters are characterized, but not tested in manufacturing. 3: Assumes 30 pF load on all SPIx pins. <sup>2:</sup> Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. TABLE 37-32: SPIX HOST MODE (CKE = 0, SMP = 1) TIMING REQUIREMENTS (CONTINUED) | AC CHA | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |---------------|--------------------|---------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | | SP9b | TSCK | SCKx Period (SPI3-6 only) | 35.7 | | | ns | (VDD = 3.3V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 0, SRCON1x.y = 0<br>All other remappable SPI pins not<br>contained in conditions for<br>parameter SP9a. Applies only to<br>SPI3-SPI6. | | | | | | | | _ | 64 | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 1, SRCON1x.y = 0<br>All other remappable SPI pins not<br>contained in conditions for<br>parameter SP9a. Applies only to<br>SPI3-SPI6. | | | | | | | | _ | 82 | _ | ns | (VDD ≥ 3.0V and the SMP bit (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 1. All other remappable SPI pins not contained in conditions for parameter SP9a. Applies only to SPI3-SPI6. | | | | | | | | _ | 97 | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 1, SRCON1x.y = 1<br>All other remappable SPI pins not<br>contained in conditions for<br>parameter SP9a. Applies only to<br>SPI3-SPI6. | | | | | SP10 | TscL | SCKx Output Low Time | Tsck/2 | _ | _ | ns | _ | | | | | SP11 | TscH | SCKx Output High Time SCKx Output Fall Time | Tsck/2 | _ | | ns | | | | | | SP20 | TscF | (Note 3) | _ | _ | _ | ns | See parameter DO32 | | | | | SP21 | TscR | SCKx Output Rise Time (Note 3) | _ | _ | _ | ns | See parameter DO31 | | | | | SP30 | TDOF | SDOx Data Output Fall Time (Note 3) | _ | _ | _ | ns | See parameter DO32 | | | | | SP31 | TDOR | SDOx Data Output Rise Time (Note 3) | 1 | _ | _ | ns | See parameter DO31 | | | | | SP35 | | SDOx Data Output Valid after | | _ | 7 | ns | VDD > 3.0V | | | | | Note 1: | | SCKx Edge | | | 10 | ns | VDD < 3.0V | | | | - **Note 1:** These parameters are characterized, but not tested in manufacturing. - 2: Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: Assumes 30 pF load on all SPIx pins. TABLE 37-32: SPIX HOST MODE (CKE = 0, SMP = 1) TIMING REQUIREMENTS (CONTINUED) | AC CHARACTERISTICS | | | (unles | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated)<br>Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | |--------------------|--------|-----------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|---|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. Typ. <sup>(2)</sup> Max. Units Conditions | | | | | | | SP40 | | Setup Time of SDIx Data<br>Input to SCKx Edge | 5 | _ | _ | ns | _ | | | SP41 | | Hold Time of SDIx Data Input to SCKx Edge | 5 | _ | | ns | _ | | Note 1: These parameters are characterized, but not tested in manufacturing. <sup>2:</sup> Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. <sup>3:</sup> Assumes 30 pF load on all SPIx pins. ### FIGURE 37-11: SPIX MODULE HOST MODE (CKE = 1) TIMING CHARACTERISTICS TABLE 37-33: SPIX MODULE HOST MODE (CKE = 1, SMP = 1) TIMING REQUIREMENTS | AC CHA | RACTERIS | TICS | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | |---------------|----------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Тур. <sup>(2)</sup> | Max. | Units | Conditions | | | | | SP9a | Тѕск | SCKx Period | 22.7 | | | ns | (VDD = 3.3V) and the SMP bit (SPIx-CON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 0. | | | | | | | | 22.7 | | | 110 | Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | | | | | _ | 27 | | ns | $(\text{VDD} \ge 3.0\text{V} \text{ and the SMP bit (SPIx-CON<9>} = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 0. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15.$ | | | | | | | | _ | 33 | _ | ns | $(VDD \ge 3.0V)$ and the SMP bit (SPIx-CON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 1. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | | | | | _ | 39 | _ | ns | $(\text{VDD} \geq 3.0\text{V}$ and the SMP bit (SPIx-CON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 1. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | Note 1: These parameters are characterized, but not tested in manufacturing. **<sup>2:</sup>** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. <sup>3:</sup> Assumes 10 pF load on all SPIx pins. TABLE 37-33: SPIX MODULE HOST MODE (CKE = 1, SMP = 1) TIMING REQUIREMENTS (CONTINUED) | AC CHARACTERISTICS | | | (unless | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | |--------------------|--------|----------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | | | SP9b | Тѕск | SCKx Period | 35.7 | _ | | ns | (VDD = 3.3V and the SMP bit (SPIx-CON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 0. All other remappable SPI pins not contained in conditions for parameter SP9a. | | | | | | | | | _ | 41 | - | ns | (VDD ≥ 3.0V and the SMP bit (SPIx-CON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 0. All other remappable SPI pins not contained in conditions for parameter SP9a. | | | | | | | | | _ | 59 | _ | ns | $(VDD \ge 3.0V)$ and the SMP bit (SPIx-CON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 1. All other remappable SPI pins not contained in conditions for parameter SP9a. | | | | | | | | | _ | 74 | 1 | ns | $(VDD \ge 3.0V)$ and the SMP bit (SPIx-CON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 1. All other remappable SPI pins not contained in conditions for parameter SP9a. | | | | | | SP10 | TscL | SCKx Output Low Time | Tsck/2 | _ | _ | ns | _ | | | | | | SP11 | TscH | SCKx Output High Time | Tsck/2 | _ | _ | ns | _ | | | | | | SP20 | TscF | SCKx Output Fall Time (Note 3) | _ | _ | _ | ns | See parameter DO32 | | | | | | SP21 | TscR | SCKx Output Rise Time (Note 3) | _ | _ | _ | ns | See parameter DO31 | | | | | | SP30 | TDOF | SDOx Data Output Fall<br>Time (Note 3) | _ | _ | _ | ns | See parameter DO32 | | | | | | SP30a | Тѕск | SCKx Period | 20 | _ | _ | ns | Dedicated SCK1 and SCK2 on RB7<br>and RB6, respectively or PPS<br>remappable SPI onto pins RB5,<br>RA1, and RB15. | | | | | | SP30b | | | 40 | _ | _ | ns | All other remappable SPI pins not contained in conditions for parameter SP9a. | | | | | - Note 1: These parameters are characterized, but not tested in manufacturing. - **2:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: Assumes 10 pF load on all SPIx pins. TABLE 37-33: SPIX MODULE HOST MODE (CKE = 1, SMP = 1) TIMING REQUIREMENTS (CONTINUED) | AC CHARACTERISTICS | | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated)<br>Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------------|----------------------|-------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | | SP31 | TDOR | SDOx Data Output Rise<br>Time (Note 3) | 1 | | 1 | ns | See parameter DO31 | | | | | SP35 | TscH2DoV, | SDOx Data Output Valid after SCKx Edge | | _ | 7 | ns | VDD > 2.7V | | | | | | TscL2doV | | | | 10 | | VDD < 2.7V | | | | | SP36 | TDOV2SC,<br>TDOV2SCL | SDOx Data Output<br>Setup to First SCKx<br>Edge | 7 | _ | _ | ns | _ | | | | | SP40 | TDIV2scH, | Setup Time of SDIx Data | 7 | _ | | ns | VDD > 2.7V | | | | | | TDIV2scL | Input to SCKx Edge | 10 | | | | VDD < 2.7V | | | | | SP41 | TscH2DIL, | Hold Time of SDIx Data | 7 | | | ns | VDD > 2.7V | | | | | | TscL2DIL | Input to SCKx Edge | 10 | _ | _ | ns | VDD < 2.7V | | | | Note 1: These parameters are characterized, but not tested in manufacturing. **<sup>2:</sup>** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. <sup>3:</sup> Assumes 10 pF load on all SPIx pins. TABLE 37-34: SPIx MODULE CLIENT MODE (CKE = 0, SMP = 1) TIMING REQUIREMENTS | AC CHARACTERISTICS | | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | | | |--------------------|--------|--------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | | SP9a | Tsck | SCKx Period | 20 | | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 0, SRCON1x.y = 0<br>Dedicated SCK1 and SCK2 on<br>RB7 and RB6, respectively or PPS<br>remappable SPI onto pins RB5, | | | | | | | | 27 | _ | _ | ns | RA1, and RB15. (VDD ≥ 3.0V and the SMP bit (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 0 Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | | | | | 33 | | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 0, SRCON1x.y = 1<br>Dedicated SCK1 and SCK2 on<br>RB7 and RB6, respectively or PPS<br>remappable SPI onto pins RB5,<br>RA1, and RB15. | | | | | | | | 39 | _ | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 1, SRCON1x.y = 1<br>Dedicated SCK1 and SCK2 on<br>RB7 and RB6, respectively or PPS<br>remappable SPI onto pins RB5,<br>RA1, and RB15. | | | | Note 1: These parameters are characterized, but not tested in manufacturing. 3: Assumes 10 pF load on all SPIx pins. **<sup>2:</sup>** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. TABLE 37-34: SPIX MODULE CLIENT MODE (CKE = 0, SMP = 1) TIMING REQUIREMENTS (CONTINUED) | AC CHA | AC CHARACTERISTICS | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | | | | |---------------|-----------------------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | | SP9b | Тѕск | SCKx Period | 22 | _ | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 0, SRCON1x.y = 0<br>All other remappable SPI pins not | | | | | | | | | | | | contained in conditions for parameter SP9a. | | | | | | | | 41 | ı | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 1, SRCON1x.y = 0<br>All other remappable SPI pins not<br>contained in conditions for<br>parameter SP9a. | | | | | | | | 59 | I | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 0, SRCON1x.y = 1<br>All other remappable SPI pins not<br>contained in conditions for<br>parameter SP9a. | | | | | | | | 74 | ı | _ | ns | (VDD ≥ 3.0V and the SMP bit<br>(SPIxCON<9> = 1), I/O Pin Slew<br>Rate Control (x = A-F, y = port pin),<br>SRCON0x.y = 1, SRCON1x.y = 1<br>All other remappable SPI pins not<br>contained in conditions for<br>parameter SP9a. | | | | | SP70 | TscL | SCKx Input Low Time | Tsck/2 | _ | _ | ns | _ | | | | | SP71 | TscH | SCKx Input High Time | Tsck/2 | _ | _ | ns | _ | | | | | SP72 | TscF | SCKx Input Fall Time | | _ | | ns | See parameter DO32 | | | | | SP73 | TscR | SCKx Input Rise Time | - | | | ns | See parameter DO31 | | | | | SP30 | TDOF | SDOx Data Output Fall<br>Time<br>(Note 3) | _ | _ | _ | ns | See parameter DO32 | | | | | SP31 | TDOR | SDOx Data Output Rise<br>Time (Note 3) | _ | _ | _ | ns | See parameter DO31 | | | | | SP35 | TscH2DoV,<br>TscL2DoV | SDOx Data Output Valid<br>after SCKx Edge | | _ | 7 | ns | VDD > 2.7V | | | | | SP40 | TDIV2scH,<br>TDIV2scL | Setup Time of SDIx Data Input to SCKx Edge | 5 | _ | 10<br>— | ns<br>ns | VDD < 2.7V — | | | | | SP41 | TscH2DIL,<br>TscL2DIL | Hold Time of SDIx Data Input to SCKx Edge | 5 | _ | _ | ns | _ | | | | - **Note 1:** These parameters are characterized, but not tested in manufacturing. - 2: Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: Assumes 10 pF load on all SPIx pins. TABLE 37-34: SPIx MODULE CLIENT MODE (CKE = 0, SMP = 1) TIMING REQUIREMENTS (CONTINUED) | | REGULTATO (CONTINOED) | | | | | | | | | | | |--------------------|-----------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|----|---|--|--|--|--| | AC CHAPACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | | | | | | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. Typ. <sup>(2)</sup> Max. Units Conditions | | | | | | | | | | SP50 | TssL2scH,<br>TssL2scL | SSx ↓ to SCKx ↑ or SCKx<br>Input | 88 | _ | | ns | _ | | | | | | SP51 | TssH2DoZ | SSx ↑ to SDOx Output<br>High-Impedance | 2.5 | _ | 12 | ns | _ | | | | | | SP52 | TscH2ssH<br>TscL2ssH | SSx after SCKx Edge | 10 | | | ns | | | | | | Note 1: These parameters are characterized, but not tested in manufacturing. **<sup>2:</sup>** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. <sup>3:</sup> Assumes 10 pF load on all SPIx pins. TABLE 37-35: SPIx MODULE CLIENT MODE (CKE = 1, SMP = 1) TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | |--------------------|--------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | SP9a | TSCK | SCKx Period | 20 | _ | _ | ns | (VDD ≥ 3.0V and the SMP bit (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 0. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | | 27 | _ | _ | ns | $(VDD \ge 3.0V)$ and the SMP bit $(SPIxCON<9>=1)$ , I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 0. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | | 33 | _ | _ | ns | $(VDD \ge 3.0V)$ and the SMP bit $(SPIxCON < 9 > = 1)$ , I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 1. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | | | | | 39 | _ | _ | ns | $(VDD \ge 3.0V)$ and the SMP bit $(SPIxCON < 9 > = 1)$ , $I/O$ Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 1. Dedicated SCK1 and SCK2 on RB7 and RB6, respectively or PPS remappable SPI onto pins RB5, RA1, and RB15. | Note 1: These parameters are characterized, but not tested in manufacturing. **<sup>2:</sup>** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. <sup>3:</sup> Assumes 10 pF load on all SPIx pins. TABLE 37-35: SPIX MODULE CLIENT MODE (CKE = 1, SMP = 1) TIMING REQUIREMENTS (CONTINUED) Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) **AC CHARACTERISTICS** Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended Param. Characteristics<sup>(1)</sup> Typ.(2) **Symbol Conditions** Min. Max. **Units** No. SCKx Period (VDD ≥ 3.0V and the SMP bit SP9b Tsck (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 0. 22 ns All other remappable SPI pins not contained in conditions for parameter SP9a. (VDD $\geq$ 3.0V and the SMP bit (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 1, SRCON1x.y = 0. 41 All other remappable SPI pins not contained in conditions for parameter SP9a. $(VDD \ge 3.0V)$ and the SMP bit (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), SRCON0x.y = 0, SRCON1x.y = 1. 59 ns All other remappable SPI pins not contained in conditions for parameter SP9a. (VDD $\geq$ 3.0V and the SMP bit (SPIxCON<9> = 1), I/O Pin Slew Rate Control (x = A-F, y = port pin), 74 SRCON0x.y = 1, SRCON1x.y = 1. All other remappable SPI pins not contained in conditions for parameter SP9a. SP70 TscL SCKx Input Low Time Tsck/2 SP71 **TscH** SCKx Input High Time Tsck/2 ns SP72 **TscF** SCKx Input Fall Time 10 ns SP73 SCKx Input Rise Time 10 **TscR** ns SP30 **TDOF** SDOx Data Output Fall See parameter DO32 ns Time (Note 3) SP31 TDOR SDOx Data Output Rise See parameter DO31 ns Time (Note 3) SP35 SDOx Data Output Valid TscH2poV. 10 VDD > 2.7Vafter SCKx Edge TscL2poV 15 VDD < 2.7V ns SP40 TDIV2scH, Setup Time of SDIx Data n ns TDIV2scL Input to SCKx Edge SP41 TscH2DIL, Hold Time of SDIx Data ns TscL2<sub>DI</sub>L Input to SCKx Edge - Note 1: These parameters are characterized, but not tested in manufacturing. - **2:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: Assumes 10 pF load on all SPIx pins. TABLE 37-35: SPIX MODULE CLIENT MODE (CKE = 1, SMP = 1) TIMING REQUIREMENTS (CONTINUED) | | | CONTENED (CONTIN | <del>/</del> | | | | | | | |--------------------|-----------------------|----------------------------------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----|---|--|--| | AC CHARACTERISTICS | | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +85°C for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | | | | | | | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. Typ. <sup>(2)</sup> Max. Units Conditions | | | | | | | | SP50 | TssL2scH,<br>TssL2scL | SSx ↓ to SCKx ↓ or SCKx<br>↑ Input | 88 | _ | | ns | _ | | | | SP51 | TssH2DoZ | SSx ↑ to SDOx Output<br>High-Impedance ( <b>Note 3</b> ) | 2.5 | _ | 12 | ns | - | | | | SP52 | TscH2ssH<br>TscL2ssH | SSx ↑ after SCKx Edge | 10 | _ | _ | ns | _ | | | | SP60 | TssL2DoV | SDOx Data Output Valid<br>after<br>SSx Edge | _ | _ | 12.5 | ns | _ | | | - Note 1: These parameters are characterized, but not tested in manufacturing. - **2:** Data in the "Typ" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: Assumes 10 pF load on all SPIx pins. #### FIGURE 37-14: I2Cx BUS START/STOP BITS TIMING CHARACTERISTICS (HOST MODE) #### FIGURE 37-15: I2Cx BUS DATA TIMING CHARACTERISTICS (HOST MODE) | TABLE | 37-36: | 12CX BUS DATA | TIMING REQU | JIREMENTS (HOS | ST MOD | E) | | | | |---------------|---------|------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|--------------------------------|--|--| | AC CHA | RACTER | ISTICS | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for Commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial $-40^{\circ}C \le TA \le +105^{\circ}C$ for V-temp | | | | | | | Param.<br>No. | Symbol | Charact | eristics | Min. <sup>(1)</sup> | Max. | Units | Conditions | | | | IM10 | TLO:SCL | Clock Low Time | 100 kHz mode | Трв * (BRG + 2) | _ | μS | _ | | | | | | | 400 kHz mode | Трв * (BRG + 2) | _ | μS | _ | | | | | | 1 MHz mode<br>(Note 2) | Трв * (BRG + 2) | _ | μs | _ | | | | | IM11 | THI:SCL | Clock High Time | 100 kHz mode | TPB * (BRG + 2) | _ | μS | _ | | | | | | | 400 kHz mode | Трв * (BRG + 2) | _ | μS | _ | | | | | | | 1 MHz mode (Note 2) | Трв * (BRG + 2) | _ | μs | _ | | | | IM20 | TF:SCL | SDAx and SCLx | 100 kHz mode | _ | 300 | ns | CB is specified to be | | | | | | Fall Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | from 10 to 400 pF | | | | | | | 1 MHz mode (Note 2) | _ | 100 | ns | | | | | IM21 | TR:SCL | SDAx and SCLx | 100 kHz mode | _ | 1000 | ns | CB is specified to be | | | | | | Rise Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | from 10 to 400 pF | | | | | | | 1 MHz mode (Note 2) | _ | 300 | ns | | | | | IM25 | TSU:DAT | Data Input | 100 kHz mode | 250 | _ | ns | _ | | | | | | Setup Time | 400 kHz mode | 100 | _ | ns | | | | | | | | 1 MHz mode (Note 2) | 100 | _ | ns | | | | | IM26 | THD:DAT | Data Input | 100 kHz mode | 0 | _ | μS | _ | | | | | | Hold Time | 400 kHz mode | 0 | 0.9 | μS | | | | | | | | 1 MHz mode (Note 2) | 0 | 0.3 | μS | | | | | IM30 | Tsu:sta | Start Condition | 100 kHz mode | TPB * (BRG + 2) | _ | μS | Only relevant for | | | | | | Setup Time | 400 kHz mode | Трв * (BRG + 2) | _ | μS | Repeated Start condition | | | | | | | 1 MHz mode (Note 2) | Трв * (BRG + 2) | _ | μS | Condition | | | | IM31 | THD:STA | Start Condition | 100 kHz mode | Трв * (BRG + 2) | _ | μS | After this period, the | | | | | | Hold Time | 400 kHz mode | Трв * (BRG + 2) | _ | μS | first clock pulse is generated | | | | | | | 1 MHz mode<br>(Note 2) | Трв * (BRG + 2) | _ | μS | generateu | | | | IM33 | Tsu:sto | Stop Condition | 100 kHz mode | Трв * (BRG + 2) | _ | μS | _ | | | | | | Setup Time | 400 kHz mode | Трв * (BRG + 2) | _ | μS | | | | | | | | 1 MHz mode (Note 2) | Трв * (BRG + 2) | _ | μS | | | | **Note 1:** BRG is the value of the I<sup>2</sup>C Baud Rate Generator. 3: The typical value for this parameter is 104 ns. <sup>2:</sup> Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). | <b>TABLE</b> | 37-36: | I2CX BUS DAT | A TIMING REQU | JIREMENTS (HOS | ST MOD | E) (CON | TINUED) | | | |---------------|---------|------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|----------------------------------------|--|--| | AC CHA | ARACTER | ISTICS | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for Commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial $-40^{\circ}C \le TA \le +105^{\circ}C$ for V-temp | | | | | | | Param.<br>No. | Symbol | Charac | teristics | Min. <sup>(1)</sup> | Max. | Units | Conditions | | | | IM34 | THD:STO | Stop Condition | 100 kHz mode | Трв * (BRG + 2) | _ | ns | _ | | | | | | Hold Time | 400 kHz mode | Трв * (BRG + 2) | _ | ns | | | | | | | | 1 MHz mode<br>(Note 2) | ТРВ * (BRG + 2) | _ | ns | | | | | IM40 | TAA:SCL | Output Valid | 100 kHz mode | _ | 3500 | ns | _ | | | | | | from Clock | 400 kHz mode | _ | 1000 | ns | _ | | | | | | | 1 MHz mode<br>(Note 2) | _ | 350 | ns | _ | | | | IM45 | TBF:SDA | Bus Free Time | 100 kHz mode | 4.7 | _ | μS | The amount of time the | | | | | | | 400 kHz mode | 1.3 | _ | μS | bus must be free | | | | | | | 1 MHz mode<br>(Note 2) | 0.5 | _ | μS | before a new<br>transmission can start | | | | IM50 | Св | Bus Capacitive Loading | | _ | 400 | pF | _ | | | | IM51 | TPGD | Pulse Gobbler D | elay | 52 | 312 | ns | See Note 3 | | | **Note 1:** BRG is the value of the I<sup>2</sup>C Baud Rate Generator. 2: Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). **3:** The typical value for this parameter is 104 ns. #### FIGURE 37-16: I2Cx BUS START/STOP BITS TIMING CHARACTERISTICS (CLIENT MODE) #### FIGURE 37-17: I2Cx BUS DATA TIMING CHARACTERISTICS (CLIENT MODE) #### FIGURE 37-18: QEI MODULE EXTERNAL CLOCK TIMING CHARACTERISTICS | TABLE | 37-37: I2 | Cx BUS DATA 1 | IMING REQUIR | EMENTS (CL | IENT N | MODE) | | | | |---------------|-----------|-----------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|--------------------------------------------|--|--| | AC CHA | RACTERIS | STICS | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) $ \begin{array}{ll} \text{Operating temperature} & 0^{\circ}\text{C} \leq \text{TA} \leq +70^{\circ}\text{C} \text{ for Commercia} \\ -40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C for Industrial} \\ -40^{\circ}\text{C} \leq \text{TA} \leq +105^{\circ}\text{C for V-temp} \end{array} $ | | | | | | | Param.<br>No. | Symbol | Charact | teristics | Min. | Max. | Units | Conditions | | | | IS10 | TLO:SCL | Clock Low Time | 100 kHz mode | 4.7 | _ | μs | PBCLK must operate at a minimum of 800 kHz | | | | | | | 400 kHz mode | 1.3 | _ | μS | PBCLK must operate at a minimum of 3.2 MHz | | | | | | | 1 MHz mode (Note 1) | 0.5 | _ | μS | _ | | | | IS11 | THI:SCL | Clock High Time | 100 kHz mode | 4.0 | _ | μS | PBCLK must operate at a minimum of 800 kHz | | | | | | | 400 kHz mode | 0.6 | _ | μS | PBCLK must operate at a minimum of 3.2 MHz | | | | | | | 1 MHz mode (Note 1) | 0.5 | _ | μS | _ | | | | IS20 | TF:SCL | SDAx and SCLx | 100 kHz mode | _ | 300 | ns | CB is specified to be from | | | | | | Fall Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | 10 to 400 pF | | | | | | | 1 MHz mode (Note 1) | _ | 100 | ns | | | | | IS21 | TR:SCL | SDAx and SCLx | 100 kHz mode | _ | 1000 | ns | CB is specified to be from | | | | | | Rise Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | 10 to 400 pF | | | | | | | 1 MHz mode (Note 1) | _ | 300 | ns | | | | | IS25 | TSU:DAT | Data Input | 100 kHz mode | 250 | _ | ns | _ | | | | | | Setup Time | 400 kHz mode | 100 | | ns | | | | | | | | 1 MHz mode (Note 1) | 100 | _ | ns | | | | | IS26 | THD:DAT | Data Input | 100 kHz mode | 0 | _ | ns | _ | | | | | | Hold Time | 400 kHz mode | 0 | 0.9 | μS | | | | | | | | 1 MHz mode (Note 1) | 0 | 0.3 | μS | | | | | IS30 | Tsu:sta | Start Condition | 100 kHz mode | 4700 | | ns | Only relevant for Repeated | | | | | | Setup Time | 400 kHz mode | 600 | | ns | Start condition | | | | | | | 1 MHz mode (Note 1) | 250 | _ | ns | | | | | IS31 | THD:STA | Start Condition | 100 kHz mode | 4000 | _ | ns | After this period, the first | | | | | | Hold Time | 400 kHz mode | 600 | _ | ns | clock pulse is generated | | | | | | | 1 MHz mode (Note 1) | 250 | _ | ns | | | | | IS33 | Tsu:sto | Stop Condition | 100 kHz mode | 4000 | | ns | | | | | | | Setup Time | 400 kHz mode | 600 | _ | ns | ] | | | | | | | 1 MHz mode (Note 1) | 600 | _ | ns | | | | **Note 1:** Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). | TABLE | 37-37: I2 | Cx BUS DATA T | IMING REQUIR | EMENTS (C | LIENT I | MODE) | (CONTINUED) | |---------------|-----------|-------------------------|------------------------|-------------------------------------------|----------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | AC CHA | RACTERIS | STICS | | Standard O<br>(unless oth<br>Operating te | erwise s | tated)<br>re 0°C<br>-40° | ons: 2.3V to 3.6V<br>$\leq$ TA $\leq$ +70°C for Commercial<br>C $\leq$ TA $\leq$ +85°C for Industrial<br>C $\leq$ TA $\leq$ +105°C for V-temp | | Param.<br>No. | Symbol | Charact | eristics | Min. | Max. | Units | Conditions | | IS34 | THD:STO | Stop Condition | 100 kHz mode | 4000 | _ | ns | _ | | | | Hold Time | 400 kHz mode | 600 | _ | ns | | | | | | 1 MHz mode<br>(Note 1) | 250 | | ns | | | IS40 | TAA:SCL | Output Valid from Clock | 100 kHz mode | 0 | 3500 | ns | _ | | | | | 400 kHz mode | 0 | 1000 | ns | | | | | | 1 MHz mode<br>(Note 1) | 0 | 350 | ns | | | IS45 | TBF:SDA | Bus Free Time | 100 kHz mode | 4.7 | _ | μS | The amount of time the bus | | | | | 400 kHz mode | 1.3 | _ | μs | must be free before a new | | | | | 1 MHz mode<br>(Note 1) | 0.5 | _ | μS | transmission can start | | IS50 | Св | Bus Capacitive Lo | Bus Capacitive Loading | | | pF | _ | Note 1: Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). #### TABLE 37-38: QEI MODULE EXTERNAL CLOCK TIMING REQUIREMENTS | AC CHA | ARACTERIST | rics | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated)<br>Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------|------------|----------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------|------|-------|-------------------------------------------------------------------------------|--| | Param<br>No. | Symbol | Characte | ristic <sup>(1)</sup> | | Min. | Тур. | Max. | Units | Conditions | | | TQ10 | TtQH | TQCK High Time | Synchron<br>with pres | | [(12.5 or<br>0.5 Tcy) / N]<br>+ 25 | | | ns | Must also meet parameter TQ15. N = 1, 2, 4, 16, 32, 64, 128 and 256 (Note 2) | | | TQ11 | TtQL | TQCK Low Time | Synchron with pres | | [(12.5 or<br>0.5 Tcy) / N]<br>+ 25 | | | ns | Must also meet parameter TQ15. N = 1, 2, 4, 16, 32, 64, 128 and 256 (Note 2) | | | TQ15 | TtQP | TQCP Input<br>Period | Synchron<br>with pres | | [(25 or Tcy)<br>/ N] + 50 | _ | _ | ns | N = 1, 2, 4, 16,<br>32, 64, 128 and<br>256 (Note 2) | | | TQ20 | TCKEXTMRL | Delay from Extern<br>Edge to Timer Inc | | Clock | _ | 1 | Tcy | _ | _ | | Note 1: These parameters are characterized but not tested in manufacturing. <sup>2:</sup> N = Index Channel Digital Filter Clock Divide Select bits. FIGURE 37-19: QEA/QEB INPUT CHARACTERISTICS TABLE 37-39: QUADRATURE DECODER TIMING REQUIREMENTS | AC CHARACTERISTICS | | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------------|--------------------------------------------------------|--------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-----------------------------------------------------------|--|--|--| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | | TQ30 | TQUL | Quadrature Input Low Time | | 6 Tcy | _ | ns | _ | | | | | TQ31 | TquH | Quadrature Input High Time | | 6 Tcy | _ | ns | _ | | | | | TQ35 | TquIN | Quadrature Input Period | | 12 Tcy | _ | ns | _ | | | | | TQ36 | TQUP | Quadrature Phase Period | | 3 Tcy | _ | ns | _ | | | | | TQ40 | TQUFL Filter Time to Recognize Low with Digital Filter | | | 3 * N * Tcy | _ | ns | N = 1, 2, 4, 16, 32, 64,<br>128 and 256 ( <b>Note 3</b> ) | | | | | TQ41 | TQUFH | Filter Time to Recognize Hig with Digital Filter | h, | 3 * N * Tcy | _ | ns | N = 1, 2, 4, 16, 32, 64, 128 and 256 (Note 3) | | | | - **Note 1:** These parameters are characterized but not tested in manufacturing. - 2: Data in "Typ" column is at 3.3V, 25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 3: N = Index Channel Digital Filter Clock Divide Select bits. #### FIGURE 37-20: CANX MODULE I/O TIMING CHARACTERISTICS #### TABLE 37-40: CANX MODULE I/O TIMING REQUIREMENTS | AC CHARA | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------|---------------------|------|-------|--------------------| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | CA10 | TioF | Port Output Fall Time | _ | _ | _ | ns | See parameter DO32 | | CA11 | TioR | Port Output Rise Time | _ | _ | _ | ns | See parameter DO31 | | CA20 | Tcwf | Pulse Width to Trigger CAN Wake-up Filter | 700 | _ | _ | ns | _ | - Note 1: These parameters are characterized but not tested in manufacturing. - 2: Data in "Typ" column is at 3.3V, 25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - **3:** CAN module wake from sleep could take up to 300us worst case. Multiple CAN messages could therefore be missed depending on the USER CAN baud rate. #### **TABLE 37-41: ADC MODULE SPECIFICATIONS** | | | ADC MODULE SPECIF | Standard Op | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) | | | | | | | | |---------------|------------|-----------------------------------------------|-----------------------------------|-----------------------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|--|--|--| | AC CHA | ARACTERI | STICS | Operating ter | | -40°C ≤ TA | $-40^{\circ}$ C $\leq$ TA $\leq$ +85 $^{\circ}$ C for Industrial $-40^{\circ}$ C $\leq$ TA $\leq$ +125 $^{\circ}$ C for Extended | | | | | | | Param.<br>No. | Symbol | Characteristics | Min. | Тур. | Max. | Units | Conditions | | | | | | Device 3 | Supply | | | | | | | | | | | | AD01 | AVDD | Module VDD Supply | Greater of<br>VDD – 0.3<br>or 2.3 | _ | Lesser of<br>VDD + 0.3<br>or 3.6 | V | _ | | | | | | AD02 | AVss | Module Vss Supply | Vss | | Vss + 0.3 | V | _ | | | | | | | ce Inputs | T | 1 | | | | I | | | | | | AD05 | VREFH | Reference Voltage High | | | AVDD | V | (Note 1) | | | | | | AD06 | VREFL | Reference Voltage Low | AVss | | VREFH – 1.8 | V | (Note 1) | | | | | | AD07 | VREF | Absolute Reference<br>Voltage (VREFH – VREFL) | 1.8 | _ | AVDD | ٧ | (Note 2) | | | | | | AD08 | IREF | Current Drain | _ | 102 | _ | μA | ADC is operating or is in Stand-by. | | | | | | | IVREF | Bandgap Reference | 1.145 | 1.2 | 1.255 | μΑ | | | | | | | Analog | Input | | | | | | | | | | | | AD12 | VINH-VINL | Full-Scale Input Span | VREFL | _ | VREFH | V | _ | | | | | | AD13 | VINL | Absolute VINL Input Voltage | AVss | _ | VREFL | V | _ | | | | | | AD14 | VINH | Absolute VINH Input Voltage | AVss | _ | VREFH | V | _ | | | | | | ADC Ac | curacy - N | Measurements with Exte | rnal VREF+/V | REF- | | | | | | | | | AD20c | Nr | Resolution | 6 | _ | 12 | bits | Selectable 6, 8, 10, 12<br>Resolution Ranges | | | | | | AD21c | INL | Integral Nonlinearity | -5 | ±0.67 | 5 | LSb | VINL = AVSS = VREFL = 0V,<br>AVDD = VREFH = 3.3V | | | | | | AD22c | DNL | Differential Nonlinearity | -1 | +1.28 | 3.5 | LSb | VINL = AVSS = VREFL = 0V,<br>AVDD = VREFH = 3.3V | | | | | | AD23c | GERR | Gain Error | -8 | 1.316 | 8 | LSb | VINL = AVSS = VREFL = 0V,<br>AVDD = VREFH = 3.3V. Gain<br>error includes offset error. | | | | | | AD24c | EOFF | Offset Error | -5 | -1.175 | 5 | LSb | VINL = AVSS = 0V,<br>AVDD = 3.3V | | | | | | AD25c | _ | Monotonicity | _ | _ | _ | _ | Guaranteed (Note 2) | | | | | | Dynami | c Perform | ance | | | | | | | | | | | AD31b | SINAD | Signal to Noise and Distortion | _ | 59 | _ | dB | Single-ended (Notes 2,3) | | | | | | AD34b | ENOB | Effective Number of bits | _ | 9.64 | _ | bits | (Notes 2,3) | | | | | | Note 1. | There | arameters are not charac | torized or toot | - al : | | | | | | | | **Note 1:** These parameters are not characterized or tested in manufacturing. <sup>2:</sup> These parameters are characterized, but not tested in manufacturing. <sup>3:</sup> Characterized with a 1 kHz sine wave. TABLE 37-42: ANALOG-TO-DIGITAL CONVERSION TIMING REQUIREMENTS | AC CHA | RACTER | RISTICS <sup>(2)</sup> | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | | | |---------------|-----------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Param.<br>No. | Symbol | Characteristics | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | | | Clock P | arameter | S | | | | | | | | | | | AD50 | TAD | ADC Clock Period | 16.667 | _ | 6250 | ns | _ | | | | | | Through | nput Rate | ) | | | | | | | | | | | AD51 | FTP | Sample Rate for<br>ADC0-ADC5<br>(Class 1 Inputs) | _<br>_<br>_<br>_ | _<br>_<br>_<br>_ | 3.75<br>4.284<br>4.992<br>6 | Msps<br>Msps<br>Msps<br>Msps | 12-bit resolution Source Impedance $\leq 200\Omega$ 10-bit resolution Source Impedance $\leq 200\Omega$ 8-bit resolution Source Impedance $\leq 200\Omega$ 6-bit resolution Source Impedance $\leq 200\Omega$ | | | | | | | | Sample Rate for<br>ADC7<br>(Class 2 and Class<br>3 Inputs) | | | 3.53<br>4.00<br>4.615<br>5.45 | Msps<br>Msps<br>Msps<br>Msps | 12-bit resolution Source Impedance $\leq 200\Omega$ 10-bit resolution Source Impedance $\leq 200\Omega$ 8-bit resolution Source Impedance $\leq 200\Omega$ 6-bit resolution Source Impedance $\leq 200\Omega$ | | | | | | Timing I | Paramete | ers | | | | | | | | | | | AD60 | Тѕамр | Sample Time for<br>ADC0-ADC5<br>(Class 1 Inputs) | 3<br>4<br>5<br>13 | _ | _ | TAD | Source Impedance $\leq 200\Omega$ , Max ADC clock Source Impedance $\leq 500\Omega$ , Max ADC clock Source Impedance $\leq 1$ K $\Omega$ , Max ADC clock Source Impedance $\leq 5$ K $\Omega$ , Max ADC clock | | | | | | | | Sample Time for<br>ADC7<br>(Class 2 and Class<br>3 Inputs) | 4<br>5<br>6<br>14 | | | TAD | Source Impedance $\leq 200\Omega$ , Max ADC clock Source Impedance $\leq 500\Omega$ , Max ADC clock Source Impedance $\leq 1$ K $\Omega$ , Max ADC clock Source Impedance $\leq 5$ K $\Omega$ , Max ADC clock | | | | | | | | Sample Time for<br>ADC7<br>(Class 2 and Class<br>3 Inputs) | See<br>Table<br>37-43 | 1 | 1 | TAD | CVDEN (ADCCON1<11>) = 1 | | | | | | AD62 | TCONV | Conversion Time<br>(after sample time is<br>complete) | _<br>_<br>_<br>_ | _<br>_<br>_<br>_ | 13<br>11<br>9<br>7 | TAD | 12-bit resolution<br>10-bit resolution<br>8-bit resolution<br>6-bit resolution | | | | | | AD65 | TWAKE | Wake-up time from Low-Power Mode | | 500<br>20 | _ | TAD<br>µs | Lesser of 500 Tad or 20 µs | | | | | Note 1: These parameters are characterized, but not tested in manufacturing. <sup>2:</sup> The ADC module is functional at VBORMIN < VDD < VDDMIN, but with degraded performance. Unless otherwise stated, module functionality is guaranteed, but not characterized. TABLE 37-43: ADC SAMPLE TIMES WITH CVD ENABLED | AC CHARACTERISTICS <sup>(2)</sup> | | | (unless | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |-----------------------------------|--------|----------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | | AD60a | TSAMP | Sample Time for<br>ADC7 (Class 2 and<br>Class 3 Inputs) with<br>the CVDEN bit<br>(ADCCON1<11>) = 1 | 8<br>9<br>11<br>12<br>14<br>16<br>17 | _ | _ | TAD | Source Impedance ≤ 200Ω<br>CVDCPL<2:0> (ADCCON2<28:26>) = 001<br>CVDCPL<2:0> (ADCCON2<28:26>) = 010<br>CVDCPL<2:0> (ADCCON2<28:26>) = 011<br>CVDCPL<2:0> (ADCCON2<28:26>) = 100<br>CVDCPL<2:0> (ADCCON2<28:26>) = 101<br>CVDCPL<2:0> (ADCCON2<28:26>) = 110<br>CVDCPL<2:0> (ADCCON2<28:26>) = 110<br>CVDCPL<2:0> (ADCCON2<28:26>) = 111 | | | | | | | | 10<br>12<br>14<br>16<br>18<br>19<br>21 | _ | _ | TAD | Source Impedance ≤ 500Ω<br>CVDCPL<2:0> (ADCCON2<28:26>) = 001<br>CVDCPL<2:0> (ADCCON2<28:26>) = 010<br>CVDCPL<2:0> (ADCCON2<28:26>) = 011<br>CVDCPL<2:0> (ADCCON2<28:26>) = 100<br>CVDCPL<2:0> (ADCCON2<28:26>) = 101<br>CVDCPL<2:0> (ADCCON2<28:26>) = 110<br>CVDCPL<2:0> (ADCCON2<28:26>) = 110<br>CVDCPL<2:0> (ADCCON2<28:26>) = 111 | | | | | | | | 13<br>16<br>18<br>21<br>23<br>26<br>28 | _ | _ | TAD | Source Impedance $\leq$ 1 K $\Omega$ CVDCPL<2:0> (ADCCON2<28:26>) = 001 CVDCPL<2:0> (ADCCON2<28:26>) = 010 CVDCPL<2:0> (ADCCON2<28:26>) = 011 CVDCPL<2:0> (ADCCON2<28:26>) = 100 CVDCPL<2:0> (ADCCON2<28:26>) = 100 CVDCPL<2:0> (ADCCON2<28:26>) = 101 CVDCPL<2:0> (ADCCON2<28:26>) = 110 CVDCPL<2:0> (ADCCON2<28:26>) = 110 CVDCPL<2:0> (ADCCON2<28:26>) = 111 | | | | | | | | 41<br>48<br>56<br>63<br>70<br>78<br>85 | _ | _ | TAD | Source Impedance $\leq$ 5 K $\Omega$<br>CVDCPL<2:0> (ADCCON2<28:26>) = 001<br>CVDCPL<2:0> (ADCCON2<28:26>) = 010<br>CVDCPL<2:0> (ADCCON2<28:26>) = 011<br>CVDCPL<2:0> (ADCCON2<28:26>) = 100<br>CVDCPL<2:0> (ADCCON2<28:26>) = 101<br>CVDCPL<2:0> (ADCCON2<28:26>) = 101<br>CVDCPL<2:0> (ADCCON2<28:26>) = 110<br>CVDCPL<2:0> (ADCCON2<28:26>) = 111 | | | | Note 1: These parameters are characterized, but not tested in manufacturing. <sup>2:</sup> The ADC module is functional at VBORMIN < VDD < VDDMIN, but with degraded performance. Unless otherwise stated, module functionality is guaranteed, but not characterized. #### TABLE 37-44: CONTROL DAC (CDAC) SPECIFICATIONS | | ARACTERIS | TICS | Standard ( | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | | |---------------|-----------|--------------------------------------------------------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Param.<br>No. | Symbol | Characteristics | Min. | Тур. | Max. | Conditions | | | | | | CDAC | | | | | | | | | | | | CD10 | Vouт | CDAC Output Voltage<br>Range for Guaranteed<br>Settling Time<br>Specifications | 0.1 *<br>CDACVREF | _ | 0.9 *<br>CDACVREF | V | @ ILOAD = IOUT (max) | | | | | CD11 | N | CDAC Resolution | 12 | | _ | Bits | Guaranteed Monotonic by architecture | | | | | CD12 | INL | CDAC Integral<br>Nonlinearity | -4 | 1.4 | 4 | LSB | Guaranteed Monotonic by architecture with CDACVREF = AVDD = 3.3V | | | | | CD13 | DNL | CDAC Differential<br>Nonlinearity | -1 | 0.772 | 2 | LSB | Guaranteed Monotonic by architecture with CDACVREF = AVDD = 3.3V | | | | | CD14 | OERR | CDAC Offset Error | -13 | -0.989 | 13 | mV | CDACVREF = AVDD = 3.3V | | | | | CD15 | GERR | CDAC Gain Error | -1 | -0.35 | +1 | % of FS | CDACVREF = AVDD = 3.3V | | | | | CD16 | CDACVREF | CDAC VREF Input<br>Range | 0.5 | _ | AVDD | V | _ | | | | | CD17 | Ton | CDAC Module Turn On Time | _ | 1.0 | 2 | μs | From write of DACON bit | | | | | CD18 | Toff | CDAC Module Turn Off<br>Time | _ | 1.0 | 2 | μs | From write of DACON bit | | | | | CD19 | Тѕт | Settling Time | _ | 3 | 6 | μs | Output is within ±4 LSb of desired output step voltage with a 10% to 90% step or 90% to 10% step. With load capacitance of 30 pF. PBCLK2 > 15MHz | | | | | CD20 | Fs | Sampling Frequency | _ | _ | 1 | Msps | Maximum frequency for a correct CDAC output change for small variations of input codes (from code to code plus 1 LSb). | | | | | CD21 | CLOAD | Output Load<br>Capacitance | | | 30 | pF | User application loads | | | | | DC22 | Іоит | Output Current Drive<br>Strength | _ | _ | 1 | mA | Sink and source | | | | **TABLE 37-45: CTMU CURRENT SOURCE SPECIFICATIONS** | AC CHARACTERISTICS | | | | | | | | | |--------------------|-----------|----------------------------------------------------|------|-------|------|-------|-----------------------------------|--| | Param<br>No. | Symbol | Characteristic | Min. | Тур. | Max. | Units | Conditions | | | CTMU CUR | RENT SOUR | CE | | | | | | | | CTMU0 | RES | Resolution | -2 | _ | +2 | °C | 3.3V @ -40°C to 125°C | | | CTMUI1 | Iout1 | Base Range <sup>(1)</sup> | _ | 0.55 | _ | μΑ | CTMUCON <1:0> = 01 | | | CTMUI2 | Іоит2 | 10x Range <sup>(1)</sup> | _ | 5.5 | _ | μA | CTMUCON <1:0> = 10 | | | CTMUI3 | Іоит3 | 100x Range <sup>(1)</sup> | _ | 55 | _ | μΑ | CTMUCON <1:0> = 11 | | | CTMUI4 | Iout4 | 1000x Range <sup>(1)</sup> | _ | 550 | _ | μΑ | CTMUCON <1:0> = 00 | | | CTMUFV1 | VF | Temperature Diode Forward Voltage <sup>(1,2)</sup> | _ | 0.594 | _ | V | TA = +25°C,<br>CTMUCON <1:0> = 01 | | | | | | _ | 0.654 | _ | V | TA = +25°C,<br>CTMUCON <1:0> = 10 | | | | | | _ | 0.716 | _ | V | TA = +25°C,<br>CTMUCON <1:0> = 11 | | | CTMUFV2 | VFVR | Temperature Diode Rate of | _ | -1.74 | _ | mV/ºC | CTMUCON <1:0> = 01 | | | | | Change <sup>(1,2)</sup> | _ | -1.58 | _ | mV/ºC | CTMUCON <1:0> = 10 | | | | | | _ | -1.42 | _ | mV/ºC | CTMUCON <1:0> = 11 | | - **Note 1:** Nominal value at center point of current trim range (CTMUCON<15:10> = 000000). - 2: Parameters are characterized but not tested in manufacturing. Measurements taken with the following conditions: - VREF+ = AVDD = 3.3V - · ADC module configured for conversion speed of 500 ksps - All PMD bits are cleared (PMDx = 0) - Executing a while (1) statement - Device operating from the FRC with no PLL FIGURE 37-21: PARALLEL SLAVE PORT TIMING **TABLE 37-46: PARALLEL SLAVE PORT REQUIREMENTS** | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | | |--------------------|----------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|------------|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Тур. | Max. | Units | Conditions | | | PS1 | TdtV2wrH | Data In Valid before PMWR or PMCSx Inactive (setup time) | 20 | | _ | ns | _ | | | PS2 | TwrH2dtl | PMWR or PMCSx Inactive to Data-in Invalid (hold time) | 40 | _ | _ | ns | _ | | | PS3 | TrdL2dtV | PMRD and PMCSx Active to Data-out Valid | _ | _ | 60 | ns | _ | | | PS4 | TrdH2dtl | PMRD Active or PMCSx Inactive to Data-out Invalid | 0 | | 10 | ns | _ | | | PS5 | Tcs | PMCSx Active Time | TPBCLK2 + 40 | _ | | ns | _ | | | PS6 | Twr | PMWR Active Time | TPBCLK2 + 25 | _ | _ | ns | _ | | | PS7 | TRD | PMRD Active Time | TPBCLK2 + 25 | _ | _ | ns | _ | | Note 1: These parameters are characterized, but not tested in manufacturing. FIGURE 37-22: PARALLEL MASTER PORT READ TIMING DIAGRAM TABLE 37-47: PARALLEL MASTER PORT READ TIMING REQUIREMENTS | AC CHA | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) | | | | | | |---------------|--------------------|----------------------------------------------------------------------|--------------------------------|-----------------------------------------------------------------------|---|----|---|--|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. Typ. Max. Units Condition | | | | | | | | PM1 | TLAT | PMALL/PMALH Pulse Width | _ | 1 TPBCLK2 | _ | _ | _ | | | | PM2 | TADSU | Address Out Valid to PMALL/<br>PMALH Invalid (address setup<br>time) | _ | 2 TPBCLK2 | _ | _ | _ | | | | PM3 | TADHOLD | PMALL/PMALH Invalid to<br>Address Out Invalid (address<br>hold time) | _ | 1 TPBCLK2 | _ | _ | _ | | | | PM4 | TAHOLD | PMRD Inactive to Address Out<br>Invalid<br>(address hold time) | 5 | _ | _ | ns | _ | | | | PM5 | TRD | PMRD Pulse Width | _ | 1 TPBCLK2 | _ | _ | _ | | | | PM6 | TDSU | PMRD or PMENB Active to Data In Valid (data setup time) | 15 | _ | _ | ns | _ | | | | PM7 | TDHOLD | PMRD or PMENB Inactive to Data In Invalid (data hold time) | 5 | _ | _ | ns | _ | | | Note 1: These parameters are characterized, but not tested in manufacturing. FIGURE 37-23: PARALLEL MASTER PORT WRITE TIMING DIAGRAM TABLE 37-48: PARALLEL MASTER PORT WRITE TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated)<br>Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | |--------------------|---------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---|---|---|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. Typ. Max. Units Conditions | | | | | | | PM11 | Twr | PMWR Pulse Width | _ | 1 TPBCLK2 | 1 | | _ | | | PM12 | TDVSU | Data Out Valid before PMWR or PMENB goes Inactive (data setup time) | _ | 2 TPBCLK2 | _ | _ | _ | | | PM13 | TDVHOLD | PMWR or PMEMB Invalid to Data<br>Out Invalid (data hold time) | _ | 1 TPBCLK2 | _ | _ | _ | | Note 1: These parameters are characterized, but not tested in manufacturing. TABLE 37-49: USB OTG ELECTRICAL SPECIFICATIONS | AC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for Commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial | | | | | | |--------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|----------------------------------------------------------------------------------------------------------------|--| | Param.<br>No. | Symbol | Characteristics <sup>(1)</sup> | Min. | Тур. | Max. | Units | Conditions | | | USB313 | VUSB3V3 | USB Voltage | 3.0 | _ | 3.6 | V | Two requirements for proper USB operation: • 3V ≤ VUSB3V3 ≤ 3.6V • (VUSB3V3 - 0.3V) ≤ VDD ≤ (VUSB3V3 + 0.3V) | | | USB315 | VILUSB | Input Low Voltage for USB Buffer | _ | _ | 0.8 | V | _ | | | USB316 | VIHUSB | Input High Voltage for USB Buffer | 2.0 | _ | _ | V | _ | | | USB318 | VDIFS | Differential Input Sensitivity | | _ | 0.2 | V | The difference between D+ and D- must exceed this value while VCM is met | | | USB319 | VCM | Differential Common Mode Range | 0.8 | _ | 2.5 | V | _ | | | USB320 | Zout | Driver Output Impedance | 28.0 | | 44.0 | Ω | | | | USB321 | Vol | Voltage Output Low | 0.0 | _ | 0.3 | V | 1.425 kΩ load connected to Vusb3v3 | | | USB322 | Voh | Voltage Output High | 2.8 | _ | 3.6 | V | 14.25 kΩ load connected to ground | | Note 1: These parameters are characterized, but not tested in manufacturing. #### **TABLE 37-50: UART TIMING CHARACTERISTICS** | AC CHA | AC CHARACTERISTICS | | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for Commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial | | | | | | |---------------|--------------------|-----------|------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------|--|--| | Param.<br>No. | Symbol | Characte | ristics <sup>(1)</sup> | Min. | Тур. | Max. | Units | nits Conditions | | | | UT10 | Fв | Baud Rate | BRGH = 0 | | _ | 7.5 | Mbps | Baud rate = (FPBy / (16 * (UxBRG + 1))<br>where:<br>'x' = 1-6<br>'y' = FPBCLK2 for UART1 and UART2<br>'y' = FPBLKC3 for UART3-UART6 | | | | UT20 | | | BRGH = 1 | _ | _ | 30 | Mbps | Baud rate = (FPBy / (4 * (UxBRG + 1))<br>where:<br>'x' = 1-6<br>'y' = FPBCLK2 for UART1 and UART2<br>'y' = FPBLKC3 for UART3-UART6 | | | Note 1: These parameters are characterized, but not tested in manufacturing. FIGURE 37-24: MOTOR CONTROL PWM MODULE FAULT TIMING CHARACTERISTICS TABLE 37-51: MOTOR CONTROL PWM MODULE TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 2.3V to 3.6V (unless otherwise stated) Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for Commercial $-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial | | | | | | |--------------------|--------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|----|--------------------|--| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. Typ. Max. Units Conditions | | | | | | | MP10 | TFPWM | PWM Output Fall Time | _ | _ | _ | ns | See parameter DO32 | | | MP11 | TRPWM | PWM Output Rise Time | _ | _ | _ | ns | See parameter DO31 | | | MP20 | TFD | Fault Input ↓ to PWM<br>I/O Change | _ | _ | 50 | ns | _ | | | MP30 | TFH | Fault Input Pulse Width | 50 | | _ | ns | _ | | Note 1: These parameters are characterized, but not tested in manufacturing. FIGURE 37-25: HLVD ELECTRICAL SPECIFICATION AND TIMING DIAGRAM TABLE 37-52: ELECTRICAL CHARACTERISTICS: LVD | DC Speci | fications | | | | | | o 3.6V (unless other-<br>°C≤ TA ≤ +125°C | |----------|-------------------|---------------|-----------|----------|--------------|-------|------------------------------------------------| | Symbol | Characteristic | | Min (-2%) | Тур† | Max<br>(+2%) | Units | Conditions | | LVDL | LVD Voltage on | LVDL = 0000 | _ | _ | _ | V | | | | VDD transition | LVDL = 0001 | _ | 1 | _ | V | | | | high to low | LVDL = 0010 | _ | 1 | _ | V | | | | | LVDL = 0011 | _ | 1 | _ | V | | | VLVD | | LVD = 0100 | 3.38 | 3.49 | 3.66 | V | | | | | LVD = 0101 | 3.14 | 3.26 | 3.40 | V | | | | | LVD = 0110 | 2.87 | 2.97 | 3.11 | V | | | | | LVD = 0111 | 2.67 | 2.77 | 2.89 | V | | | | | LVD = 1000 | 2.57 | 2.67 | 2.79 | V | | | | | LVD= 1001 | 2.39 | 2.48 | 2.59 | V | | | | | LVD = 1010 | 2.294 | 2.38 | 2.49 | V | | | | | LVDL = 1011 | _ | _ | _ | V | Reserved | | | | LVDL = 1100 | _ | _ | _ | V | Reserved | | | | LVDL = 1101 | _ | _ | _ | V | Reserved | | | | LVDL = 1110 | _ | _ | | V | Reserved | | | | LVDL = 1111 | External | External | External | V | | | VLVERR | LVD Total Error | | -10 | _ | 10 | mV | offset, regulation drift and temperature drift | | VLHYS | Low-voltage Detec | ct Hysteresis | | 6.8 | 24 | mV | | Note 1: FIGURE 37-26: EJTAG TIMING CHARACTERISTICS #### **TABLE 37-53:** | AC CHARACTERISTICS | | | (unless | s otherw | ise state | nditions: 2.3V to 3.6V<br>d)<br>$-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial<br>$-40^{\circ}C \le TA \le +125^{\circ}C$ for Extended | | |--------------------|------------|--------------------------------------------------|---------|----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|--| | Param.<br>No. | Symbol | Description <sup>(1)</sup> | Min. | Max. | Units | Conditions | | | EJ1 | Ттсксус | TCK Cycle Time | 25 | _ | ns | _ | | | EJ2 | Ттскнідн | TCK High Time | 10 | _ | ns | _ | | | EJ3 | TTCKLOW | TCK Low Time | 10 | _ | ns | _ | | | EJ4 | TTSETUP | TAP Signals Setup Time Before Rising TCK | 5 | _ | ns | _ | | | EJ5 | TTHOLD | TAP Signals Hold Time After Rising TCK | 3 | _ | ns | _ | | | EJ6 | Ттроопт | TDO Output Delay Time from Falling TCK | _ | 5 | ns | _ | | | EJ7 | TTDOZSTATE | TDO 3-State Delay Time from Falling TCK | _ | 5 | ns | _ | | | EJ8 | TTRSTLOW | TRST Low Time | 25 | _ | ns | _ | | | EJ9 | TRF | TAP Signals Rise/Fall Time, All Input and Output | _ | _ | ns | _ | | Note 1: These parameters are characterized, but not tested in manufacturing. # PIC32MK GPK/MCM with CAN FD #### 38.0 AC AND DC CHARACTERISTICS GRAPHS Note: The graphs provided are a statistical summary based on a limited number of samples and are provided for design guidance purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs, the data presented may be outside the specified operating range (e.g., outside specified power supply range) and therefore, outside the warranted range. FIGURE 38-1: VOH – 4x DRIVER PINS FIGURE 38-3: VOH – 8x DRIVER PINS FIGURE 38-2: Vol – 4x DRIVER PINS FIGURE 38-4: Vol – 8x DRIVER PINS | NOTES: | | | |--------|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 39.0 PACKAGING INFORMATION #### 39.1 Package Marking Information 64-Lead VQFN (9x9x0.9 mm) 64-Lead TQFP (10x10x1 mm) 100-Lead TQFP (12x12x1 mm) Example Example Example Legend: XX...X Customer-specific information Y Year code (last digit of calendar year) YY Year code (last 2 digits of calendar year) WW Week code (week of January 1 is week '01') NNN Alphanumeric traceability code Pb-free JEDEC designator for Matte Tin (Sn) \* This package is Pb-free. The Pb-free JEDEC designator (e3) can be found on the outer packaging for this package. **Note:** In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line, thus limiting the number of available characters for customer-specific information. #### 39.2 Package Details 64-Lead Very Thin Plastic Quad Flat, No Lead Package (R4X) – 9x9x0.9 mm Body [VQFN] With 7.15 x 7.15 Exposed Pad [Also called QFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-149 [R4X] Rev E Sheet 1 of 2 # 64-Lead Very Thin Plastic Quad Flat, No Lead Package (R4X) – 9x9x0.9 mm Body [VQFN] With 7.15 x 7.15 Exposed Pad [Also called QFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | N | MILLIMETERS | | | | |------------------------|--------|----------------|-------------|------|--|--| | Dimension | Limits | MIN | NOM | MAX | | | | Number of Pins | N | 64 | | | | | | Pitch | е | | 0.50 BSC | | | | | Overall Height | Α | 0.80 | 0.90 | 1.00 | | | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | | | Contact Thickness | A3 | 0.20 REF | | | | | | Overall Width | E | 9.00 BSC | | | | | | Exposed Pad Width | E2 | 7.05 | 7.15 | 7.25 | | | | Overall Length | D | | 9.00 BSC | | | | | Exposed Pad Length | D2 | 7.05 | 7.15 | 7.25 | | | | Contact Width | b | 0.18 | 0.25 | 0.30 | | | | Contact Length | L | 0.30 0.40 0.50 | | | | | | Contact-to-Exposed Pad | K | 0.20 | - | - | | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated - 3. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-149 [R4X] Rev E Sheet 2 of 2 # 64-Lead Very Thin Plastic Quad Flat, No Lead Package (R4X) – 9x9x0.9 mm Body [VQFN] With 7.15 x 7.15 Exposed Pad [Also called QFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | | Units | MILLIMETERS | | | | |------------------------------------|--------|-------------|------|------|--| | Dimension | Limits | MIN | NOM | MAX | | | Contact Pitch | Е | E 0.50 BSC | | | | | Optional Center Pad Width | X2 | | | 7.25 | | | Optional Center Pad Length | Y2 | | | 7.25 | | | Contact Pad Spacing | C1 | | 9.00 | | | | Contact Pad Spacing | C2 | | 9.00 | | | | Contact Pad Width (X64) | X1 | | | 0.30 | | | Contact Pad Length (X64) | Y1 | | | 0.95 | | | Contact Pad to Center Pad (X64) | G1 | 0.40 | | | | | Spacing Between Contact Pads (X60) | G2 | 0.20 | | | | | Thermal Via Diameter | V | | 0.33 | | | | Thermal Via Pitch | EV | | 1.20 | | | #### Notes: - Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. - 2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during reflow process Microchip Technology Drawing C04-149 [R4X] Rev E #### 64-Lead Plastic Thin Quad Flatpack (PT)-10x10x1 mm Body, 2.00 mm Footprint [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging **TOP VIEW** Microchip Technology Drawing C04-085C Sheet 1 of 2 #### 64-Lead Plastic Thin Quad Flatpack (PT)-10x10x1 mm Body, 2.00 mm Footprint [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | MILLIMETERS | | | | | |--------------------------|-------------|-------------|----------|------|--| | Dimension | MIN | NOM | MAX | | | | Number of Leads | N | 64 | | | | | Lead Pitch | е | | 0.50 BSC | | | | Overall Height | Α | - | - | 1.20 | | | Molded Package Thickness | A2 | 0.95 | 1.00 | 1.05 | | | Standoff | A1 | 0.05 | - | 0.15 | | | Foot Length | L | 0.45 | 0.60 | 0.75 | | | Footprint | L1 | 1.00 REF | | | | | Foot Angle | ф | 0° 3.5° 7° | | | | | Overall Width | Е | 12.00 BSC | | | | | Overall Length | D | 12.00 BSC | | | | | Molded Package Width | E1 | 10.00 BSC | | | | | Molded Package Length | D1 | 10.00 BSC | | | | | Lead Thickness | С | 0.09 - 0.20 | | | | | Lead Width | b | 0.17 | 0.22 | 0.27 | | | Mold Draft Angle Top | α | 11° | 12° | 13° | | | Mold Draft Angle Bottom | β | 11° 12° 13° | | | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Chamfers at corners are optional; size may vary. - 3. Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.25mm per side. - 4. Dimensioning and tolerancing per ASME Y14.5M $\,$ BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-085C Sheet 2 of 2 #### 64-Lead Plastic Thin Quad Flatpack (PT)-10x10x1 mm Body, 2.00 mm Footprint [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | | Units | | | S | |--------------------------|-------|----------|-------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | Е | 0.50 BSC | | | | Contact Pad Spacing | C1 | | 11.40 | | | Contact Pad Spacing | C2 | | 11.40 | | | Contact Pad Width (X28) | X1 | | | 0.30 | | Contact Pad Length (X28) | Y1 | | | 1.50 | | Distance Between Pads | G | 0.20 | | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-2085B Sheet 1 of 1 #### 100-Lead Plastic Thin Quad Flatpack (PT) - 12x12x1 mm Body, 2.00 mm [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Chamfers at corners are optional; size may vary. - 3. Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.25 mm per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-100B 100-Lead Plastic Thin Quad Flatpack (PT)-12x12x1mm Body, 2.00 mm Footprint [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | MILLIMETERS | | | | |---------------------------|-------------|----------|-------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | E | 0.40 BSC | | | | Contact Pad Spacing | C1 | 13.40 | | | | Contact Pad Spacing | C2 | | 13.40 | | | Contact Pad Width (X100) | X1 | | | 0.20 | | Contact Pad Length (X100) | Y1 | | | 1.50 | | Distance Between Pads | G | 0.20 | | | #### Notes: BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2100B <sup>1.</sup> Dimensioning and tolerancing per ASME Y14.5M | 1 103211111 0 | WILLI OAL | i i D i ali | iii y | | |---------------|-----------|-------------|-------|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 40.0 APPENDIX A: MIGRATION GUIDE TABLE 40-1: MIGRATION FROM PIC32MKXXGPD/GPE/MCFXX TO PIC32MKXXGPK/MCMXX | FEATURE | PIC32MKxxGPD/GPE/<br>MCFxx | PIC32MKxxGPK/MCMxx | 64/100pin PIC32MKxxGPD/E/<br>MCF to<br>64/100pin PIC32MKxxGPK/<br>MCM<br>Migration Impact | | COMMENTS | |---------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | | | | PCB HDW<br>Non-<br>Compatible | SW<br>Non-<br>Compatible | | | #PIN | 100 / 64 | 100 / 64 | Х | Х | Pin Differences:<br>LVDIN, T1CLK, VBAT, RD8, PWM7L, PWM7H, | | # I/O | 77 (100pin), 48 (64pin) | 78 (100pin), 49 (64pin) | х | х | PWM8L, PWM8H, PWM9L, PWM9H, PWM10H I2Cx [SCLx, SDAx (x=1-4)] differences. + GP Variants have one extra I/O pin | | CPU | MIPS arch @ 120Mhz | MIPS arch @ 120Mhz | | | | | Configuration Word<br>Registers | 4 | 5/10 | | x | 1 new configuration register + new bits + 5 new alternate configuration words. | | FLASH | 1024 / 512 Mb<br>No ECC<br>Live Update<br>Dual Boot | 1024 / 512 Mb<br>ECC<br>Live Update<br>Dual Boot | | X <sup>(1)</sup> | Flash ECC added on PIC32MKxxGPK/MCMxx. (i.e. Silicon FLASH error correction) | | SRAM | 256, 128Kb | 256, 128Kb | | | | | Oscillator | POSC (No AGC)<br>SOSC<br>UPLL (USB PLL)<br>No BFRC | POSC w/AGC & Fine gain<br>SOSC<br>UPLL (USB PLL)<br>BFRC (Bck-up FRC) | X <sup>(1,2)</sup> | X <sup>(1,2)</sup> | PIC32MKxxGPK/MCMxx: New BFRC, (Bck-Up FRC), + OSCCON Reg clock source selections + AGC, (Auto Gain Ctl), feature/selections in Configuration words. | | EE Data Flash Module | 4Kb | 4Kb | | | | | DMA | 8/13 | 8/13 | | | | | USB | (2) Full Speed (100pin)<br>(1) Full Speed (64pin) | (2) Full Speed (100pin)<br>(1) Full Speed (64pin) | | | NOTE: USB LS Non-Functional on both product families | | TIMER1 | 1 | 1 | | | | | 32bit TIMERS 2-9 type B | 8 | 8 | | | | | Watch Dog Timer | 1 | 1 | | | | | Dead Man Timer | 1 | 1 | | | | TABLE 40-1: MIGRATION FROM PIC32MKXXGPD/GPE/MCFXX TO PIC32MKXXGPK/MCMXX (CONTINUED) | FEATURE | PIC32MKxxGPD/GPE/<br>MCFxx | PIC32MKYYGPK/MCMYY Minnetics Inches | | F to<br>32MKxxGPK/<br>CM | COMMENTS | | |---------------------------------|----------------------------|-------------------------------------|-------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------|--| | | | | PCB HDW<br>Non-<br>Compatible | SW<br>Non-<br>Compatible | | | | Input Capture | 16 | 16 | | | | | | Output Compare | 16 | 16 | | | | | | SPI | 6 | 6 | | | | | | I2C | (None) | 4 | Х | X | (4) I2C Peripherals | | | UART | 6 | 6 | | | | | | PMP | 1 | 1 | | | | | | RTCC | 1 | 1 | | | | | | CAN | CAN (Lite) | CAN FD<br>(New HDW/SW) | | x | Completely new CAN architecture with all new features register/bit definitions | | | ADC Modules | 7 | 7 | | | | | | ADC Channels (External) | 42 (100pin), 26 (64pin) | 42 (100pin), 26 (64pin) | | | | | | ADC Channels<br>(VBAT Internal) | Yes (AN52=VBAT/2) | No - None | | X(1) | No VBAT on PIC32MKxxGPK | | | ОРАМР | 4 | 4 (New features and configurations) | | Х | New Op-Amp features, modes, configurations & register bit additions/deletions + new performance specs. | | | CFGCON2 Register | Yes | No | | Х | PIC32MKxxGPD/GPE/MCFxx Op-Amp Enable/<br>Disable reg | | | COMPARATORS | 5 | 5 (New features and configurations) | | Х | | | | DAC | 3 | 3 | | | | | DS60001519E-page 756 **TABLE 40-2**: MIGRATION FROM PIC32MKXXGPD/GPE/MCFXX TO PIC32MKXXGPK/MCMXX | FEATURE | FEATURE PIC32MKxxGPD/GPE/<br>MCFxx | | 64/100pin PIC32MKxxGPD/E/<br>MCF to<br>64/100pin PIC32MKxxGPK/<br>MCM<br>Migration Impact | | COMMENTS | |----------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | PCB HDW<br>Non-<br>Compatible | SW<br>Non-<br>Compatible | | | Motor Ctl PWM<br>(PIC32MKXXMCxXX Only) | 8 Complimentary pairs (1-6,<br>11-12),+ 4 single ended (7-10) | 12 Complimentary pairs + (6)<br>single ended | х | х | PIC32MKxxMCFxx: Max (8) complimentary pairs or (4) Independent pairs or any combination of complimentary/independent that do not exceed (8) total pairs. PIC32MKxxMCMxx: Max (12) complimentary pairs or (6) Independent pairs or any combination of complimentary/independent that do not exceed (12) total pairs. | | PWM IOCONx: (x=1-12)<br>FLT and DTCOMP | 9 | 11 | X <sup>(1)</sup> | X <sup>(1)</sup> | PWM Fault and DTCOMP, Different Fault & Dead Time Compensation features/selections | | Low Voltage Detect | (None) | 1 | Х | Х | | | CTMU | 1 | 1 | | | | | PMD<br>(Peripheral Module<br>Disable) | Yes | Yes | | | | | JTAG | Yes | Yes | | | | | TRACE | Yes (100 & 64pin) | Yes (100 & 64pin) | | | | | PGCx/PGDx (Debug) | 3 | 3 | | | | | VBAT (GP variants) | Yes | No | X | X | No VBAT on PIC32MKxxGPK/GPLxx | | Deep Sleep Modes/ features * DSWDT / DSBOR * DSCON Reg * DSWAKE Reg * DSGPR[0 - 32] Regs | Yes | No | | Х | No Deep Sleep modes/features & registers on PIC32MKxxGPK/GPL/MCMxx | TABLE 40-2: MIGRATION FROM PIC32MKXXGPD/GPE/MCFXX TO PIC32MKXXGPK/MCMXX (CONTINUED) | FEATURE | PIC32MKxxGPD/GPE/<br>MCFxx | PIC32MKxxGPK/MCMxx | MC<br>64/100pin PIC<br>MG | 32MKxxGPD/E/<br>F to<br>332MKxxGPK/<br>CM<br>n Impact | COMMENTS | |------------------------------------------------|-----------------------------|--------------------|-------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------| | | | | PCB HDW<br>Non-<br>Compatible | SW<br>Non-<br>Compatible | | | PRISS Reg: Priority<br>Shadow Select Registers | 2 | 8 | | х | Interrupt Priority Shadow Reg Sets added to reduce interrupt latency & interrupt stack memory usage by ~7x | | PB5DIV Reg | Yes | No | | Х | No PB5 Peripheral Bus #5 Clk Pre-scalar or | | PB6DIV Reg Default | SYSCLK/2 | SYSCLK/4 | | x | Peripherals on PB6 only runs at 30Mhz. Changes in default Peripheral Bus #5 Clk Pre-scalar | | RD8 I/O pin<br>(GP Variants Only) | No | Yes | х | X(1) | PINx: PIC32MKxxGPD/GPExx = VBAT/VDD<br>PINx: PIC32MKxxGPK= RD8 | | VDD Ramp Rate | 300ms to 3μs | 300ms to 10μs | x | | Max VDD ramp rate reduced from 3us to 10us. Some users' designs may need to add a 3.3v VDD Regulator soft start circuit to meet new spec. | | CFGCON2 Reg | ENPGAx + EEWS<br>(x=1-3, 5) | EEWS Bits Only | | X | PIC32MKxxGPK/MCMxx Op-Amp Unity gain mode enabled removed from CFGCON2 Reg. (Unity Gain mode moved to CMxCON Reg, x=1-3,5) | Note 1: This is only affected if the user application is using any of additional modules, peripheral functions, peripheral pin function, or features on the PIC32MKxxGPD/GPExx that the PIC32MKxxGPH/GPGxx does not possess. <sup>2:</sup> POSC Legacy code on PIC32MKxxGPD/GPExx will default in silicon on to PIC32MKxxGPK POSC w/AGC and ignore POSC gain setting. If using an external shunt gain resistor across POSC XTAL on PIC32MKxxGPD/GPExx user MUST ensure that DEVCFG0<POSCBOOST>=0 on PIC32MKxxGPH/GPGxx or remove the resistor for proper operation. Either internal or external gain boost but not both. TABLE 40-3: (100) PIN PIC32MKXXMCF100 VERSUS PIC32MKXXMCM100 PIN/FUNCTION MIGRATION DIFFERENCES | PIN | PIC32MKxxMCF100 | PIC32MKxxMCM100 | FUNCTION<br>PIN<br>MISMATCH | |-----|---------------------------------------------------|---------------------------------------------------|-----------------------------| | 1 | AN23/CVD23/PMA23/RG15 | AN23/CVD23/PWM7L/PMA23/RG15 | PWM7L | | 2 | VDD | VDD | | | 3 | TCK/RPA7/PWMH10/PWML4/PMD5/RA7 | TCK/RPA7/PWM10H/PWM4L/PMD5/RA7 | | | 4 | RPB14/PWMH1/VBUSON1/PMD6/RB14 | RPB14/PWM1H/VBUSON1/PMD6/RB14 | | | 5 | RPB15/PWMH7/PWML1/PMD7/RB15 | RPB15/PWM7H/PWM1L/PMD7/RB15 | | | 6 | PWMH11/PWML5/RD1 | PWM11H/PWM5L/RD1 | | | 7 | PWMH5/RD2 | PWM5H/RD2 | | | 8 | RPD3/PWMH12/PWML6/RD3 | RPD3/PWM12H/PWM6L/RD3 | | | 9 | RPD4/PWMH6/RD4 | RPD4/PWM6H/RD4 | | | 10 | AN19/CVD19/RPG6/VBUSON2/PMA5/RG6 | AN19/CVD19/RPG6/PWM10L/VBUSON2/<br>PMA5/RG6 | | | 11 | AN18/CVD18/RPG7/PMA4/RG7 | AN18/CVD18/RPG7/PWM10H/SCL1/PMA4/RG7 | SCL1,<br>PWM10H | | 12 | AN17/CVD17/RPG8/PMA3/RG8 | AN17/CVD17/RPG8/SDA1/PMA3/RG8 | SDA1 | | 13 | MCLR# | MCLR# | | | 14 | AN16/CVD16/RPG9/PMA2/RG9 | AN16/CVD16/RPG9/PMA2/RG9 | | | 15 | VSS | vss | | | 16 | VDD | VDD | | | 17 | AN22/CVD22/RG10 | AN22/CVD22/RG10 | | | 18 | AN21/CVD21/RE8 | AN21/CVD21/RE8 | | | 19 | AN20/CVD20/RE9 | AN20/CVD20/RE9 | | | 20 | AN10/CVD10/RPA12/RA12 | AN10/CVD10/RPA12/RA12 | | | 21 | AN9/CVD9/RPA11/RA11 | AN9/CVD9/RPA11/RA11 | | | 22 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | | 23 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | | 24 | PGD3/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 | PGD3/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 | | | 25 | PGC3/OA1OUT/AN3/C1IN4-/C4IN2-/RPB1/<br>CTED1/RB1 | PGC3/OA1OUT/AN3/C1IN4-/C4IN2-/RPB1/<br>CTED1/RB1 | | | 26 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | | | 27 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | | | 28 | VREF-/AN33/CVD33/PMA7/RF9 | VREF-/AN33/CVD33/PMA7/RF9 | | | 29 | VREF+/AN34/CVD34/PMA6/RF10 | VREF+/AN34/CVD34/PMA6/RF10 | | # TABLE 40-3: (100) PIN PIC32MKXXMCF100 VERSUS PIC32MKXXMCM100 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxMCF100 | PIC32MKxxMCM100 | FUNCTION<br>PIN<br>MISMATCH | |-----|--------------------------------------------------------|-------------------------------------------------------|-----------------------------| | 30 | AVDD | AVDD | | | 31 | AVSS | AVSS | | | 32 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/<br>RPC0/RC0 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/<br>RPC0/RC0 | | | 33 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/RC1 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/RC1 | | | 34 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/<br>FLT3/PMA13/RC2 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/<br>FLT3/PMA13/RC2 | | | 35 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | | | 36 | VSS | vss | | | 37 | VDD | VDD | | | 38 | AN35/CVD35/RG11 | AN35/CVD35/RG11 | | | 39 | AN36/CVD36/RF13 | AN36/CVD36/RF13 | | | 40 | AN37/CVD37/RF12 | AN37/CVD37/RF12 | | | 41 | AN12/CVD12/C2IN2-/C5IN2-/FLT5/PMA11/<br>RE12 | AN12/CVD12/C2IN2-/C5IN2-/SDA4/FLT5/<br>PMA11/RE12 | SDA4 | | 42 | AN13/CVD13/C3IN2-/FLT6/PMA10/RE13 | AN13/CVD13/C3IN2-/SCL4/FLT6/PMA10/RE13 | SCL4 | | 43 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | | | 44 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | | | 45 | vss | vss | | | 46 | VDD | VDD | | | 47 | AN38/CVD38/RD14 | AN38/CVD38/RD14 | | | 48 | AN39/CVD39/RD15 | AN39/CVD39/RD15 | | | 49 | TDI/DAC3/AN26/CVD26/RPA8/PMA9/RA8 | TDI/DAC3/AN26/CVD26/RPA8/SDA2/PMA9/<br>RA8 | SDA2 | | 50 | FLT15/RPB4/PMA8/RB4 | FLT15/RPB4/SCL2/PMA8/RB4 | SCL2 | | 51 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/<br>RPA4/T1CK/RA4 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/<br>RPA4/RA4 | T1CLK | | 52 | AN40/CVD40/RPE0/RE0 | AN40/CVD40/RPE0/RE0 | | | 53 | AN41/CVD41/RPE1/RE1 | AN41/CVD41/RPE1/RE1 | | | 54 | VBUS1 | VBUS1 | | | 55 | VUSB3V3 | VUSB3V3 | | | 56 | D1- | D1- | | | 57 | D1+ | D1+ | | | 58 | VBUS2 | VBUS2 | | | 59 | D2- | D2- | | # TABLE 40-3: (100) PIN PIC32MKXXMCF100 VERSUS PIC32MKXXMCM100 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxMCF100 | PIC32MKxxMCM100 | FUNCTION<br>PIN<br>MISMATCH | |-----|-------------------------------------------------|-------------------------------------------------|-----------------------------| | 60 | D2+ | D2+ | | | 61 | AN45/CVD45/RF5 | AN45/CVD45/RF5 | | | 62 | VDD | VDD | | | 63 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | | | 64 | OSCO/CLKO/RPC15/RC15 | OSCO/CLKO/RPC15/RC15 | | | 65 | vss | vss | | | 66 | AN46/CVD46/RPA14/RA14 | AN46/CVD46/RPA14/RA14 | | | 67 | AN47/CVD47/RPA15/RA15 | AN47/CVD47/RPA15/RA15 | | | 68 | RD8 | RD8 | | | 69 | PGD2/RPB5/USBID1/RB5 | PGD2/RPB5/SDA3/USBID1/RB5 | SDA3 | | 70 | PGC2/RPB6/SCK2/PMA15/RB6 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | SCL3 | | 71 | DAC2/AN48/CVD48/RPC10/PMA14/RC10 | DAC2/AN48/CVD48/RPC10/PMA14/RC10 | | | 72 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | | | 73 | SOSCI/RPC13/RC13 | SOSCI/RPC13/RC13 | | | 74 | SOSCO/RPB8/RB8 | SOSCO/RPB8/T1CK/RB8 | T1CLK | | 75 | VSS | vss | | | 76 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/<br>RPB9/RB9 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/<br>RPB9/RB9 | | | 77 | RPC6/USBID2/PMA16/RC6 | RPC6/USBID2/PMA16/RC6 | | | 78 | RPC7/PMA17/RC7 | RPC7/PMA17/RC7 | | | 79 | PMD12/RD12 | PMD12/RD12 | | | 80 | PMD13/RD13 | PMD13/RD13 | | | 81 | RPC8/PMWR/RC8 | RPC8/PMWR/RC8 | | | 82 | RPD5/PWMH12/PMRD/RD5 | RPD5/PWM12H/PMRD/RD5 | | | 83 | RPD6/PWML12/PMD14/RD6 | RPD6/PWM12L/PMD14/RD6 | | | 84 | RPC9/PMD15/RC9 | RPC9/PMD15/RC9 | | | 85 | VSS | vss | | | 86 | VDD | VDD | | | 87 | RPF0/PWMH11/PMD11/RF0 | RPF0/PWM11H/PMD11/RF0 | | | 88 | RPF1/PWML11/PMD10/RF1 | RPF1/PWM11L/PMD10/RF1 | | | 89 | RPG1/PMD9/RG1 | RPG1/PMD9/RG1 | | | 90 | RPG0/PMD8/RG0 | RPG0/PMD8/RG0 | | # TABLE 40-3: (100) PIN PIC32MKXXMCF100 VERSUS PIC32MKXXMCM100 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxMCF100 | PIC32MKxxMCM100 | FUNCTION<br>PIN<br>MISMATCH | |-----|-----------------------------------|-----------------------------------|-----------------------------| | 91 | TRCLK/PMA18/RF6 | TRCLK/PWM9H/PMA18/RF6 | PWM9H | | 92 | TRD3/PMA19/RF7 | TRD3/PWM9L/PMA19/RF7 | PWM9L | | 93 | RPB10/PWMH3/PMD0/RB10 | RPB10/PWM3H/PMD0/RB10 | | | 94 | RPB11/PWMH9/PWML3/PMD1/RB11 | RPB11/PWM9H/PWM3L/PMD1/RB11 | | | 95 | TRD2/PMA20/RG14 | TRD2/PWM8H/PMA20/RG14 | PWM8H | | 96 | TRD1/RPG12/PMA21/RG12 | TRD1/RPG12/PWM8L/PMA21/RG12 | PWM8L | | 97 | TRD0/PMA22/RG13 | TRD0/PWM7H/PMA22/RG13 | PWM7H | | 98 | RPB12/PWMH2/PMD2/RB12 | RPB12/PWM2H/PMD2/RB12 | | | 99 | RPB13/PWMH8/PWML2/CTPLS/PMD3/RB13 | RPB13/PWM8H/PWM2L/CTPLS/PMD3/RB13 | | | 100 | TDO/PWMH4/PMD4/RA10 | TDO/PWM4H/PMD4/RA10 | | TABLE 40-4: (100) PIN PIC32MKXXGPD/E100 VERSUS PIC32MKXXGPK100 PIN/FUNCTION MIGRATION DIFFERENCES | PIN | PIC32MKxxGPD/GPE100 | PIC32MKxxGPK100 | FUNCTION PIN<br>MISMATCH | |-----|---------------------------------------------------|---------------------------------------------------|--------------------------| | 1 | AN23/CVD23/PMA23/RG15 | AN23/CVD23/PMA23/RG15 | | | 2 | VDD | VDD | | | 3 | TCK/RPA7/PMD5/RA7 | TCK/RPA7/PMD5/RA7 | | | 4 | RPB14/VBUSON1/PMD6/RB14 | RPB14/VBUSON1/PMD6/RB14 | | | 5 | RPB15/PMD7/RB15 | RPB15/PMD7/RB15 | | | 6 | RD1 | RD1 | | | 7 | RD2 | RD2 | | | 8 | RPD3/RD3 | RPD3/RD3 | | | 9 | RPD4/RD4 | RPD4/RD4 | | | 10 | AN19/CVD19/RPG6/VBUSON2/PMA5/RG6 | AN19/CVD19/RPG6/VBUSON2/PMA5/RG6 | | | 11 | AN18/CVD18/RPG7/PMA4/RG7 | AN18/CVD18/RPG7/SCL1/PMA4/RG7 | SCL1 | | 12 | AN17/CVD17/RPG8/PMA3/RG8 | AN17/CVD17/RPG8/SDA1/PMA3/RG8 | SDA1 | | 13 | MCLR# | MCLR# | | | 14 | AN16/CVD16/RPG9/PMA2/RG9 | AN16/CVD16/RPG9/PMA2/RG9 | | | 15 | vss | VSS | | | 16 | VDD | VDD | | | 17 | AN22/CVD22/RG10 | AN22/CVD22/RG10 | | | 18 | AN21/CVD21/RE8 | AN21/CVD21/RE8 | | | 19 | AN20/CVD20/RE9 | AN20/CVD20/RE9 | | | 20 | AN10/CVD10/RPA12/RA12 | AN10/CVD10/RPA12/RA12 | | | 21 | AN9/CVD9/RPA11/RA11 | AN9/CVD9/RPA11/RA11 | | | 22 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | | 23 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | | 24 | PGD3/OA2IN-/AN2/C2IN1-/RPB0/CTED2/<br>RB0 | PGD3/OA2IN-/AN2/C2IN1-/RPB0/CTED2/RB0 | | | 25 | PGC3/OA1OUT/AN3/C1IN4-/C4IN2-/RPB1/<br>CTED1/RB1 | PGC3/OA1OUT/AN3/C1IN4-/C4IN2-/RPB1/<br>CTED1/RB1 | | | 26 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | | | 27 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | | | 28 | VREF-/AN33/CVD33/PMA7/RF9 | VREF-/AN33/CVD33/PMA7/RF9 | | | 29 | VREF+/AN34/CVD34/PMA6/RF10 | VREF+/AN34/CVD34/PMA6/RF10 | | | 30 | AVDD | AVDD | | ### TABLE 40-4: (100) PIN PIC32MKXXGPD/E100 VERSUS PIC32MKXXGPK100 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxGPD/GPE100 | PIC32MKxxGPK100 | FUNCTION PIN<br>MISMATCH | |-----|--------------------------------------------------------|-------------------------------------------------------|--------------------------| | 31 | AVSS | AVSS | | | 32 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/RPC0/RC0 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/<br>RPC0/RC0 | | | 33 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/<br>RC1 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/RC1 | | | 34 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/<br>FLT3/PMA13/RC2 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/<br>FLT3/PMA13/RC2 | | | 35 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | | | 36 | VSS | VSS | | | 37 | VDD | VDD | | | 38 | AN35/CVD35/RG11 | AN35/CVD35/RG11 | | | 39 | AN36/CVD36/RF13 | AN36/CVD36/RF13 | | | 40 | AN37/CVD37/RF12 | AN37/CVD37/RF12 | | | 41 | AN12/CVD12/C2IN2-/C5IN2-/FLT5/PMA11/<br>RE12 | AN12/CVD12/C2IN2-/C5IN2-/SDA4/FLT5/<br>PMA11/RE12 | SDA4 | | 42 | AN13/CVD13/C3IN2-/FLT6/PMA10/RE13 | AN13/CVD13/C3IN2-/SCL4/FLT6/PMA10/RE13 | SCL4 | | 43 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | | | 44 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | | | 45 | VSS | VSS | | | 46 | VDD | VDD | | | 47 | AN38/CVD38/RD14 | AN38/CVD38/RD14 | | | 48 | AN39/CVD39/RD15 | AN39/CVD39/RD15 | | | 49 | TDI/DAC3/AN26/CVD26/RPA8/PMA9/RA8 | TDI/DAC3/AN26/CVD26/RPA8/SDA2/PMA9/<br>RA8 | SDA2 | | 50 | FLT15/RPB4/PMA8/RB4 | FLT15/RPB4/SCL2/PMA8/RB4 | SCL2 | | 51 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/<br>C5IN3-/RPA4/T1CK/RA4 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/<br>RPA4/RA4 | T1CLK | | 52 | AN40/CVD40/RPE0/RE0 | AN40/CVD40/RPE0/RE0 | | | 53 | AN41/CVD41/RPE1/RE1 | AN41/CVD41/RPE1/RE1 | | | 54 | VBUS1 | VBUS1 | | | 55 | VUSB3V3 | VUSB3V3 | | | 56 | D1- | D1- | | | 57 | D1+ | D1+ | | | 58 | VBUS2 | VBUS2 | | | 59 | D2- | D2- | | | 60 | D2+ | D2+ | | # TABLE 40-4: (100) PIN PIC32MKXXGPD/E100 VERSUS PIC32MKXXGPK100 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxGPD/GPE100 | PIC32MKxxGPK100 | FUNCTION PIN<br>MISMATCH | |-----|-------------------------------------------------|-------------------------------------------------|--------------------------| | 61 | AN45/CVD45/RF5 | AN45/CVD45/RF5 | | | 62 | VDD | VDD | | | 63 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | | | 64 | OSCO/CLKO/RPC15/RC15 | OSCO/CLKO/RPC15/RC15 | | | 65 | vss | vss | | | 66 | AN46/CVD46/RPA14/RA14 | AN46/CVD46/RPA14/RA14 | | | 67 | AN47/CVD47/RPA15/RA15 | AN47/CVD47/RPA15/RA15 | | | 68 | VBAT / VDD (i.e. Non-5v Tolerant) | RD8 (i.e. 5v Tolerant) | VBAT/VDD, RD8 | | 69 | PGD2/RPB5/USBID1/RB5 | PGD2/RPB5/SDA3/USBID1/RB5 | SDA3 | | 70 | PGC2/RPB6/SCK2/PMA15/RB6 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | SCL3 | | 71 | DAC2/AN48/CVD48/RPC10/PMA14/RC10 | DAC2/AN48/CVD48/RPC10/PMA14/RC10 | | | 72 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | | | 73 | SOSCI/RPC13/RC13 | SOSCI/RPC13/RC13 | | | 74 | SOSCO/RPB8/RB8 | SOSCO/RPB8/T1CK/RB8 | T1CLK | | 75 | vss | vss | | | 76 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/<br>RPB9/RB9 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/<br>RPB9/RB9 | | | 77 | RPC6/USBID2/PMA16/RC6 | RPC6/USBID2/PMA16/RC6 | | | 78 | RPC7/PMA17/RC7 | RPC7/PMA17/RC7 | | | 79 | PMD12/RD12 | PMD12/RD12 | | | 80 | PMD13/RD13 | PMD13/RD13 | | | 81 | RPC8/PMWR/RC8 | RPC8/PMWR/RC8 | | | 82 | RPD5/PMRD/RD5 | RPD5/PMRD/RD5 | | | 83 | RPD6/PMD14/RD6 | RPD6/PMD14/RD6 | | | 84 | RPC9/PMD15/RC9 | RPC9/PMD15/RC9 | | | 85 | vss | vss | | | 86 | VDD | VDD | | | 87 | RPF0/PMD11/RF0 | RPF0/PMD11/RF0 | | | 88 | RPF1/PMD10/RF1 | RPF1/PMD10/RF1 | | | 89 | RPG1/PMD9/RG1 | RPG1/PMD9/RG1 | | | 90 | RPG0/PMD8/RG0 | RPG0/PMD8/RG0 | | | 91 | TRCLK/PMA18/RF6 | TRCLK/PMA18/RF6 | | | 92 | TRD3/PMA19/RF7 | TRD3/PMA19/RF7 | | # TABLE 40-4: (100) PIN PIC32MKXXGPD/E100 VERSUS PIC32MKXXGPK100 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxGPD/GPE100 | PIC32MKxxGPK100 | FUNCTION PIN<br>MISMATCH | |-----|-----------------------|-----------------------|--------------------------| | 93 | RPB10/PMD0/RB10 | RPB10/PMD0/RB10 | | | 94 | RPB11/PMD1/RB11 | RPB11/PMD1/RB11 | | | 95 | TRD2/PMA20/RG14 | TRD2/PMA20/RG14 | | | 96 | TRD1/RPG12/PMA21/RG12 | TRD1/RPG12/PMA21/RG12 | | | 97 | TRD0/PMA22/RG13 | TRD0/PMA22/RG13 | | | 98 | RPB12/PMD2/RB12 | RPB12/PMD2/RB12 | | | 99 | RPB13/CTPLS/PMD3/RB13 | RPB13/CTPLS/PMD3/RB13 | | | 100 | TDO/PMD4/RA10 | TDO/PMD4/RA10 | | TABLE 40-5: (64) PIN PIC32MKXXMCF64 VERSUS PIC32MKXXMCM64 PIN/FUNCTION MIGRATION DIFFERENCES | PIN | PIC32MKxxMCF64 | PIC32MKxxMCM64 | FUNCTION<br>PIN<br>MISMATCH | |-----|-------------------------------------------------------------|-------------------------------------------------------------|-----------------------------| | 1 | TCK/RPA7/PWM10H/PWM4L/PMD5/RA7 | TCK/RPA7/PWM10H/PWM4L/PMD5/RA7 | | | 2 | RPB14/PWM1H/VBUSON1/PMD6/RB14 | RPB14/PWM1H/VBUSON1/PMD6/RB14 | | | 3 | RPB15/PWM7H/PWM1L/PMD7/RB15 | RPB15/PWM7H/PWM1L/PMD7/RB15 | | | 4 | AN19/CVD19/RPG6/PMA5/RG6 | AN19/CVD19/RPG6/PWM10L/PMA5/RG6 | PWM10L | | 5 | AN18/CVD18/RPG7/PMA4/RG7 <sup>(6)</sup> | AN18/CVD18/RPG7/PWM10H/SCL1/PMA4/RG7 | PWM10H,<br>SCL1 | | 6 | AN17/CVD17/RPG8/PMA3/RG8 <sup>(7)</sup> | AN17/CVD17/RPG8/SDA1/PMA3/RG8 | SDA1 | | 7 | MCLR# | MCLR# | | | 8 | AN16/CVD16/RPG9/PMA2/RG9 | AN16/CVD16/RPG9/PMA2/RG9 | | | 9 | vss | vss | | | 10 | VDD | VDD | | | 11 | AN10/CVD10/RPA12/RA12 | AN10/CVD10/RPA12/RA12 | | | 12 | AN9/CVD9/RPA11/USBOEN1/RA11 | AN9/CVD9/RPA11/USBOEN1/RA11 | | | 13 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | | 14 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | | 15 | PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/<br>CTED2/RB0 | PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/<br>CTED2/RB0 | | | 16 | PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/<br>RPB1/CTED1/PMA6/RB1 | PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/<br>RPB1/CTED1/PMA6/RB1 | | | 17 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | | | 18 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | | | 19 | AVDD | AVDD | | | 20 | AVSS | AVSS | | | 21 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/<br>RPC0/RC0 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/<br>RPC0/RC0 | | | 22 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/<br>PMA7/RC1 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/PMA7/<br>RC1 | | | 23 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/<br>FLT3/PMA13/RC2 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/FLT3/<br>PMA13/RC2 | | | 24 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | | | 25 | vss | vss | | | 26 | VDD | VDD | | | 27 | AN12/CVD12/C2IN2-/C5IN2-/FLT5/PMA11/<br>RE12 <sup>(7)</sup> | AN12/CVD12/C2IN2-/C5IN2-/SDA4/FLT5/<br>PMA11/RE12 | SDA4 | | 28 | AN13/CVD13/C3IN2-/FLT6/PMA10/RE13 <sup>(6)</sup> | AN13/CVD13/C3IN2-/FLT6/SCL4/PMA10/RE13 | SCL4 | # TABLE 40-5: (64) PIN PIC32MKXXMCF64 VERSUS PIC32MKXXMCM64 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxMCF64 | PIC32MKxxMCM64 | FUNCTION<br>PIN<br>MISMATCH | |-----|--------------------------------------------------------|---------------------------------------------------|-----------------------------| | 29 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | | | 30 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | | | 31 | TDI/DAC3/AN26/CVD26/RPA8/PMA9/RA8 <sup>(7)</sup> | TDI/DAC3/AN26/CVD26/RPA8/SDA2/PMA9/RA8 | SDA2 | | 32 | FLT15/RPB4/PMA8/RB4 <sup>(6)</sup> | FLT15/RPB4/SCL2/PMA8/RB4 | SCL2 | | 33 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/<br>RPA4/T1CK/RA4 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/<br>RPA4/RA4 | T1CLK | | 34 | VBUS | VBUS | | | 35 | VUSB3V3 | VUSB3V3 | | | 36 | D- | D- | | | 37 | D+ | D+ | | | 38 | VDD | VDD | | | 39 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | | | 40 | OSCO/CLKO/RPC15/RC15 | OSCO/CLKO/RPC15/RC15 | | | 41 | VSS | VSS | | | 42 | RD8 | RD8 | | | 43 | PGED2/RPB5/USBID1/RB5 | PGD2/RPB5/SDA3/USBID1/RB5 | SDA3 | | 44 | PGEC2/RPB6/SCK2/PMA15/RB6 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | SCL3 | | 45 | DAC2/AN48/CVD48/RPC10/PMA14/PMCS/<br>RC10 | DAC2/AN48/CVD48/RPC10/PMA14/PMCS/<br>RC10 | | | 46 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | | | 47 | SOSCI/RPC13/RC13 | SOSCI/RPC13/RC13 | | | 48 | SOSCO/RPB8/RB8 | SOSCO/T1CK/RPB8/RB8 | T1CLK | | 49 | TMS/OA5IN-/AN27/CVD27/C5IN1-/RPB9/RB9 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/RPB9/<br>RB9 | LVDIN | | 50 | TRCLK/RPC6/PWM6H/RC6 | TRCLK/RPC6/PWM6H/RC6 | | | 51 | TRD0/RPC7/PWM12H/PWM6L/RC7 | TRD0/RPC7/PWM12H/PWM6L/RC7 | | | 52 | TRD1/RPC8/PWM5H/PMWR/RC8 | TRD1/RPC8/PWM5H/PMWR/RC8 | | | 53 | TRD2/RPD5/PWM12H/PMRD/RD5 | TRD2/RPD5/PWM12H/PMRD/RD5 | | | 54 | TRD3/RPD6/PWM12L/RD6 | TRD3/RPD6/PWM12L/RD6 | | | 55 | RPC9/PWM11H/PWM5L/RC9 | RPC9/PWM11H/PWM5L/RC9 | | | 56 | vss | vss | | | 57 | VDD | VDD | | | 58 | RPF0/PWM11H/RF0 | RPF0/PWM11H/RF0 | | | 59 | RPF1/PWM11L/RF1 | RPF1/PWM11L/RF1 | | # TABLE 40-5: (64) PIN PIC32MKXXMCF64 VERSUS PIC32MKXXMCM64 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxMCF64 | PIC32MKxxMCM64 | FUNCTION<br>PIN<br>MISMATCH | |-----|-----------------------------------|-----------------------------------|-----------------------------| | 60 | RPB10/PWM3H/PMD0/RB10 | RPB10/PWM3H/PMD0/RB10 | | | 61 | RPB11/PWM9H/PWM3L/PMD1/RB11 | RPB11/PWM9H/PWM3L/PMD1/RB11 | | | 62 | RPB12/PWM2H/PMD2/RB12 | RPB12/PWM2H/PMD2/RB12 | | | 63 | RPB13/PWM8H/PWM2L/CTPLS/PMD3/RB13 | RPB13/PWM8H/PWM2L/CTPLS/PMD3/RB13 | | | 64 | TDO/PWM4H/PMD4/RA10 | TDO/PWM4H/PMD4/RA10 | | TABLE 40-6: (64) PIN PIC32MKXXGPD/E64 VERSUS PIC32MKXXGPK64 PIN/FUNCTION MIGRATION DIFFERENCES | PIN | PIC32MKxxGPD/E64 | PIC32MKxxGPK64 | FUNCTION<br>PIN<br>MISMATCH | |-----|-------------------------------------------------------------|-------------------------------------------------------------|-----------------------------| | 1 | TCK/RPA7/PMD5/RA7 | TCK/RPA7/PMD5/RA7 | | | 2 | RPB14/VBUSON1/PMD6/RB14 | RPB14/VBUSON1/PMD6/RB14 | | | 3 | RPB15/PMD7/RB15 | RPB15/PMD7/RB15 | | | 4 | AN19/CVD19/RPG6/PMA5/RG6 | AN19/CVD19/RPG6/PMA5/RG6 | | | 5 | AN18/CVD18/RPG7/PMA4/RG7 <sup>(6)</sup> | AN18/CVD18/RPG7/SCL1/PMA4/RG7 | SCL1 | | 6 | AN17/CVD17/RPG8/PMA3/RG8 <sup>(7)</sup> | AN17/CVD17/RPG8/SDA1/PMA3/RG8 | SDA1 | | 7 | MCLR# | MCLR# | | | 8 | AN16/CVD16/RPG9/PMA2/RG9 | AN16/CVD16/RPG9/PMA2/RG9 | | | 9 | VSS | vss | | | 10 | VDD | VDD | | | 11 | AN10/CVD10/RPA12/RA12 | AN10/CVD10/RPA12/RA12 | | | 12 | AN9/CVD9/RPA11/USBOEN1/RA11 | AN9/CVD9/RPA11/USBOEN1/RA11 | | | 13 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | OA2OUT/AN0/C2IN4-/C4IN3-/RPA0/RA0 | | | 14 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | OA2IN+/AN1/C2IN1+/RPA1/RA1 | | | 15 | PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/<br>CTED2/RB0 | PGD3/VREF-/OA2IN-/AN2/C2IN1-/RPB0/<br>CTED2/RB0 | | | 16 | PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/<br>RPB1/CTED1/PMA6/RB1 | PGC3/OA1OUT/VREF+/AN3/C1IN4-/C4IN2-/<br>RPB1/CTED1/PMA6/RB1 | | | 17 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | PGC1/OA1IN+/AN4/C1IN1+/C1IN3-/C2IN3-/<br>RPB2/RB2 | | | 18 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | PGD1/OA1IN-/AN5/CTCMP/C1IN1-/RTCC/<br>RPB3/RB3 | | | 19 | AVDD | AVDD | | | 20 | AVSS | AVSS | | | 21 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/<br>RPC0/RC0 | OA3OUT/AN6/CVD6/C3IN4-/C4IN1+/C4IN4-/<br>RPC0/RC0 | | | 22 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/<br>PMA7/RC1 | OA3IN-/AN7/CVD7/C3IN1-/C4IN1-/RPC1/PMA7/<br>RC1 | | | 23 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/<br>FLT3/PMA13/RC2 | OA3IN+/AN8/CVD8/C3IN1+/C3IN3-/RPC2/<br>FLT3/PMA13/RC2 | | | 24 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | AN11/CVD11/C1IN2-/FLT4/PMA12/RC11 | | | 25 | VSS | VSS | | | 26 | VDD | VDD | | | 27 | AN12/CVD12/C2IN2-/C5IN2-/FLT5/PMA11/<br>RE12 <sup>(7)</sup> | AN12/CVD12/C2IN2-/C5IN2-/SDA4/FLT5/<br>PMA11/RE12 | SDA4 | | 28 | AN13/CVD13/C3IN2-/FLT6/PMA10/RE13 <sup>(6)</sup> | AN13/CVD13/C3IN2-/FLT6/SCL4/PMA10/RE13 | SCL4 | # TABLE 40-6: (64) PIN PIC32MKXXGPD/E64 VERSUS PIC32MKXXGPK64 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxGPD/E64 | PIC32MKxxGPK64 | FUNCTION<br>PIN<br>MISMATCH | |-----|--------------------------------------------------------|---------------------------------------------------|-----------------------------| | 29 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | AN14/CVD14/RPE14/FLT7/PMA1/RE14 | | | 30 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | AN15/CVD15/RPE15/FLT8/PMA0/RE15 | | | 31 | TDI/DAC3/AN26/CVD26/RPA8/PMA9/RA8 <sup>(7)</sup> | TDI/DAC3/AN26/CVD26/RPA8/SDA2/PMA9/<br>RA8 | SDA2 | | 32 | FLT15/RPB4/PMA8/RB4 <sup>(6)</sup> | FLT15/RPB4/SCL2/PMA8/RB4 | SCL2 | | 33 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/<br>RPA4/T1CK/RA4 | OA5IN+/DAC1/AN24/CVD24/C5IN1+/C5IN3-/<br>RPA4/RA4 | T1CLK | | 34 | VBUS | VBUS | | | 35 | VUSB3V3 | VUSB3V3 | | | 36 | D- | D- | | | 37 | D+ | D+ | | | 38 | VDD | VDD | | | 39 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | OSCI/CLKI/AN49/CVD49/RPC12/RC12 | | | 40 | OSCO/CLKO/RPC15/RC15 | OSCO/CLKO/RPC15/RC15 | | | 41 | VSS | VSS | | | 42 | VBAT, (VDD) | RD8 | VBAT, RD8 | | 43 | PGED2/RPB5/USBID1/RB5 | PGD2/RPB5/SDA3/USBID1/RB5 | SDA3 | | 44 | PGEC2/RPB6/SCK2/PMA15/RB6 | PGC2/RPB6/SCL3/SCK2/PMA15/RB6 | SCL3 | | 45 | DAC2/AN48/CVD48/RPC10/PMA14/PMCS/<br>RC10 | DAC2/AN48/CVD48/RPC10/PMA14/PMCS/<br>RC10 | | | 46 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | OA5OUT/AN25/CVD25/C5IN4-/RPB7/SCK1/<br>INT0/RB7 | | | 47 | SOSCI/RPC13/RC13 | SOSCI/RPC13/RC13 | | | 48 | SOSCO/RPB8/RB8 | SOSCO/T1CK/RPB8/RB8 | T1CLK | | 49 | TMS/OA5IN-/AN27/CVD27/C5IN1-/RPB9/RB9 | TMS/OA5IN-/AN27/CVD27/LVDIN/C5IN1-/<br>RPB9/RB9 | LVDIN | | 50 | TRCLK/RPC6/RC6 | TRCLK/RPC6/RC6 | | | 51 | TRD0/RPC7/RC7 | TRD0/RPC7/RC7 | | | 52 | TRD1/RPC8/PMWR/RC8 | TRD1/RPC8/PMWR/RC8 | | | 53 | TRD2/RPD5/PMRD/RD5 | TRD2/RPD5/PMRD/RD5 | | | 54 | TRD3/RPD6/RD6 | TRD3/RPD6/RD6 | | | 55 | RPC9/RC9 | RPC9/RC9 | | | 56 | vss | vss | | | 57 | VDD | VDD | | | 58 | RPF0/RF0 | RPF0/RF0 | | | 59 | RPF1/RF1 | RPF1/RF1 | | # TABLE 40-6: (64) PIN PIC32MKXXGPD/E64 VERSUS PIC32MKXXGPK64 PIN/FUNCTION MIGRATION DIFFERENCES (CONTINUED) | PIN | PIC32MKxxGPD/E64 | PIC32MKxxGPK64 | FUNCTION<br>PIN<br>MISMATCH | |-----|-----------------------|-----------------------|-----------------------------| | 60 | RPB10/PMD0/RB10 | RPB10/PMD0/RB10 | | | 61 | RPB11/PMD1/RB11 | RPB11/PMD1/RB11 | | | 62 | RPB12/PMD2/RB12 | RPB12/PMD2/RB12 | | | 63 | RPB13/CTPLS/PMD3/RB13 | RPB13/CTPLS/PMD3/RB13 | | | 64 | TDO/PMD4/RA10 | TDO/PMD4/RA10 | | # 41.0 APPENDIX B: REVISION HISTORY ### Revision A (October 2017) This is the initial released version of the document. ### **Revision B (August 2019)** This revision includes typographical and formatting updates throughout the data sheet text. All other major updates are referenced by their respective section in Table 41-1. TABLE 41-1: MAJOR SECTION UPDATES | Section Name | Update Description | |-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1.0 "Device Overview" | PB5 was changed to SYSCLK and CAN1 through CAN4 references were updated to CAN FD1 through CAN FD4, respectively in the PIC32MK GPK/GPL/MCM With CAN FD Family Block Diagram (see Figure 1-1). | | 8.0 "CPU Exceptions and Interrupt Controller" | Prefetch Cache Event (IRQ 247) was added (see Table 8-3). | | 27.0 "Op Amp/Comparator Module" | Updated images for FIGURE 27-1: "Op amp 1/Comparator 1 Module Block Diagram", FIGURE 27-2: "Op amp 2/Comparator 2 Module Block Diagram", FIGURE 27-3: "Op amp 3/Comparator 3 Module Block Diagram", FIGURE 27-4: "Comparator 4 Module Block Diagram", and FIGURE 27-5: "Op amp 5/Comparator 5 Module Block Diagram". | | | Added new sections 27.7 "Op-amp High Performance Mode 10 MHz-100MHz Use Requirements (CMXCON <oplpwr> = 0)" and 27.7.1 "OP AMP LOW-POWER MODE ≤10 MHz USE REQUIREMENTS (CMxCON<oplpwr> = 1)"</oplpwr></oplpwr> | | 31.0 "Motor Control PWM Module" | Note 2 was added to the PWM Primary Special Event Compare (SEVTCMP) register (see Register 31-3 SEVTCMP: PWM Primary Special Event Compare Register). | | | Note 1 was added to the PWM Secondary Special Event Compare (SSEVTCMP) register (see Register 31-7 SSEVTCMP: PWM Secondary Special Event Compare Register). | | | A Note was added to the PWM Primary Trigger Compare Value (TRIGx) register (see Register 31-19 TRIGx: PWM Primary Trigger Compare Value Register 'x' ('x' = 1 through 12) ). | | | Note 2 was added to the Secondary PWM Trigger Compare (STRIGx) register (see Register 31-21 STRIGx: Secondary PWM Trigger Compare Register 'x' ('x' = 1 through 12) ). | | 37.0 "Electrical Characteristics" | Parameter OA16 (Gain) was updated in the Op Amp Specifications (see Table 37-30). | | Section 40.0, Appendix A: Migration Guide | Added a new Appendix for Hardware Migration. | ### Revision C (March 2020) This revision includes typographical and formatting updates throughout the data sheet text. The device name was changed throughout the document from PIC32MK GPK/GPL/MCM to PIC32MK GPK/MCM. All other major updates are referenced by their respective section in Table 41-2. **TABLE 41-2: MAJOR SECTION UPDATES** | Section Name | Update Description | |---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Section 27.0 "Op Amp/Comparator Module" | Updated FIGURE 27-9: "OP-AMP GAIN ≥ 2: HIGH PERFORMANCE<br>≥10 MHz SINGLE ENDED MODE REQUIREMENTS (CMx-<br>CON <oplpwr> = 0)" and FIGURE 27-10: "OP-AMP HIGH PERFOR-<br/>MANCE ≥10 MHz DIFFERENTIAL MODE REQUIREMENTS<br/>(CMxCON<oplpwr> = 0)" with a new line item for CLOAD</oplpwr></oplpwr> | | | Updated Figures 27.8 "Op amp Circuit Examples", FIGURE 27-<br>16: "OP-amp configuration circuit examples", FIGURE 27-16: "OP-Amp Configuration Circuit examples", FIGURE 27-17: "OP-Amp Configuration Circuit examples", and 2FIGURE 27-18: "OP-Amp Configuration Circuit examples" with new information | | Section 25.0 "12-bit High-Speed<br>Successive Approximation<br>Register (SAR) Analog-to-Digital<br>Converter (ADC)" | Updated data for the WOVERR bit for Register 25-28 ADCDSTAT: ADC DMA Status Register . | | Section 31.0 "Motor Control PWM Module" | Added new diagram, FIGURE 31-2: "3-Phase AC Motor Control Example" | | Section 1.0 "Device Overview" | Updated The description column with more specific information for Table 1-15, "USB1 and USB2 Pinout I/O Descriptions," on page 28. | | Section 1.0 "Device Overview" | Updated QFN in all tables to VQFN. | | 37.0 "Electrical Characteristics" | Added new table Table 37-13, "DC CHARACTERISTICS: PROGRAM FLASH MEMORY WAIT STATES FOR ACTIVE HIGH-POWER MODE," on page 690. | ### Revision D (07/2020) This revision included typographical changes throughout the document. The following updates were made for this revision of the document: | Section | Updates | | | |-------------------------------------------|-------------------------------------------------------------------------------------------------|--|--| | Section 5.0 "Flash Program Memory" | Updated Register 5-8 NVMCON2: Flash Programming Control Register 2 with new Reserved bits | | | | Section 10.0 "Prefetch Module" | Updated the table for the PFMWS bit for Register 10-1 CHECON: Cache Module Control Register | | | | Section 27.0 "Op Amp/Comparator Module" | Added a new section, Section 27.8 "Op amp Circuit Examples" | | | | | Added a second note to Figure 27-18 | | | | Section 37.0 "Electrical Characteristics" | Added new values for SDAx and SCLx in Table 37-9 | | | | Coulon of to Electrical offaracteristics | Updated Table 37-13, removed the note | | | ### **Revision E (01/2021)** This revision included typographical changes throughout the document. The following updates were made for this revision of the document: | Section | Updates | |-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | General | Updated Master and Slave terminology throughout the document to "Host" and "Client" | | Section 1.0 "Device Overview" | Updated the program memory bit width from 128 to 140 in FIG-<br>URE 1-1: "PIC32MK GPK/MCM with CAN FD Family Block<br>Diagram" | | Section 7.0 "Resets" | Updated Register 7-3 RNMICON: Non-Maskable Interrupt (NMI) Control Register with a new description and note for bit 24 and the addition of a new bit 16 description | | Section 8.0 "CPU Exceptions and Interrupt Controller" | Updated Table 8-1, "ISR Latency Information," on page 122 with correct nomenclature to reference binary values | | Section 9.0 "Oscillator Configuration" | Updated Register 9-1 OSCCON: Oscillator Control Register<br>with a new bit description and information in the note for bit 7<br>CLKLOCK | | Section 28.0 "Charge Time Measurement Unit (CTMU)" | Updated definition for EDG1SEL<3:0> (CTMUCON<29:26>) and EDG2SEL<3:0> (CTMUCON<29:26>) for bit value - 4'b1100 in Register 28-1 CTMUCON: CTMU Control Register | | | | y | | |--------|--|---|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### **INDEX** | A | | Power-Down Current (IPD) | 685 | |-------------------------------------------------|------------|------------------------------------------------------------------------------------|-------| | AC Characteristics | 691 | Program Memory | | | ADC Module Specifications | | Temperature and Voltage Specifications | | | Analog-to-Digital Conversion Requirements | | Development Support | | | Assembler | | Direct Memory Access (DMA) Controller | 194 | | MPASM Assembler | 677 | E | | | <b>n</b> | | _ | 000 | | В | | Electrical Characteristics | | | Block Diagrams | | AC | | | CPU | 48 | Errata | 10 | | CTMU Configurations | | External Clock | 704 | | Time Measurement | 558 | Timer1 Timing Requirements | | | DMA | 194 | Timer2, 3, 4, 5 Timing Requirements | | | Input Capture | 310 | Timing Requirements | 692 | | Inter-Integrated Circuit (I2C) | 337 | F | | | Interrupt Controller | | | 2 442 | | JTAG Programming, Debugging and Trace Ports | 672 | Flash Program Memory96 RTSP Operation | | | Op amp/Comparator Module 530, 531, 532, 533 | 3, 534 | K13F Operation | 90 | | Output Compare Module | 316 | I | | | PIC32 CAN Module | 464 | I/O Ports | 240 | | PMP Pinout and Connections to External Devices. | 359 | Parallel I/O (PIO) | | | Prefetch Module | 188 | Write/Read Timing | | | Prefetch Module Block Diagram | 188 | Input Change Notification | | | Quadrature Encoder Interface | | Instruction Set | | | Reset System | 113 | Inter-Integrated Circuit (I2C) | | | RTCC | 374 | Internal FRC Accuracy | | | SPI Module | 324 | · | | | Timer1 | 286 | Internal LPRC AccuracyInternat Address | | | Timer2/3/4/5 (16-Bit)29 | 1, 292 | Interrupt Controller | 100 | | Typical Multiplexed Port Structure | | IRG, Vector and Bit Location | 107 | | UART | | IRG, Vector and bit Location | 121 | | WDT and Power-up Timer | 305 | M | | | and On-Chip Voltage Regulator | 072 | Devices with 1024 KB Program Memory and 51 RAM Devices with 512 KB Program Memory | 71 | | C Compilers | | Memory Organization | | | MPLAB XC32 | 677 | Layout | | | Charge Time Measurement Unit. See CTMU. | | Microchip Internet Web Site | | | Comparator | 000 | Motor Control PWM | | | Specifications | | MPLAB ASM30 Assembler, Linker, Librarian | 677 | | Comparator Module | | MPLAB ICD 3 In-Circuit Debugger | 678 | | Configuration Bit | | MPLAB PM3 Device Programmer | 678 | | Configuring Analog Port Pins | | MPLAB REAL ICE In-Circuit Emulator System | 678 | | Controller Area Network (CAN) | 463 | MPLAB X Integrated Development Environment Softwa | re | | CPU Auditorium Commitme | 40 | 676 | | | Architecture Overview | | MPLINK Object Linker/MPLIB Object Librarian | 677 | | Coprocessor 0 Registers | | • | | | Core Exception Types | | 0 | | | EJTAG Debug Support | | Op Amp | | | Power Management | | Specifications | | | CPU Module | 35, 47 | Oscillator Configuration | 167 | | СТМИ | <b>500</b> | OTG Electrical Specifications | 738 | | Registers | | Output Compare | 316 | | Customer Change Notification Service | | D | | | Customer Notification Service | | Р | | | Customer Support | 780 | Packaging | 744 | | D | | Details | | | | 407 | Marking | | | Data EEPROM | | Parallel Master Port (PMP) | 358 | | DC Characteristics | | Parallel Master Port Read Requirements | 736 | | I/O Pin Input Specifications | | Parallel Master Port Write Requirements | 737 | | I/O Pin Output Specifications | | Parallel Slave Port Requirements | | | Idle Current (IIDLE) | 084 | PIC32MK Family USB Interface Diagram | 223 | | | | | | | PICkit 3 In-Circuit Debugger/Programmer678 | Timer1-Timer9 | |-------------------------------------------------------------------|-------------------------------------------------------| | Pinout I/O Descriptions | UART1 and UART2345 | | MCPWM Fault, Current Limit and Dead-Time Compen- | UART3-UART6346 | | sation30 | USB1 and USB2224 | | MCPWM Generators 1 through 1229 | Registers | | Quadrature Encoders 1 through 631 | [pin name]R (Peripheral Pin Select Input) 283 | | Pinout I/O Descriptions (table) . 15, 16, 17, 18, 21, 22, 23, 24, | AD1CON1 (A/D Control 1) | | 26, 27, 28, 32, 33 | AD1CON1 (ADC Control 1) | | PORTB Register Map (64-pin and 100-pin Devices) 264 | ADCANCON (ADC Analog Warm-up Control Register). | | Power-on Reset (POR) | 457 | | and On-Chip Voltage Regulator672 | ADCBASE (ADC Base)445 | | Power-Saving Features641 | ADCCMP1CON (ADC Digital Comparator 1 Contro | | with CPU Running641 | Register)440 | | Prefetch Cache SFR Summary108 | ADCCMPENx (ADC Digital Comparator 'x' Enable Reg- | | Prefetch Module | ister ('x' = 1 through 4))422 | | 0 | ADCCMPx (ADC Digital Comparator 'x' Limit Value Reg | | Q | ister ('x' = 1 through 4))423 | | Quadrature Encoder Interface (QEI)568 | ADCCMPxCON (ADC Digital Comparator 'x' Contro | | R | Register ('x' = 2 through 4))443 | | | ADCCNTB (ADC Channel Sample Count Base Address | | Real-Time Clock and Calendar (RTCC)374 | 448 | | Register Map | ADCCON1 (ADC Control Register 1) | | Comparator Voltage Reference | ADCCON2 (ADC Control Register 2) | | CTMU551, 559, 565 | ADCCON3 (ADC Control Register 3) 402 | | Device ADC Calibration Summary652 | ADCCSS1 (ADC Common Scan Select Register 1). 418 | | Device Configuration Word Summary649, 650 | ADCCSS2 (ADC Common Scan Select Register 2). 419 | | Device EEDATA Calibration Summary652 | ADCDATAx (ADC Output Data Register ('x' = 0-27, 33- | | Device Serial Number Summary653 | 41, and 45-53))449 | | DMA Channel 0-3196 | ADCDMAB (ADC Channel Sample count Base Address | | DMA CRC195 | 448 | | DMA Global195 | ADCDSTAT1 (ADC Data Ready Status Register 1). 420 | | Flash Controller97, 298, 306 | ADCDSTAT2 (ADC Data Ready Status Register 2). 420 | | I2C1 and I2C2338 | ADCEIEN1 (ADC Early Interrupt Enable Register 1) 453 | | I2C3 and I2C4339 | ADCEIEN2 (ADC Early Interrupt Enable Register 2) 454 | | Input Capture 10-16313 | ADCEISTAT2 (ADC Early Interrupt Status Register 2) | | Input Capture 1-9312 | 456 | | Interrupt136 | ADCFLTRx (ADC Digital Filter 'x' Register ('x' = 1 | | Op amp/Comparator551 | through 6))42 <sup>4</sup> | | Oscillator Configuration171 | ADCGIRQEN1 (ADC Interrupt Enable Register 1) 416 | | Output Compare 10-16320 | ADCIMCON1 (ADC Input Mode Control Register 1) 408 | | Output Compare1-9318 | ADCIMCON2 (ADC Input Mode Control Register 2) 411 | | Parallel Master Port360 | ADCIMCON3 (ADC Input Mode Control Register 3) 413 | | Peripheral Pin Select Input274 | ADCIMCON4 (ADC Input Mode Control Register 4) 415 | | Peripheral Pin Select Output280 | ADCIRQEN2 (ADC Interrupt Enable Register 2) 417 | | PORTA (100-pin Devices) | ADCSYSCFG0 (ADC System Configuration Register 0) | | PORTA (64-pin Devices)263 | 460 | | PORTB264 | ADCSYSCFG1 (ADC System Configuration Register 1) | | PORTC (64-pin and 100-pin Devices)265 | 461 | | PORTD267 | ADCTRG1 (ADC Trigger Source 1 Register) 426 | | PORTD (100-pin Devices)266 | ADCTRG2 (ADC Trigger Source 2 Register) 428 | | PORTE (100-pin Devices)268 | ADCTRG3 (ADC Trigger Source 3 Register) 430 | | PORTE (64-pin Devices)269 | ADCTRG4 (ADC Trigger Source 4 Register) 432 | | PORTF (100-pin Devices)270 | ADCTRG5 (ADC Trigger Source 5 Register) 434 | | PORTF (64-pin Devices)271 | ADCTRG6 (ADC Trigger Source 6 Register) 436 | | PORTG (100-pin Devices)272 | ADCTRG7 (ADC Trigger Source 7 Register) 438 | | PORTG (64-pin Devices)273 | ADCTRGMODE (ADC Triggering Mode for Dedicated | | Prefetch189 | ADC)400 | | RTCC375 | ADCTRGSNS (ADC Trigger Level/Edge Sensitivity) 450 | | SPI1 andSPI2325 | ADCxCFG (ADCx Configuration Register 'x' ('x' = 0 | | SPI3 through SPI6326 | through 5 and 7))459 | | System Bus83 | ADCxTIME (Dedicated ADCx Timing Register 'x' ('x' = 0 | | System Bus Target 083 | through 5))45 | | System Bus Target 184 | ALRMDATE (Alarm Date Value) | | System Bus Target 286 | ALRMDATECLR (ALRMDATE Clear) | | System Bus Target 387 | ALRMDATESET (ALRMDATE Set) | | System Control114 | ALRMTIME (Alarm Time Value) | | ALRMTIMECLR (ALRMTIME Clear)383 | Register - CP1 Register 28) 65 | |-----------------------------------------------------------------------------------------|--------------------------------------------------------| | ALRMTIMEINV (ALRMTIME Invert) | FEXR (Floating Point Exceptions Status Register - CP1 | | ALRMTIMESET (ALRMTIME Set) | Register 26)64 | | ALTDTRx (PWM Alternate Dead Time Register) 625 | FIR (Floating Point Implementation Register - CP1 Reg- | | ALTDTRx (PWM Alternate Dead-Time Register) 626 | ister 0) 62 | | AUXCONx (PWM Auxiliary Control Register) 634 | I2CxCON (I2C Control)340 | | BFxSEQ (Boot Flash 'x' Sequence)79 | I2CxSTAT (I2C Status)342 | | CFGCON2 (EE Data and Op amp Configuration) 669 | ICxCON (Input Capture x Control) | | CHECON (Cache Module Control)190 | IFSx (Interrupt Flag Status) | | CHEHIT (Cache Hit Status)192 | INDxCNT (Index Counter Register)584 | | CHEMIS (Cache Miss Status)193 | INTCON (Interrupt Control) 159 | | CHOP (PWM Chop Clock Generator Register) 610 | INTSTAT (Interrupt Status) | | CMSTAT (Op amp/Comparator Status)552 | INTxHLD (Interval Timer Hold Register) 583 | | CMxCON (Op amp/Comparator 'x' Control)553 | INTxTMR (Interval Timer Register) 584 | | CMxMSKCON (Op amp/Comparator 'x' Mask Control) | IOCONx (PWM I/O Control Register) 615 | | 556 | IPCx (Interrupt Priority Control) | | CNCONx (Change Notice Control for PORTx) 284 | IPTMR Interrupt Proximity Timer) | | CONFIG (Configuration Register - CP0 Register 16, Se- | LEBCONx (Leading Edge Blanking Control Register) | | lect 0) 55 | 627, 631, 632 | | CONFIG1 (Configuration Register 1 - CP0 Register 16, | LEBDLYx (Leading-Edge Blanking Delay Register). 633 | | Select 1) | NVMADDR (Flash Address) | | CONFIG3 (Configuration Register 3 - CP0 Register 16, | NVMBWP (Flash Boot (Page) Write-protect) 103 | | Select 3) | NVMCON (Programming Control) | | CONFIG5 (Configuration Register 5 - CP0 Register 16, | NVMDATA (Flash Data) | | Select 5) | NVMKEY (Programming Unlock) | | CONFIG7 (Configuration Register 7 - CP0 Register 16, | NVMPWP (Program Flash Write-Protect) | | Select 7) | NVMSRCADDR (Source Data Address) | | CTMUCON (CTMU Control)560 | OCxCON (Output Compare x Control) | | DCHxCON (DMA Channel 'x' Control) | OSCCON (Oscillator Control) | | DCHxCPTR (DMA Channel x Cell Pointer) | OSCTUN (FRC Tuning) | | DCHxCSIZ (DMA Channel x Cell-Size)219 | PDCx (PWM Generator Duty Cycle Register) 622 | | DCHxDAT (DMA Channel x Pattern Data) | PHASEx (PWM Primary Phase Shift Register) 624 | | DCHxDPTR (Channel x Destination Pointer) | PMADDR (Parallel Port Address) | | DCHxDSA (DMA Channel x Destination | PMAEN (Parallel Port Pin Enable) | | Start Address) | PMCON (Parallel Port Control) | | DCHxDSIZ (DMA Channel x Destination Size)216 DCHxECON (DMA Channel x Event Control)211 | PMDIN (Parallel Port Input Data) | | · · | | | DCHxINT (DMA Channel x Interrupt Control)212 DCHxSPTR (DMA Channel x Source Pointer)217 | PMMODE (Parallel Port Mode) | | DCHxSSA (DMA Channel x Source Start Address) . 214 | PMSTAT (Parallel Port Status (Client Modes Only). 369 | | DCHxSSIZ (DMA Channel x Source Size) | PMTMR (Primary Host Time Base Timer Register) . 606 | | DCRCCON (DMA CRC Control)205 | PMWADDR (Parallel Port Write Address) | | DCRCDATA (DMA CRC Data)207 | POSxCNT (Position Counter Register) 581 | | DCRCXOR (DMA CRCXOR Enable) | PRISS (Priority Shadow Select) | | DEVCFG0 (Device Configuration Word 0 | PSCNT (Post Status Configure DMT Count Status) 302 | | DEVCFG1 (Device Configuration Word 1 | PSINTV (Post Status Configure DMT Interval Status) | | DEVCFG2 (Device Configuration Word 2 | 303 | | DEVCFG3 (Device Configuration Word 3 | PTCON (PWM Primary Time Base Control Register) | | DEVCFG4 (Device Configuration Word 4) | 603 | | DEVCP0 (Device Code-protect 0) | PTPER (Primary Host Time Base Period Register) . 605 | | DEVID (Device and Revision ID)670 | PWMCONx (PWM Control Register) | | DEVSIGN0 (Device Signature Word 0) | PWMKEY | | DMAADDR (DMA Address) | (PWM Unlock Register)611 | | DMAADDR (DMR Address)204 | QEIxCMPL (Capture Low Register) | | DMACON (DMA Controller Control)202 | QEIxCON QEIx Control) | | DMASTAT (DMA Status)203 | QEIxICC (QEIx Initialize/Capture/Compare Register) | | DMSTAT (Deadman Timer Status)301 | 585 | | DMTCLR (Deadman Timer Clear) | QEIxIOC (QEIx I/O Control) 577 | | DMTCNT (Deadman Timer Count)302 | QEIxSTAT (QEIx Status) | | DMTCON (Deadman Timer Control) | REFOxCON (Reference Oscillator Control ('x' = 1-4)) | | DMTPRECLR (Deadman Timer Preclear)299 | 181 | | FCCR (Floating Point Condition Codes Register - CP1 | REFOxTRIM (Reference Oscillator Trim ('x' = 1-4)). 183 | | Register 25)63 | RPnR (Peripheral Pin Select Output) | | FCSR (Floating Point Control and Status Register - CP1 | RSWRST (Software Reset) 117, 118, 120 | | Register 31) 66 | RTCCON (RTCC Control) | | FENR (Floating Point Exceptions and Modes Enable | RTCDATE (RTC Date Value) | | RTCTIME (RTC Time Value) | 380 | VELxHLD (Velocity Hold Register) | 583 | |----------------------------------------------------|-----------|---------------------------------------------------|------------| | SBFLAG (System Bus Status Flag) | 38, 109 | WDTCON (Watchdog Timer Control) | 307 | | SBTxECLRM (System Bus Target 'x' Multiple Erro | | Revision History | | | 92 | | RTCALRM (RTC ALARM Control) | 378 | | SBTxECLRS (System Bus Target 'x' Single Error | Single) | | | | 92 | , | S | | | SBTxECON (System Bus Target 'x' Error Control | )91, | Serial Peripheral Interface (SPI) | 324 | | 112 | , | Software Simulator (MPLAB X SIM) | 678 | | SBTxELOG1 (System Bus Target 'x' Error Log 1) | 89. | Special Features | 648 | | 111 | , | | | | SBTxELOG2 (System Bus Target 'x' Error Log 2) | 91 | Т | | | 111 | 0 1, | Timer1 Module | 285 | | SBTxRDy (System Bus Target 'x' Region 'y' Rea | ad Per- | Timer2/3, Timer4/5, Timer6/7, and Timer8/9 Module | es 291 | | missions) | | Timing Diagrams | | | SBTxREGy (System Bus Target 'x' Region 'y') | | ČAN I/O | 729 | | SBTxWRy (System Bus Target 'x' Region 'y' Wri | | EJTAG | | | | | External Clock | | | missions) | | I/O Characteristics | | | SDCx (PWM Secondary Duty Cycle Register) | | I2Cx Bus Data (Host Mode) | | | SEVTCMP (Special Event Compare Register) | | I2Cx Bus Data (Client Mode) | | | SMTMR (Secondary Host Time Base Timer Regi | ster) | I2Cx Bus Start/Stop Bits (Host Mode) | | | 609 | 004 | I2Cx Bus Start/Stop Bits (Client Mode) | | | SPIxBRG (SPIx Baud Rate Generator) | | . , , | | | SPIxBUF (SPIx Buffer) | | Input Capture (CAPx) Motor Control PWM Fault | | | SPIxCON (SPI Control) | | | | | SPIxCON2 (SPI Control 2) | | OCx/PWM | | | SPIxSTAT (SPI Status) | | Output Compare (OCx) | | | SPLLCON (System PLL Control) | | Parallel Master Port Read | | | SSEVTCMP (PWM Secondary Special Event Co | | Parallel Master Port Write | | | Register) | 608 | Parallel Slave Port | | | STCON (Secondary Host Time Base Control Reg | gister) . | QEA/QEB Input | | | 607 | | SPIx Host Mode (CKE = 0) | | | STPER (Secondary Host Time Base Period Regi | ster) | SPIx Host Mode (CKE = 1) | | | 608 | | SPIx Client Mode (CKE = 0) | | | STRIGx (Secondary PWM Trigger Compare Reg | ister) | SPIx Client Mode (CKE = 1) | | | 631 | | Timer1, 2, 3, 4, 5 External Clock | 701 | | T1CON (Type A Timer Control) | 288 | TimerQ (QEI Module) External Clock | | | TMR (PWM Timer Register) | 635 | UART Reception | 356 | | TMRx (PWM Timer Register 'x') | 635 | UART Transmission (8-bit or 9-bit Data) | 356 | | TRGCONx (PWM Trigger Control Register) | | Timing Requirements | | | TRIGx (PWM Trigger Compare Value Register) | | CLKO and I/O | 697 | | TxCON (Type B Timer Control) | | Timing Specifications | | | UPLLCON USB PLL Control) | | CAN I/O Requirements | 729 | | UxADDR (USB Address) | | Input Capture Requirements | 702 | | UxBDTP1 (USB BDT Page 1) | | Motor Control PWM Requirements | . 739, 740 | | UxBDTP2 (USB BDT Page 2) | | Output Compare Requirements | 703 | | UxBDTP3 (USB BDT Page 3) | | QEI External Clock Requirements | 727 | | UxCNFG1 (USB Configuration 1) | | Quadrature Decoder Requirements | 728 | | UxCON (USB Control) | | Simple OCx/PWM Mode Requirements | . 703, 705 | | UxEIE (USB Error Interrupt Enable) | | SPIx Host Mode (CKE = 0) Requirements | 707 | | UxEIR (USB Error Interrupt Status) | | SPIx Host Mode (CKE = 1) Requirements | | | UxEP0-UxEP15 (USB Endpoint Control) | | SPIx Client Mode (CKE = 1) Requirements | | | UxFRMH (USB Frame Number High) | | SPIx Client Mode Requirements (CKE = 0) | | | UxFRML (USB Frame Number Low) | | | | | | | U | | | UxIE (USB Interrupt) | | UART | 344 | | UxIR (USB Interrupt)<br>UxOTGCON (USB OTG Control) | | USB On-The-Go (OTG) | | | | | , , | | | UxOTGIE (USB OTG Interrupt Enable) | | V | | | UxOTGIR (USB OTG Interrupt Status) | | Voltage Regulator (On-Chip) | 672 | | UxOTGSTAT (USB OTG Status) | | | | | UxPWRC (USB Power Control) | | W | | | UxSOF (USB SOF Threshold) | | WWW Address | 780 | | UxSTAT (USB Status) | | WWW, On-Line Support | | | UxTOK (USB Token) | | ··, -·· | | | VELxCNT (Velocity Counter Register) | 582 | | | ### THE MICROCHIP WEB SITE Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information: - Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software - General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing - Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives # CUSTOMER CHANGE NOTIFICATION SERVICE Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest. To register, access the Microchip web site at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions. ### **CUSTOMER SUPPORT** Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - Field Application Engineer (FAE) - Technical Support Customers should contact their distributor, representative or Field Application Engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document. Technical support is available through the web site at: http://microchip.com/support ### PRODUCT IDENTIFICATION SYSTEM To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office. PIC32MK1024GPK100-I/PT: General Purpose PIC32MK without CAN FD, MIPS32<sup>®</sup> microAptiv MCU core, 1024 KB program memory, 100-pin, Industrial temperature, TQFP package. ### Flash Memory Family MK = MIPS32<sup>®</sup> microAptiv MCU Core with Floating Point Unit (FPU) Architecture Flash Memory Size 0512 = 512 KB 1024 = 1024 KB GP = General Purpose Microcontroller Family MC = Motor Control Microcontroller Family Family Key Feature = PIC32 GP Family Features (without CAN) = PIC32 MC Family Features (with CAN FD, PWM, and QEI) Pin Count 064 = 64-pin 100 = 100-pin Temperature Range = -40°C to +85°C (Industrial) = -40°C to +105°C (V-Temp) = -40°C to +125°C (Extended) R4X = 64-Lead (9x9x0.9 mm) VQFN (Very Thin Plastic Quad Flat-pack) PT = 64-Lead (10x10x1 mm) TQFP (Thin Quad Flatpack) PT = 100-Lead (12x12x1 mm) TQFP (Thin Quad Flatpack) Package Three-digit QTP, SQTP, Code or Special Requirements (blank otherwise) Pattern ES = Engineering Sample #### Note the following details of the code protection feature on Microchip devices: - · Microchip products meet the specifications contained in their particular Microchip Data Sheet. - · Microchip believes that its family of products is secure when used in the intended manner and under normal conditions. - There are dishonest and possibly illegal methods being used in attempts to breach the code protection features of the Microchip devices. We believe that these methods require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Attempts to breach these code protection features, most likely, cannot be accomplished without violating Microchip's intellectual property rights. - Microchip is willing to work with any customer who is concerned about the integrity of its code. - Neither Microchip nor any other semiconductor manufacturer can guarantee the security of its code. Code protection does not mean that we are guaranteeing the product is "unbreakable." Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act. Information contained in this publication is provided for the sole purpose of designing with and using Microchip products. Information regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. THIS INFORMATION IS PROVIDED BY MICROCHIP "AS IS". MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE OR WARRANTIES RELATED TO ITS CONDITION, QUALITY, OR PERFORMANCE. IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDI-RECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUEN-TIAL LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THE INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THE INFORMATION. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated. For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality. #### **Trademarks** The Microchip name and logo, the Microchip logo, Adaptec, AnyRate, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, chipKIT, chipKIT logo, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PackeTime, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. AgileSwitch, APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, FlashTec, Hyper Speed Control, HyperLight Load, IntelliMOS, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet-Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, WinPath, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A. Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, Augmented Switching, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, $Crypto Companion, \ Crypto Controller, \ ds PICDEM, \ ds PICDEM.net,$ Dynamic Average Matching, DAM, ECAN, Espresso T1S, EtherGREEN, IdealBridge, In-Circuit Serial Programming, ICSP, INICnet, Intelligent Paralleling, Inter-Chip Connectivity, JitterBlocker, maxCrypto, maxView, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, RTAX, RTG4, SAM-ICE, Serial Quad I/O. simpleMAP, SimpliPHY, SmartBuffer, SMART-I.S., storClad, SQI, SuperSwitcher, SuperSwitcher II, Switchtec, SynchroPHY, Total Endurance, TSHARC, USBCheck, VariSense, VectorBlox, VeriPHY, ViewSpan, WiperLock, XpressConnect, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other $\ensuremath{\mathsf{SQTP}}$ is a service mark of Microchip Technology Incorporated in the U.S.A. The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries. GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries. All other trademarks mentioned herein are property of their respective companies. © 2017-2021, Microchip Technology Incorporated, All Rights Reserved. ISBN: 978-1-5224-7502-6 ### **Worldwide Sales and Service** #### **AMERICAS** Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://www.microchip.com/ support Web Address: www.microchip.com Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455 **Austin, TX** Tel: 512-257-3370 **Boston** Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088 Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075 **Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924 **Detroit** Novi, MI Tel: 248-848-4000 Houston, TX Tel: 281-894-5983 Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453 Tel: 317-536-2380 Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Fax: 949-462-9608 Tel: 951-273-7800 **Raleigh, NC** Tel: 919-844-7510 New York, NY Tel: 631-435-6000 **San Jose, CA** Tel: 408-735-9110 Tel: 408-436-4270 **Canada - Toronto** Tel: 905-695-1980 Fax: 905-695-2078 #### ASIA/PACIFIC Australia - Sydney Tel: 61-2-9868-6733 **China - Beijing** Tel: 86-10-8569-7000 **China - Chengdu** Tel: 86-28-8665-5511 **China - Chongqing** Tel: 86-23-8980-9588 **China - Dongguan** Tel: 86-769-8702-9880 China - Guangzhou Tel: 86-20-8755-8029 **China - Hangzhou** Tel: 86-571-8792-8115 China - Hong Kong SAR Tel: 852-2943-5100 China - Nanjing Tel: 86-25-8473-2460 China - Qingdao Tel: 86-532-8502-7355 China - Shanghai Tel: 86-21-3326-8000 **China - Shenyang** Tel: 86-24-2334-2829 **China - Shenzhen** Tel: 86-755-8864-2200 China - Suzhou Tel: 86-186-6233-1526 **China - Wuhan** Tel: 86-27-5980-5300 China - Xian Tel: 86-29-8833-7252 **China - Xiamen** Tel: 86-592-2388138 **China - Zhuhai** Tel: 86-756-3210040 #### ASIA/PACIFIC India - Bangalore Tel: 91-80-3090-4444 India - New Delhi Tel: 91-11-4160-8631 India - Pune Tel: 91-20-4121-0141 **Japan - Osaka** Tel: 81-6-6152-7160 **Japan - Tokyo** Tel: 81-3-6880- 3770 Korea - Daegu Tel: 82-53-744-4301 Korea - Seoul Tel: 82-2-554-7200 Malaysia - Kuala Lumpur Tel: 60-3-7651-7906 Malaysia - Penang Tel: 60-4-227-8870 Philippines - Manila Tel: 63-2-634-9065 **Singapore** Tel: 65-6334-8870 **Taiwan - Hsin Chu** Tel: 886-3-577-8366 Taiwan - Kaohsiung Tel: 886-7-213-7830 **Taiwan - Taipei** Tel: 886-2-2508-8600 Thailand - Bangkok Tel: 66-2-694-1351 **Vietnam - Ho Chi Minh** Tel: 84-28-5448-2100 #### **EUROPE** Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 **Denmark - Copenhagen** Tel: 45-4485-5910 Fax: 45-4485-2829 Finland - Espoo Tel: 358-9-4520-820 France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 Germany - Garching Tel: 49-8931-9700 **Germany - Haan** Tel: 49-2129-3766400 Germany - Heilbronn Tel: 49-7131-72400 Germany - Karlsruhe Tel: 49-721-625370 **Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44 Germany - Rosenheim Tel: 49-8031-354-560 Israel - Ra'anana Tel: 972-9-744-7705 Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781 **Italy - Padova** Tel: 39-049-7625286 **Netherlands - Drunen** Tel: 31-416-690399 Fax: 31-416-690340 Norway - Trondheim Tel: 47-7288-4388 **Poland - Warsaw** Tel: 48-22-3325737 Romania - Bucharest Tel: 40-21-407-87-50 **Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91 **Sweden - Gothenberg** Tel: 46-31-704-60-40 Sweden - Stockholm Tel: 46-8-5090-4654 **UK - Wokingham** Tel: 44-118-921-5800 Fax: 44-118-921-5820