# 16-Bit Digital Signal Controllers with High-Resolution PWM and CAN Flexible Data-Rate (CAN FD) ### **Operating Conditions** - 3V to 3.6V, -40°C to +125°C - DC to 100 MIPS - 3V to 3.6V, -40°C to +150°C: - DC to 70 MIPS #### Core: 16-Bit dsPIC33CK CPU - · 256-512 Kbytes of Program Flash with ECC and 64 Kbytes of Data RAM - · Fast Six-Cycle Divide - · Flash with Dual Partition for LiveUpdate Capabilities - LiveUpdate - · Code-Efficient (C and Assembly) Architecture - 40-Bit Wide Accumulators - Single-Cycle (MAC/MPY) with Dual Data Fetch - Single-Cycle, Mixed-Sign MUL Plus Hardware Divide - 32-Bit Multiply Support - · Five Sets of Interrupt Context Selected Registers for Fast Interrupt Response - · Zero Overhead Looping - RAM Memory Built-In Self-Test (MBIST) ## **Clock Management** - Fast RC (FRC) - Internal Oscillator - · Programmable PLLs and Oscillator Clock Sources - Reference Clock Output - Fail-Safe Clock Monitor (FSCM) - Fast Wake-up and Start-up - 8 MHz Backup FRC (BFRC) with a Divider (244 decimal) to provide a Nominal 32.768 kHz Output with a 50% Duty Cycle ## **Power Management** - · Low-Power Management Modes (Sleep, Idle, Doze) - · Integrated Power-on Reset and Brown-out Reset ## **High-Resolution PWM with Fine Edge Placement** - · Up to Eight PWM Channels - · 250 ps PWM Resolution - Applications Include: - DC/DC Converters - AC/DC power supplies - Uninterruptable Power Supply (UPS) - Motor Control: BLDC, PMSM, SR, ACIM ### Timers/Output Compare/Input Capture - · One General Purpose 16-Bit Timer - · Peripheral Trigger Generator (PTG) Module - Eight SCCP Modules: - Timer, Capture/Compare and PWM modes - 16 or 32-bit time base - 16 or 32-bit capture - Four-deep capture buffer - Fully asynchronous operation, available in Sleep modes - Nine MCCP/SCCP modules which Include Timer, Capture/Compare and PWM: - One MCCP - Eight SCCPs - 16 or 32-bit time base - 16 or 32-bit capture - Four-deep capture buffer ## **Advanced Analog Features** - · Five ADC Modules: - 12-bit, 4.3 Msps ADC - Up to 24 conversion channels - 250 ns conversion latency - Six DAC/Analog Comparator Modules: - 12-bit DACs with hardware slope compensation - 15 ns analog comparators - · Shared DAC/Analog Output: - DAC/analog comparator outputs #### **Communication Interfaces** - · Three UART Modules: - Support for DMX, LIN/J2602 protocols - Three 4-Wire SPI/I<sup>2</sup>S Modules - · Two CAN Flexible Data-Rate (FD) Modules - Three I<sup>2</sup>C Modules: - Support for SMBus - PPS to Allow Function Remap - · Two SENT Modules ## **Direct Memory Access (DMA)** · Eight DMA Channels ### **Peripheral Features** - One Quadrature Encoder Interface (QEI): - Four inputs: Phase A, Phase B, Home, Index - · Four Configurable Logic Cells (CLCs) with Internal Connections to Select Peripherals and PPS - · Two Current Bias Generators (CBGs) ### **Debugger Development Support** - In-Circuit and In-Application Programming - · Three Complex, Five Simple Breakpoints - · IEEE 1149.2 Compatible (JTAG) Boundary Scan - · Trace Buffer and Run-Time Watch ### Safety Features - DMT (Deadman Timer) - · ECC (Error Correcting Code) for Flash Memory - WDT (Watchdog Timer) - CodeGuard<sup>™</sup> Security - · CRC (Cyclic Redundancy Check) - ICSP<sup>™</sup> Write Inhibit - RAM Memory Built-In Self Test (MBIST) - Two-Speed Start-up - · Fail-Safe Clock Monitoring (FSCM) - Backup FRC (BFRC) - · Capless Internal Voltage Regulator - · Virtual Pins for Redundancy and Monitoring ## **Functional Safety Collateral** - Class B Safety Library IEC 60730 - For ASIL B and Beyond Applications ISO 26262 - FMEDA Computation Spreadsheet (Evaluation of Random Hardware Failures Metric) - Functional Safety Manual - Functional Safety Diagnostics Suite ## **Qualification Support** - AEC-Q100 REV-H (Grade 1: -40°C to +125°C) Compliant - AEC-Q100 REV-H (Grade 0: -40°C to +150°C) Compliant ## dsPIC33CK512MP608 Product Families The device names, pin counts, memory sizes and peripheral availability of each device are listed in Table 1 and Table 2. The following pages show their pinout diagrams. Table 1. dsPIC33CK512MP608 Motor Control/Power Supply Families | REFO | | - | _ | - | _ | <del></del> | _ | |------------------------|---------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------| | Sourcent Bias Source | | - | - | - | - | - | - | | 42-Bit DAC/Analog CMP | | 9 | 9 | 9 | 9 | 9 | 9 | | PWM (High Resolution) | | 80 | 8 | 80 | 80 | ∞ | 8 | | скс | | - | - | - | - | - | - | | ərq | | - | - | - | - | - | - | | сгс | | 4 | 4 | 4 | 4 | 4 | 4 | | ØΕΙ | | က | e | က | 8 | က | က | | o <sub>Z</sub> ı | | က | ო | m | m | ო | က | | S <sup>2</sup> I/IdS | | က | 8 | က | 8 | 8 | 3 | | TЯAU | | က | en. | က | က | က | 3 | | SENT | | 2 | 2 | 2 | 2 | 2 | 2 | | СРИ FD | | 2 | 2 | 2 | 2 | 2 | 2 | | SCCP/MCCP | | 8/1 | 8/1 | 8/1 | 8/1 | 8/1 | 8/1 | | ≳19miT ji <b>G</b> -∂1 | | - | - | - | - | - | - | | ADC Channels | | 24 | 20 | 19 | 24 | 20 | 19 | | səluboM DQA | | 5 | 5 | 5 | 5 | 5 | 5 | | MAЯ stsQ | | 64K | 64K | 64K | 64K | 64K | 64K | | Fissh/(PRAM) | | 512K | 512K | 512K | 256K | 256K | 256K | | sniq | | 80 | 64 | 48 | 80 | 64 | 48 | | Product | Devices with CAN FD | dsPIC33CK512MP608 | dsPIC33CK512MP606 | dsPIC33CK512MP605 | dsPIC33CK256MP608 | dsPIC33CK256MP606 | dsPIC33CK256MP605 | Table 2. dsPIC33CK512MP608 Motor Control/Power Supply Families with No CAN FD | REFO | | - | - | - | - | - | <del>-</del> | |------------------------|------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------| | Current Bias Source | | - | - | - | _ | - | - | | 4N2-Bit DAC/Analog CMP | | 9 | 9 | 9 | 9 | 9 | 9 | | (High Resolution) | | œ | 80 | œ | 80 | œ | 80 | | 282 | | - | - | - | - | - | - | | 9Tq | | - | - | - | - | - | - | | сгс | | 4 | 4 | 4 | 4 | 4 | 4 | | ОЕІ | | က | m | m | m | က | က | | ا2د | | n | n | m | es | m | es | | S <sup>2</sup> I/IdS | | က | m | m | ю | က | က | | TЯAU | | က | m | ო | m | ო | ю | | SENT | | 2 | 2 | 2 | 2 | 2 | 2 | | CAN FD | | ļ | ı | 1 | ı | 1 | 1 | | GCCP/MCCP | | 8/1 | 8/1 | 8/1 | 8/1 | 8/1 | 8/1 | | erəmiT JiB-Əf | | - | - | - | - | - | - | | ADC Channels | | 24 | 20 | 19 | 24 | 20 | 19 | | səluboM DQA | | 2 | 22 | 22 | 5 | 2 | 5 | | MAЯ stsQ | | 64K | 64K | 64K | 64K | 64K | 64K | | Flash/(PRAM) | | 512K | 512K | 512K | 256K | 256K | 256K | | sni <b>q</b> | | 80 | 64 | 48 | 80 | 64 | 48 | | Product | Devices with No CAN FD | dsPIC33CK512MP308 | dsPIC33CK512MP306 | dsPIC33CK512MP305 | dsPIC33CK256MP308 | dsPIC33CK256MP306 | dsPIC33CK256MP305 | ## **Pin Diagrams** Figure 1. 48-Pin TQFP/VQFN<sup>(1,2)</sup> #### Notes: - 1. Shaded pins are up to 5 V<sub>DC</sub> tolerant. - The large center pad on the bottom of the package may be left floating or connected to V<sub>SS</sub>. The four-corner anchor pads are internally connected to the large bottom pad, and therefore, must be connected to the same net as the large center pad. Table 3. 48-Pin TQFP/VQFN | Pin# | Function | Pin# | Function | |------|-------------------------------|------|-------------------------------------------------------------------------------------------------------| | 1 | RP46/PWM1H/RB14 | 25 | OA2OUT/AN1/AN7/ANA0/ANA2/ANA3/<br>CMP1D/CMP2D/CMP3D/CMP4D/<br>CMP5D/CMP6D/ <b>RP34</b> /SCL3/INT0/RB2 | | 2 | RP47/PWM1L/RB15 | 26 | PGD2/OA2IN-/AN8/CMP4A/ <b>RP35</b> /RB3 | | 3 | RP60/PWM8H/RC12 | 27 | PGC2/OA2IN+/RP36/RB4 | | 4 | RP61/PWM8L/RC13 | 28 | RP56/ASDA1/SCK2/RC8 | | 5 | MCLR | 29 | RP57/ASCL1/SDI2/RC9 | | 6 | ANN4/CMP5B/ <b>RP77</b> /RD13 | 30 | RP72/SDO2/PCI19/RD8 | | 7 | AN12/ANN0/RP48/RC0 | 31 | Vss | | 8 | OA1OUT/AN0/CMP1A/IBIAS0/RA0 | 32 | V <sub>DD</sub> | | 9 | OA1IN-/ANA1/RA1 | 33 | PGD3/ <b>RP37</b> /PWM6L/SDA2/RB5 | | 10 | OA1IN+/AN9/RA2 | 34 | PGC3/RP38/PWM6H/SCL2/RB6 | **Legend:** RPn and RPln represent remappable peripheral functions. **Notes:** - 1. A pull-up resistor is connected to this pin when device is erased (JTAG enabled) and during programming. - This pin is toggled during programming. © 2021 Microchip Technology Inc. Datasheet 70005452B-page 7 | continu | continued | | | | | | | |---------|----------------------------------------------|------|-----------------------------------------------|--|--|--|--| | Pin# | Function | Pin# | Function | | | | | | 11 | DACOUT1/AN27/AN3/CMP1C/RA3 | 35 | TDO/AN2/AN26/CMP3A/ <b>RP39</b> /<br>SDA3/RB7 | | | | | | 12 | OA3OUT/AN4/ANB1/ANB2/CMP3B/<br>IBIAS3/RA4 | 36 | PGD1/AN10/CMP6A/RP40/SCL1/RB8 | | | | | | 13 | AV <sub>DD</sub> | 37 | PGC1/AN11/CMP5A/ <b>RP41</b> /SDA1/RB9 | | | | | | 14 | AV <sub>SS</sub> | 38 | RP52/PWM5H/ASDA2/RC4 | | | | | | 15 | OA3IN-/AN13/CMP1B/ISRC0/<br>RP49/RC1 | 39 | RP53/PWM5L/ASCL2/RC5 | | | | | | 16 | OA3IN+/AN14/CMP2B/ISRC1/<br>RP50/RC2 | 40 | RP58/PWM7H/RC10 | | | | | | 17 | AN17/ANN1/CMP4B/IBIAS1/<br>RP54/RC6 | 41 | RP59/PWM7L/RC11 | | | | | | 18 | $V_{DD}$ | 42 | V <sub>SS</sub> | | | | | | 19 | V <sub>SS</sub> | 43 | $V_{DD}$ | | | | | | 20 | AN15/ANN2/CMP2A/IBIAS2/<br>RP51/RC3 | 44 | RP65/PWM4H/RD1 | | | | | | 21 | OSCI/CLKI/AN5/RP32/RB0 | 45 | TMS/ <b>RP42</b> /PWM3H/RB10 <sup>(1)</sup> | | | | | | 22 | OSCO/CLKO/AN6/RP33/RB1 <sup>(2)</sup> | 46 | TCK/RP43/PWM3L/RB11 | | | | | | 23 | AN18/ANC2/CMP3C/ISRC3/ <b>RP74</b> /<br>RD10 | 47 | TDI/ <b>RP44</b> /PWM2H/RB12 | | | | | | 24 | DACOUT2/AN16/CMP4C/ISRC2/<br>RP55/RC7 | 48 | RP45/PWM2L/RB13 | | | | | **Legend:** RPn and RPln represent remappable peripheral functions. **Notes:** <sup>1.</sup> A pull-up resistor is connected to this pin when device is erased (JTAG enabled) and during programming. <sup>2.</sup> This pin is toggled during programming. ## Pin Diagrams (Continued) Figure 2. 64-Pin TQFP, QFN(1,2) #### Notes: - 1. Shaded pins are up to $5 V_{DC}$ tolerant. - 2. The large center pad on the bottom of the package may be left floating or connected to V<sub>SS</sub>. The four-corner anchor pads are internally connected to the large bottom pad, and therefore, must be connected to the same net as the large center pad. Table 4. 64-Pin TQFP/QFN | Pin # | Function | Pin # | Function | |-------|----------------------|-------|-------------------------------------------------------------------------------------------------------| | 1 | RP46/PWM1H/PMD5/RB14 | 33 | OA2OUT/AN1/AN7/ANA0/ANA2/ANA3/<br>CMP1D/CMP2D/CMP3D/CMP4D/<br>CMP5D/CMP6D/ <b>RP34</b> /SCL3/INT0/RB2 | | 2 | RP47/PWM1L/PMD6/RB15 | 34 | PGD2/OA2IN-/AN8/CMP4A/RP35/RB3 | | 3 | RP60/PWM8H/PMD7/RC12 | 35 | PGC2/OA2IN+/RP36/RB4 | | 4 | RP61/PWM8L/PMA5/RC13 | 36 | RP56/ASDA1/SCK2/RC8 | | 5 | RP62/PWM6H/PMA4/RC14 | 37 | RP57/ASCL1/SDI2/RC9 | | 6 | RP63/PWM6L/PMA3/RC15 | 38 | RP73/PCI20/RD9 | | 7 | MCLR | 39 | RP72/SDO2/PCI19/RD8 | | 8 | RP79/PCI22/PMA2/RD15 | 40 | V <sub>SS</sub> | | 9 | V <sub>SS</sub> | 41 | $V_{DD}$ | **Legend:** RPn and RPln represent remappable peripheral functions. #### Notes: - 1. A pull-up resistor is connected to this pin when device is erased (JTAG enabled) and during programming. - This pin is toggled during programming. © 2021 Microchip Technology Inc. Datasheet 70005452B-page 9 | continue | continued | | | | | | |----------|--------------------------------------------------------------------|-------|--------------------------------------------------|--|--|--| | Pin# | Function | Pin # | Function | | | | | 10 | $V_{DD}$ | 42 | RP71/PMD15/RD7 | | | | | 11 | RP78/PCI21/RD14 | 43 | RP70/PMD14/RD6 | | | | | 12 | ANN4/CMP5B/ <b>RP77</b> /RD13 | 44 | RP69/PMA15/PMCS2/RD5 | | | | | 13 | AN12/ANN0/ <b>RP48</b> /RC0 | 45 | PGD3/ <b>RP37</b> /SDA2/PMA14/PMCS1/<br>PSCS/RB5 | | | | | 14 | OA1OUT/AN0/CMP1A/IBIAS0/RA0 | 46 | PGC3/RP38/SCL2/RB6 | | | | | 15 | OA1IN-/ANA1/RA1 | 47 | TDO/AN2/AN26/CMP3A/ <b>RP39</b> /<br>SDA3/RB7 | | | | | 16 | OA1IN+/AN9/PMA6/RA2 | 48 | PGD1/AN10/CMP6A/RP40/SCL1/RB8 | | | | | 17 | DACOUT1/AN27/AN3/CMP1C/RA3 | 49 | PGC1/AN11/CMP5A/ <b>RP41</b> /SDA1/RB9 | | | | | 18 | OA3OUT/AN4/ANB1/ANB2/CMP3B/<br>IBIAS3/RA4 | 50 | RP52/PWM5H/ASDA2/RC4 | | | | | 19 | $AV_{DD}$ | 51 | RP53/PWM5L/ASCL2/PMWR/PMENB/<br>PSWR/RC5 | | | | | 20 | AV <sub>SS</sub> | 52 | RP58/PWM7H/PMRD/PMWR/PSRD/<br>RC10 | | | | | 21 | <b>RP76</b> /RD12 | 53 | RP59/PWM7L/RC11 | | | | | 22 | OA3IN-/AN13/CMP1B/ISRC0/ <b>RP49</b> /<br>PMA7/RC1 | 54 | RP68/ASDA3/RD4 | | | | | 23 | OA3IN+/AN14/CMP2B/ISRC1/ <b>RP50</b> /<br>PMD13/PMA13/RC2 | 55 | RP67/ASCL3/RD3 | | | | | 24 | AN17/ANN1/CMP4B/IBIAS1/RP54/<br>PMD12/PMA12/RC6 | 56 | V <sub>SS</sub> | | | | | 25 | $V_{DD}$ | 57 | V <sub>DD</sub> | | | | | 26 | V <sub>SS</sub> | 58 | RP66/RD2 | | | | | 27 | AN15/ANN2/CMP2A/IBIAS2/ <b>RP51</b> /<br>PMD11/PMA11/RC3 | 59 | RP65/PWM4H/RD1 | | | | | 28 | OSCI/CLKI/AN5/RP32/PMD10/<br>PMA10/RB0 | 60 | RP64/PWM4L/PMD0/RD0 | | | | | 29 | OSCO/CLKO/AN6/ <b>RP33</b> /PMA1/PMALH/<br>PSA1/RB1 <sup>(2)</sup> | 61 | TMS/ <b>RP42</b> /PWM3H/PMD1/RB10 <sup>(1)</sup> | | | | | 30 | AN19/ANB0/CMP2C/RP75/PMA0/<br>PMALL/PSA0/RD11 | 62 | TCK/RP43/PWM3L/PMD2/RB11 | | | | | 31 | AN18/ANC2/CMP3C/ISRC3/ <b>RP74</b> /<br>PMD9/PMA9/RD10 | 63 | TDI/ <b>RP44</b> /PWM2H/PMD3/RB12 | | | | | 32 | DACOUT2/AN16/CMP4C/ISRC2/ <b>RP55</b> /<br>PMD8/PMA8/RC7 | 64 | RP45/PWM2L/PMD4/RB13 | | | | **Legend:** RPn and RPln represent remappable peripheral functions. **Notes:** - 1. A pull-up resistor is connected to this pin when device is erased (JTAG enabled) and during programming. - 2. This pin is toggled during programming. ## Pin Diagrams (Continued) Figure 3. 80-pin TQFP(1) #### Note: 1. Shaded pins are up to $5 V_{DC}$ tolerant. Table 5. 80-Pin TQFP | Pin # | Function | Pin # | Function | |-------|----------------------|-------|-----------------------------------------------------------------------------------------------------------| | 1 | RP46/PWM1H/PMD5/RB14 | 41 | OA2OUT/AN1/AN7/ANA0/ANA2/<br>ANA3/CMP1D/CMP2D/CMP3D/<br>CMP4D/CMP5D/CMP6D/ <b>RP34</b> /SCL3/<br>INT0/RB2 | | 2 | AN20/ANC0/CMP5C/RE0 | 42 | RE8 | | 3 | RP47/PWM1L/PMD6/RB15 | 43 | PGD2/OA2IN-/AN8/CMP4A/<br>RP35/RB3 | | 4 | AN21/ANC1/CMP6B/RE1 | 44 | RE9 | | 5 | RP60/PWM8H/PMD7/RC12 | 45 | PGC2/OA2IN+/ <b>RP36</b> /RB4 | | 6 | RP61/PWM8L/PMA5/RC13 | 46 | RP56/ASDA1/SCK2/RC8 | | 7 | RP62/PWM6H/PMA4/RC14 | 47 | RP57/ASCL1/SDI2/RC9 | | 8 | RP63/PWM6L/PMA3/RC15 | 48 | RP73/PCI20/RD9 | | 9 | MCLR | 49 | RP72/SDO2/PCI19/RD8 | | 10 | RP79/PCI22/PMA2/RD15 | 50 | V <sub>SS</sub> | **Legend:** RPn and RPIn represent remappable pins for Peripheral Pin Select (PPS) functions. **Notes:** - 1. A pull-up resistor is connected to this pin when device is erased (JTAG enabled) and during programming. - 2. This pin is toggled during programming | continu | continued | | | | | | |---------|-----------------------------------------------------------|-------|--------------------------------------------------|--|--|--| | Pin # | Function | Pin # | Function | | | | | 11 | V <sub>SS</sub> | 51 | $V_{DD}$ | | | | | 12 | $V_{DD}$ | 52 | RP71/PMD15/RD7 | | | | | 13 | RP78/PCI21/RD14 | 53 | RP70/PMD14/RD6 | | | | | 14 | ANN4/CMP5B/ <b>RP77</b> /RD13 | 54 | RP69/PMA15/PMCS2/RD5 | | | | | 15 | AN12/ANN0/ <b>RP48</b> /RC0 | 55 | PGD3/ <b>RP37</b> /SDA2/PMA14/PMCS1/<br>PSCS/RB5 | | | | | 16 | OA1OUT/AN0/CMP1A/IBIAS0/RA0 | 56 | PGC3/RP38/SCL2/RB6 | | | | | 17 | AN22/ANB3/CMP6C/RE2 | 57 | RE10 | | | | | 18 | OA1IN-/ANA1/RA1 | 58 | TDO/AN2/AN26/CMP3A/ <b>RP39</b> /<br>SDA3/RB7 | | | | | 19 | AN23/ANN3/RE3 | 59 | RE11 | | | | | 20 | OA1IN+/AN9/PMA6/RA2 | 60 | PGD1/AN10/CMP6A/ <b>RP40</b> /<br>SCL1/RB8 | | | | | 21 | DACOUT1/AN27/AN3/CMP1C/RA3 | 61 | PGC1/AN11/CMP5A/ <b>RP41</b> /<br>SDA1/RB9 | | | | | 22 | RE4 | 62 | RE12 | | | | | 23 | OA3OUT/AN4/ANB1/ANB2/CMP3B/<br>IBIAS3/RA4 | 63 | RP52/PWM5H/ASDA2/RC4 | | | | | 24 | RE5 | 64 | RE13 | | | | | 25 | AV <sub>DD</sub> | 65 | RP53/PWM5L/ASCL2/PMWR/<br>PMENB/PSWR/RC5 | | | | | 26 | AV <sub>SS</sub> | 66 | RP58/PWM7H/PMRD/PMWR/PSRD/<br>RC10 | | | | | 27 | RP76/RD12 | 67 | RP59/PWM7L/RC11 | | | | | 28 | OA3IN-/AN13/CMP1B/ISRC0/ <b>RP49</b> /<br>PMA7/RC1 | 68 | RP68/ASDA3/RD4 | | | | | 29 | OA3IN+/AN14/CMP2B/ISRC1/ <b>RP50</b> /<br>PMD13/PMA13/RC2 | 69 | RP67/ASCL3/RD3 | | | | | 30 | AN17/ANN1/CMP4B/IBIAS1/ <b>RP54</b> /<br>PMD12/PMA12/RC6 | 70 | V <sub>SS</sub> | | | | | 31 | $V_{DD}$ | 71 | V <sub>DD</sub> | | | | | 32 | V <sub>SS</sub> | 72 | RP66/RD2 | | | | | 33 | AN15/ANN2/CMP2A/IBIAS2/ <b>RP51</b> /<br>PMD11/PMA11/RC3 | 73 | RP65/PWM4H/RD1 | | | | | 34 | OSCI/CLKI/AN5/RP32/PMD10/<br>PMA10/RB0 | 74 | RP64/PWM4L/PMD0/RD0 | | | | **Legend:** RPn and RPIn represent remappable pins for Peripheral Pin Select (PPS) functions. **Notes:** - 1. A pull-up resistor is connected to this pin when device is erased (JTAG enabled) and during programming. - 2. This pin is toggled during programming. | continued | | | | | | | |-----------|--------------------------------------------------------------------|-------|--------------------------------------------------|--|--|--| | Pin# | Function | Pin # | Function | | | | | 35 | OSCO/CLKO/AN6/ <b>RP33</b> /PMA1/PMALH/<br>PSA1/RB1 <sup>(2)</sup> | 75 | TMS/ <b>RP42</b> /PWM3H/PMD1/RB10 <sup>(1)</sup> | | | | | 36 | AN19/ANB0/CMP2C/RP75/PMA0/<br>PMALL/PSA0/RD11 | 76 | TCK/RP43/PWM3L/PMD2/RB11 | | | | | 37 | RE6 | 77 | RE14 | | | | | 38 | AN18/ANC2/CMP3C/ISRC3/ <b>RP74</b> /<br>PMD9/PMA9/RD10 | 78 | TDI/RP44/PWM2H/PMD3/RB12 | | | | | 39 | RE7 | 79 | RE15 | | | | | 40 | DACOUT2/AN16/CMP4C/ISRC2/ <b>RP55</b> /<br>PMD8/PMA8/RC7 | 80 | RP45/PWM2L/PMD4/RB13 | | | | **Legend: RPn** and **RPIn** represent remappable pins for Peripheral Pin Select (PPS) functions. **Notes:** - 1. A pull-up resistor is connected to this pin when device is erased (JTAG enabled) and during programming. - 2. This pin is toggled during programming. #### 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 Website at: #### 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). #### **Frrata** 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 Website; 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 website at www.microchip.com/ to receive the most current information on all of our products. © 2021 Microchip Technology Inc. Datasheet 70005452B-page 14 #### Referenced Sources This device data sheet is based on the following individual chapters of the "dsPIC33/PIC24 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 documents listed below, browse to the documentation section of the dsPIC33CK512MP608 product page of the Microchip website (www.microchip.com) or select a family reference manual section from the following list. In addition to parameters, features and other documentation, the resulting page provides links to the related family reference manual sections. - "Introduction" (www.microchip.com/DS70573) - "Enhanced CPU" (www.microchip.com/DS70005158) - "dsPIC33/PIC24 Program Memory" (www.microchip.com/DS70000613) - "Data Memory" (www.microchip.com/DS70595) - "Dual Partition Flash Program Memory" (www.microchip.com/DS70005156) - "Flash Programming" (www.microchip.com/DS70000609) - "Reset" (www.microchip.com/DS70602) - "Interrupts" (www.microchip.com/DS70000600) - "I/O Ports with Edge Detect" (www.microchip.com/DS70005322) - "Oscillator Module with High-Speed PLL" (www.microchip.com/DS70005255) - "Direct Memory Access Controller (DMA)" (www.microchip.com/DS30009742) - "CAN Flexible Data-Rate (FD) Protocol Module" (www.microchip.com/DS70005340) - "High-Resolution PWM with Fine Edge Placement" (www.microchip.com/DS70005320) - "12-Bit High-Speed, Multiple SARs A/D Converter (ADC)" (www.microchip.com/DS70005213) - "High-Speed Analog Comparator Module with Slope Compensation DAC" (www.microchip.com/ DS70005280) - "Quadrature Encoder Interface (QEI)" (www.microchip.com/DS70000601) - "Multiprotocol Universal Asynchronous Receiver Transmitter (UART) Module" (www.microchip.com/ DS70005288) - "Serial Peripheral Interface (SPI) with Audio Codec Support" (www.microchip.com/DS70005136) - "Inter-Integrated Circuit (I<sup>2</sup>C)" (www.microchip.com/DS70000195) - "Parallel Master Port (PMP)" (www.microchip.com/DS70005344) - "Single-Edge Nibble Transmission (SENT) Module" (www.microchip.com/DS70005145) - "Timer1 Module" (www.microchip.com/DS70005279) - "Capture/Compare/PWM/Timer (MCCP and SCCP)" (www.microchip.com/DS30003035) - "Configurable Logic Cell (CLC)" (www.microchip.com/DS70005298) - "Peripheral Trigger Generator (PTG)" (www.microchip.com/DS70000669) - "32-Bit Programmable Cyclic Redundancy Check (CRC)" (www.microchip.com/DS30009729) - "Current Bias Generator (CBG)" (www.microchip.com/DS70005253) - "Deadman Timer" (www.microchip.com/DS70005155) - "Watchdog Timer and Power-Saving Modes" (www.microchip.com/DS70615) - "CodeGuard™ Intermediate Security" (www.microchip.com/DS70005182) - "Dual Watchdog Timer" (www.microchip.com/DS70005250) - "Programming and Diagnostics" (www.microchip.com/DS70608) ## **Terminology Cross Reference** Table 6 provides updated terminology for depreciated naming conventions. Register and bit names remain unchanged, however, descriptions and usage guidance may have been updated. Table 6. Terminology Cross References | Use Case | Deprecated Term | New Term | |------------------|-----------------|-----------| | CPU | Master | Initiator | | DMA | Master | Initiator | | I <sup>2</sup> C | Master | Host | | | Slave | Client | | SPI | Master | Host | | | Slave | Client | | PMP | Master | Host | | | Slave | Client | | UART, LIN Mode | Master | Commander | | | Slave | Responder | | PWM | Master | Host | | | Slave | Client | ## **Table of Contents** | Operating Conditions | 1 | |-----------------------------------------------------------------------|---| | Core: 16-Bit dsPIC33CK CPU | 1 | | Clock Management | 1 | | Power Management | 1 | | High-Resolution PWM with Fine Edge Placement | 2 | | Timers/Output Compare/Input Capture | 2 | | Advanced Analog Features | 2 | | Communication Interfaces | 2 | | Direct Memory Access (DMA) | 3 | | Peripheral Features | 3 | | Debugger Development Support | 3 | | Safety Features | | | Functional Safety Collateral | | | Qualification Support | | | dsPIC33CK512MP608 Product Families | | | Pin Diagrams | | | Pin Diagrams (Continued) | | | Pin Diagrams (Continued) | | | To Our Valued Customers. | | | Referenced Sources. | | | | | | Terminology Cross Reference. | | | 1. Device Overview | | | Guidelines for Getting Started with 16-Bit Digital Signal Controllers | | | Basic Connection Requirements. Decoupling Capacitors. | | | 2.3. Master Clear (MCLR) Pin | | | 2.4. ICSP Pins | | | 2.5. External Oscillator Pins | | | 2.6. External Oscillator Layout Guidance | | | 2.7. Oscillator Value Conditions on Device Start-up | | | 2.8. Unused I/Os. | | | 2.9. Bulk Capacitors | | | | 2.10. | Targeted Applications | 34 | |----|--------|----------------------------------------------|-----| | 3. | CPU. | | 38 | | | 3.1. | Registers | 38 | | | 3.2. | Instruction Set | 38 | | | 3.3. | Data Space Addressing | 38 | | | 3.4. | Addressing Modes | 39 | | | 3.5. | CPU Control/Status Registers | 44 | | | 3.6. | Arithmetic Logic Unit (ALU) | 78 | | | 3.7. | DSP Engine | 79 | | 4. | Memo | ory Organization | 81 | | | 4.1. | Program Address Space | 81 | | | 4.2. | Data Address Space | 84 | | | 4.3. | BIST Overview | 86 | | | 4.4. | Memory Resources | 88 | | 5. | Flash | Program Memory | 99 | | | 5.1. | Table Instructions and Flash Programming | 99 | | | 5.2. | RTSP Operation | 100 | | | 5.3. | Error Correcting Code (ECC) | 102 | | | 5.4. | ECC Fault Injection | 102 | | | 5.5. | Flash OTP by ICSP <sup>™</sup> Write Inhibit | 102 | | | 5.6. | Dual Partition Flash Configuration | 103 | | | 5.7. | NVM/ECC Control Registers | 106 | | 6. | Reset | ts | 120 | | | 6.1. | Reset Resources | 121 | | 7. | Interr | upt Controller | 124 | | | 7.1. | Interrupt Vector Table | 124 | | | 7.2. | Alternate Interrupt Vector Table | 125 | | | 7.3. | Reset Sequence | 127 | | | 7.4. | Interrupt Resources | 133 | | | 7.5. | Interrupt Control and Status Registers | 134 | | | 7.6. | Status/Control Registers | | | | 7.7. | Status/Control Registers | | | 8. | I/O Po | orts | 269 | | | 8.1. | Parallel I/O (PIO) Ports | 269 | | | 8.2. | Configuring Analog and Digital Port Pins | | | | 8.3. | Input Change Notification (ICN) | 286 | | | 8.4. | Peripheral Pin Select (PPS) | 287 | | | 8.5. | Considerations for Peripheral Pin Selection | | | | 8.6. | Input Mapping | | | | 8.7. | Virtual Connections | | | | 8.8. | Output Mapping. | | | | 8.9. | Mapping Limitations | | | | 8.10. | I/O Helpful Tips | | | | 8.11. | I/O Ports Resources | 299 | |-----|---------|--------------------------------------------------------|-----| | | 8.12. | Peripheral Pin Select Control Registers | 301 | | 9. | Oscilla | ator with High-Frequency PLL | 374 | | | 9.1. | Primary PLL | 376 | | | 9.2. | Auxiliary PLL | | | | 9.3. | CPU Clocking | | | | 9.4. | Primary Oscillator (POSC) | | | | 9.5. | Internal Fast RC (FRC) Oscillator | | | | 9.6. | Low-Power RC Oscillator | | | | 9.7. | Backup Internal Fast RC (BFRC) Oscillator | 381 | | | 9.8. | Reference Clock Output | 381 | | | 9.9. | Oscillator Configuration | 382 | | | 9.10. | OSCCON Unlock Sequence | 383 | | | 9.11. | Oscillator Control Registers | 384 | | 10. | Direct | Memory Access (DMA) Controller | 399 | | | 10.1. | Summary of DMA Operations | 400 | | | | Typical Setup | | | 11. | Contro | oller Area Network Flexible Data-Rate (CAN FD) Modules | 411 | | | | Features | | | | | CAN Control/Status Registers | | | 12. | High-l | Resolution PWM with Fine Edge Placement | 492 | | | | Features | | | | | Architecture Overview | | | | | Lock and Write Restrictions | | | | | PWM4H/L Output on Peripheral Pin Select | | | | | PWM Control/Status Registers. | | | | | Control Registers | | | 13. | High-S | Speed, 12-Bit Analog-to-Digital Converter | 543 | | | 13.1. | ADC Features Overview | 543 | | | | Temperature Sensor | | | | | Analog-to-Digital Converter Resources | | | | | ADC Control Registers | | | 14. | High- | Speed Analog Comparator with Slope Compensation DAC | 616 | | | 14.1. | Overview | 616 | | | | Features Overview | | | | 14.3. | DAC Control Registers | 618 | | | 14.4. | DAC Control Registers | 619 | | 15. | Quadi | rature Encoder Interface (QEI) | 633 | | | 15.1. | QEI Control/Status Registers | 636 | | 16. | Unive | rsal Asynchronous Receiver Transmitter (UART) | 663 | | | | Architectural Overview | | | | | Character Frame | | | | | | | | | 16.3. | Data Buffers | 664 | |-------------------|--------|------------------------------------------------------|------| | | 16.4. | Protocol Extensions. | .664 | | | 16.5. | UART Control/Status Registers. | .665 | | 17. | | Peripheral Interface (SPI) | | | | 17.1. | SPI Control/Status Registers | .696 | | 18. | | ntegrated Circuit (I <sup>2</sup> C) | | | | 18.1. | Communicating as a Host in a Single Host Environment | .714 | | | 18.2. | Setting Baud Rate When Operating as a Bus Main | 716 | | | 18.3. | Client Address Masking | .716 | | | 18.4. | SMBus Support | 717 | | | 18.5. | I2C Control/Status Registers | .718 | | <mark>1</mark> 9. | Parall | el Main Port (PMP) | .726 | | | 19.1. | Parallel Main Port Control Registers | 727 | | 20. | Single | -Edge Nibble Transmission (SENT) | 743 | | | 20.1. | Transmit Mode | .744 | | | 20.2. | Receive Mode | 745 | | | 20.3. | SENT Control/Status Registers | .747 | | 21. | Timer | 1 | 754 | | | 21.1. | Timer1 Control Register | 755 | | 22. | Captu | re/Compare/PWM/Timer Modules (SCCP) | .758 | | | 22.1. | Time Base Generator | 759 | | | 22.2. | General Purpose Timer | 759 | | | 22.3. | Output Compare Mode | .760 | | | 22.4. | Input Capture Mode | .761 | | | 22.5. | Auxiliary Output | 763 | | | 22.6. | SCCP Control/Status Registers | 764 | | 23. | Config | urable Logic Cell (CLC) | 788 | | | 23.1. | Control Registers | .791 | | 24. | Periph | eral Trigger Generator (PTG) | .801 | | | 24.1. | Features | 801 | | | 24.2. | PTG Registers | .803 | | | 24.3. | PTG Step Commands | 819 | | 25. | 32-Bit | Programmable Cyclic Redundancy Check (CRC) Generator | .822 | | | 25.1. | CRC Control Registers | .823 | | 26. | Curre | nt Bias Generator (CBG) | .829 | | | 26.1. | Current Bias Generator Control Registers | 831 | | 27. | Opera | tional Amplifier | .837 | | | 27.1. | Operational Amplifier Control Registers | 838 | | 28. | Deadr | nan Timer (DMT) | 841 | | | 28.1. Deadman Timer Control/Status Registers | 842 | | | | | |-----|------------------------------------------------|-----|--|--|--|--| | 29. | Power-Saving Features | 854 | | | | | | | 29.1. Clock Frequency and Clock Switching | 854 | | | | | | | 29.2. Instruction-Based Power-Saving Modes | | | | | | | | 29.3. Doze Mode | 856 | | | | | | | 29.4. Peripheral Module Disable | | | | | | | | 29.5. Power-Saving Resources | | | | | | | | 29.6. Power-Saving Control Registers | 858 | | | | | | 30. | Special Features | 871 | | | | | | | 30.1. Configuration Bits | 871 | | | | | | | 30.2. Configuration Registers | 874 | | | | | | | 30.3. Device Calibration and Identification | 897 | | | | | | | 30.4. User OTP Memory | | | | | | | | 30.5. On-Chip Voltage Regulators | | | | | | | | 30.6. Brown-out Reset (BOR) | | | | | | | | 30.7. Dual Watchdog Timer (WDT) | | | | | | | | 30.8. JTAG Interface | | | | | | | | 30.9. In-Circuit Debugger | | | | | | | | 50. 10. Code Protection and CodeGuard Security | 905 | | | | | | 31. | Instruction Set Summary | 907 | | | | | | 32. | Development Support | 921 | | | | | | 33. | Electrical Characteristics. | 922 | | | | | | | 33.1. DC Characteristics | 923 | | | | | | | 33.2. AC Characteristics and Timing Parameters | 936 | | | | | | 34. | High-Temperature Electrical Characteristics | 965 | | | | | | | 34.1. DC Characteristics | 966 | | | | | | 35 | Packaging Information | 975 | | | | | | | 35.1. Package Marking Information | | | | | | | | 35.2. Package Marking Information (Continued) | | | | | | | | 35.3. Package Details | | | | | | | 36 | Revision History | | | | | | | | | | | | | | | The | Microchip Website | 993 | | | | | | Pro | duct Change Notification Service | 993 | | | | | | Cus | stomer Support | 993 | | | | | | Pro | duct Identification System | 994 | | | | | | Mic | Microchip Devices Code Protection Feature994 | | | | | | | Leg | al Notice | 995 | | | | | | _ | | | | | | | | Quality Management System | 996 | |-----------------------------|------| | Worldwide Sales and Service | .997 | #### 1. Device Overview #### Notes: - This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive resource. To complement the information in this data sheet, refer to the related section of the "dsPIC33/PIC24 Family Reference Manual", which is available from the Microchip website (www.microchip.com) - Some registers and associated bits described in this section may not be available on all devices. Refer to Memory Organization in this data sheet for device-specific register and bit information. This document contains device-specific information for the dsPIC33CK512MP608 Digital Signal Controller (DSC) devices dsPIC33CK512MP608 devices contain extensive Digital Signal Processor (DSP) functionality with a high-performance, 16-bit MCU architecture. Figure 1-1 shows a general block diagram of the core and peripheral modules of the dsPIC33CK512MP608 family. Figure 1-1. dsPIC33CK512MP608 Family Block Diagram<sup>(1)</sup> - 1. The numbers in the parentheses are the number of instantiations of the module indicated. - 2. Not all I/O pins or features are implemented on all device pinout configurations. See Table 1-1 for specific implementations by pin count. - 3. Some peripheral I/Os are only accessible through Peripheral Pin Select (PPS). Table 1-1. Pinout I/O Descriptions | Pin Name <sup>(1)</sup> | Pin<br>Type | Buffer<br>Type | PPS | Description | |-------------------------|-------------|----------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AN0-AN23, AN26, AN27 | 1 | Analog | No | Analog input channels | | ANA0-ANA3 | 1 | Analog | No | Analog alternate inputs | | ANB0-ANB3 | 1 | Analog | No | Analog alternate "B" inputs | | ANC0-ANC2 | I | Analog | No | Analog alternate "C" inputs | | ANN0-ANN4 | 1 | Analog | No | Analog negative inputs | | ADTRG31 | I | ST | Yes | ADC Trigger Input 31 | | CAN1RX | 1 | ST | Yes | CAN1 receive input | | CAN1 | 0 | _ | Yes | CAN1 transmit output | | CAN2RX | 1 | ST | Yes | CAN2 receive input | | CAN2 | 0 | _ | Yes | CAN2 transmit output | | CLKI | ı | ST/CMOS | No | External Clock (EC) source input. Always associated with OSCI pin function. | | CLKO | 0 | _ | No | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. Optionally functions as CLKO in RC and EC modes. Always associated with OSCO pin function. | | OSCI | I | ST/CMOS | No | Oscillator crystal input. ST buffer when configured in RC mode; CMOS otherwise. | | osco | I/O | _ | No | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. Optionally functions as CLKO in RC and EC modes. | | REFOI | ı | ST | Yes | Reference clock input | | REFCLKO | 0 | _ | Yes | Reference clock output | | INT0 | 1 | ST | No | External Interrupt 0 | | INT1 | 1 | ST | Yes | External Interrupt 1 | | INT2 | 1 | ST | Yes | External Interrupt 2 | | INT3 | ı | ST | Yes | External Interrupt 3 | | | | | | | **Legend:** CMOS = CMOS compatible input or output; Analog = Analog input; P = Power; ST = Schmitt Trigger input with CMOS levels; O = Output; I = Input; PPS = Peripheral Pin Select; TTL = TTL input buffer - 1. Not all pins are available in all package variants. See the Pin Diagrams section for pin availability. - 2. These pins are remappable as well as dedicated. **Device Overview** | continued | | | | | | |-------------------------|-------------|----------------|-----|-------------------------------------|--| | Pin Name <sup>(1)</sup> | Pin<br>Type | Buffer<br>Type | PPS | Description | | | IOCA[4:0] | 1 | ST | No | Interrupt-on-Change input for PORTA | | | IOCB[15:0] | 1 | ST | No | Interrupt-on-Change input for PORTB | | | IOCC[15:0] | 1 | ST | No | Interrupt-on-Change input for PORTC | | | IOCD[15:0] | 1 | ST | No | Interrupt-on-Change input for PORTD | | | IOCE[15:0] | 1 | ST | No | Interrupt-on-Change input for PORTE | | | QEIA1 | 1 | ST | Yes | QEI Input A1 | | | QEIB1 | 1 | ST | Yes | QEI Input B1 | | | QEINDX1 | 1 | ST | Yes | QEI Index 1 input | | | QEIHOM1 | 1 | ST | Yes | QEI Home 1 input | | | QEICMP | 0 | _ | Yes | QEI comparator output | | | QEIA2 | 1 | ST | Yes | QEI Input A2 | | | QEIB2 | 1 | ST | Yes | QEI Input B2 | | | QEINDX2 | 1 | ST | Yes | QEI Index 2 input | | | QEIHOM2 | I | ST | Yes | QEI Home 2 input | | | QEICMP | 0 | _ | Yes | QEI comparator output | | | QEIA3 | 1 | ST | Yes | QEI Input A3 | | | QEIB3 | 1 | ST | Yes | QEI Input B3 | | | QEINDX3 | 1 | ST | Yes | QEI Index 3 input | | | QEIHOM3 | 1 | ST | Yes | QEI Home 3 input | | | QEICMP | 0 | _ | Yes | QEI comparator output | | | RA0-RA4 | I/O | ST | No | PORTA is a bidirectional I/O port | | | RB0-RB15 | I/O | ST | No | PORTB is a bidirectional I/O port | | | RC0-RC15 | I/O | ST | No | PORTC is a bidirectional I/O port | | | RD0-RD15 | I/O | ST | No | PORTD is a bidirectional I/O port | | | RE0-RE15 | I/O | ST | No | PORTE is a bidirectional I/O port | | | T1CK | 1 | ST | Yes | Timer1 external clock input | | **Legend:** CMOS = CMOS compatible input or output; Analog = Analog input; P = Power; ST = Schmitt Trigger input with CMOS levels; O = Output; I = Input; PPS = Peripheral Pin Select; TTL = TTL input buffer - 1. Not all pins are available in all package variants. See the Pin Diagrams section for pin availability. - 2. These pins are remappable as well as dedicated. **Device Overview** | continued | | | | | | |-------------------------|-------------|----------------|-----|---------------------------------------|--| | Pin Name <sup>(1)</sup> | Pin<br>Type | Buffer<br>Type | PPS | Description | | | U1CTS | 1 | ST | Yes | UART1 Clear-to-Send | | | U1RTS | О | _ | Yes | UART1 Request-to-Send | | | U1RX | 1 | ST | Yes | UART1 receive | | | U1TX | 0 | <del>_</del> | Yes | UART1 transmit | | | U1DSR | 1 | ST | Yes | UART1 Data-Set-Ready | | | U1DTR | 0 | _ | Yes | UART1 Data-Terminal-Ready | | | U2CTS | ı | ST | Yes | UART2 Clear-to-Send | | | U2RTS | 0 | _ | Yes | UART2 Request-to-Send | | | U2RX | 1 | ST | Yes | UART2 receive | | | U2TX | 0 | _ | Yes | UART2 transmit | | | U2DSR | 1 | ST | Yes | UART2 Data-Set-Ready | | | U2DTR | О | _ | Yes | UART2 Data-Terminal-Ready | | | U3CTS | I | ST | Yes | UART3 Clear-to-Send | | | U3RTS | 0 | _ | Yes | UART3 Request-to-Send | | | U3RX | 1 | ST | Yes | UART3 receive | | | U3TX | O | _ | Yes | UART3 transmit | | | U3DSR | I | ST | Yes | UART3 Data-Set-Ready | | | U3DTR | 0 | _ | Yes | UART3 Data-Terminal-Ready | | | SENT1 | I | ST | Yes | SENT1 input | | | SENT2 | 1 | ST | Yes | SENT2 input | | | SENT1OUT | 0 | _ | Yes | SENT1 output | | | SENT2OUT | 0 | _ | Yes | SENT2 output | | | PTGTRG24 | 0 | _ | Yes | PTG Trigger Output 24 | | | PTGTRG25 | 0 | _ | Yes | PTG Trigger Output 25 | | | TCKI1-TCKI9 | I | ST | Yes | SCCP/MCCP Timer Inputs 1 through 9 | | | ICM1-ICM9 | I | ST | Yes | SCCP/MCCP Capture Inputs 1 through 9 | | | OCFA-OCFD | 1 | _ | Yes | SCCP/MCCP Fault Inputs A through D | | | OCM1-OCM9 | 0 | _ | Yes | SCCP/MCCP Compare Outputs 1 through 9 | | **Legend:** CMOS = CMOS compatible input or output; Analog = Analog input; P = Power; ST = Schmitt Trigger input with CMOS levels; O = Output; I = Input; PPS = Peripheral Pin Select; TTL = TTL input buffer - 1. Not all pins are available in all package variants. See the Pin Diagrams section for pin availability. - 2. These pins are remappable as well as dedicated. **Device Overview** | continued | | | | | | |-------------------------|-------------|----------------|-----|-------------------------------------------------|--| | Pin Name <sup>(1)</sup> | Pin<br>Type | Buffer<br>Type | PPS | Description | | | SCK1 | I/O | ST | Yes | Synchronous serial clock I/O for SPI1 | | | SDI1 | 1 | ST | Yes | SPI1 data in | | | SDO1 | 0 | <u> </u> | Yes | SPI1 data out | | | SS1 | I/O | ST | Yes | SPI1 Client synchronization or frame pulse I/O | | | SCK2 | I/O | ST | Yes | Synchronous serial clock I/O for SPI2 | | | SDI2 | I | ST | Yes | SPI2 data in | | | SDO2 | 0 | _ | Yes | SPI2 data out | | | <u>\$\$2</u> | I/O | ST | Yes | SPI2 Client synchronization or frame pulse I/O | | | SCK3 | I/O | ST | Yes | Synchronous serial clock I/O for SPI3 | | | SDI3 | ı | ST | Yes | SPI3 data in | | | SDO3 | 0 | _ | Yes | SPI3 data out | | | SS3 | I/O | ST | Yes | SPI3 Client synchronization or frame pulse I/O | | | SCL1 | I/O | ST | No | Synchronous serial clock I/O for I2C1 | | | SDA1 | I/O | ST | No | Synchronous serial data I/O for I2C1 | | | ASCL1 | I/O | ST | No | Alternate synchronous serial clock I/O for I2C1 | | | ASDA1 | I/O | ST | No | Alternate synchronous serial data I/O for I2C1 | | | SCL2 | I/O | ST | No | Synchronous serial clock I/O for I2C2 | | | SDA2 | I/O | ST | No | Synchronous serial data I/O for I2C2 | | | ASCL2 | I/O | ST | No | Alternate synchronous serial clock I/O for I2C2 | | | ASDA2 | I/O | ST | No | Alternate synchronous serial data I/O for I2C2 | | | SCL3 | I/O | ST | No | Synchronous serial clock I/O for I2C3 | | | SDA3 | I/O | ST | No | Synchronous serial data I/O for I2C3 | | | ASCL3 | I/O | ST | No | Alternate synchronous serial clock I/O for I2C3 | | | ASDA3 | I/O | ST | No | Alternate synchronous serial data I/O for I2C3 | | **Legend:** CMOS = CMOS compatible input or output; Analog = Analog input; P = Power; ST = Schmitt Trigger input with CMOS levels; O = Output; I = Input; PPS = Peripheral Pin Select; TTL = TTL input buffer - 1. Not all pins are available in all package variants. See the Pin Diagrams section for pin availability. - 2. These pins are remappable as well as dedicated. **Device Overview** | continued | | | | | | |-----------------------------------------------------------------|-------------|----------------|-----|------------------------------------------|--| | Pin Name <sup>(1)</sup> | Pin<br>Type | Buffer<br>Type | PPS | Description | | | TMS | 1 | ST | No | JTAG Test mode select pin | | | TCK | TI II | ST | No | JTAG test clock input pin | | | TDI | I | ST | No | JTAG test data input pin | | | TDO | 0 | _ | No | JTAG test data output pin | | | PCI8-PCI18 | 1 | ST | Yes | PWM Inputs 8 through 18 | | | PWMEA-PWMEF | 0 | _ | Yes | PWM Event Outputs A through F | | | PCI19 - PCI22 | 1 | ST | Yes | PWM Inputs 19 through 22 | | | PWM1L-PWM4L <sup>(2)</sup> | 0 | _ | No | PWM Low Outputs 1 through 4 | | | PWM1H-PWM4H <sup>(2)</sup> | 0 | _ | No | PWM High Outputs 1 through 4 | | | CLCINA-CLCIND | 1 | ST | Yes | CLC Inputs A through D | | | CLC10UT-CLC40UT | 0 | _ | Yes | CLC Outputs 1 through 4 | | | CMP1 | 0 | _ | Yes | Comparator 1 output | | | CMP1A-CMP3A | 1 | Analog | No | Comparator Channels 1A through 3A inputs | | | CMP1B-CMP3B | 1 | Analog | No | Comparator Channels 1B through 3B inputs | | | CMP1C-CMP3C | 1 | Analog | No | Comparator Channels 1C through 3C inputs | | | CMP1D-CMP3D | 1 | Analog | No | Comparator Channels 1D through 3D inputs | | | DACOUT1 | 0 | _ | No | DAC1 output voltage | | | DACOUT2 | 0 | _ | No | DAC2 output voltage | | | IBIAS3, IBIAS2, IBIAS1,<br>IBIAS0/ISRC3, ISRC2,<br>ISRC1, ISRC0 | 0 | Analog | No | Constant-Current Outputs 0 through 3 | | **Legend:** CMOS = CMOS compatible input or output; Analog = Analog input; P = Power; ST = Schmitt Trigger input with CMOS levels; O = Output; I = Input; PPS = Peripheral Pin Select; TTL = TTL input buffer - 1. Not all pins are available in all package variants. See the Pin Diagrams section for pin availability. - 2. These pins are remappable as well as dedicated. **Device Overview** | continued | | | | | | |-------------------------|-------------|----------------|-----|----------------------------------------------------------------------------------|--| | Pin Name <sup>(1)</sup> | Pin<br>Type | Buffer<br>Type | PPS | Description | | | OA1IN+ | 1 | _ | No | Op Amp 1+ input | | | OA1IN- | 1 | _ | No | Op Amp 1- input | | | OA1OUT | 0 | _ | No | Op Amp 1 output | | | OA2IN+ | 1 | <u> </u> | No | Op Amp 2+ input | | | OA2IN- | 1 | _ | No | Op Amp 2- input | | | OA2OUT | 0 | _ | No | Op Amp 2 output | | | OA3IN+ | 1 | _ | No | Op Amp 3+ input | | | OA3IN- | 1 | <del>-</del> | No | Op Amp 3- input | | | OA3OUT | 0 | _ | No | Op Amp 3 output | | | PGD1 | I/O | ST | No | Data I/O pin for Programming/Debugging Communication Channel 1 | | | PGC1 | 1 | ST | No | Clock input pin for Programming/<br>Debugging Communication<br>Channel 1 | | | PGD2 | I/O | ST | No | Data I/O pin for Programming/Debugging Communication Channel 2 | | | PGC2 | I | ST | No | Clock input pin for Programming/<br>Debugging Communication<br>Channel 2 | | | PGD3 | I/O | ST | No | Data I/O pin for Programming/Debugging Communication Channel 3 | | | PGC3 | 1 | ST | No | Clock input pin for Programming/<br>Debugging Communication<br>Channel 3 | | | MCLR | I/P | ST | No | Master Clear (Reset) input. This pin is an active-low Reset to the device. | | | AV <sub>DD</sub> | Р | Р | No | Positive supply for analog modules. This pin must be connected at all times. | | | AV <sub>SS</sub> | Р | Р | No | Ground reference for analog modules.<br>This pin must be connected at all times. | | | $V_{DD}$ | Р | _ | No | Positive supply for peripheral logic and I/O pins | | | V <sub>SS</sub> | Р | _ | No | Ground reference for logic and I/O pins | | **Legend:** CMOS = CMOS compatible input or output; Analog = Analog input; P = Power; ST = Schmitt Trigger input with CMOS levels; O = Output; I = Input; PPS = Peripheral Pin Select; TTL = TTL input buffer - 1. Not all pins are available in all package variants. See the Pin Diagrams section for pin availability. - 2. These pins are remappable as well as dedicated. ## 2. Guidelines for Getting Started with 16-Bit Digital Signal Controllers #### 2.1 Basic Connection Requirements Getting started with the family devices of the dsPIC33CK512MP608 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 V<sub>DD</sub> and V<sub>SS</sub> pins (see 2.2 Decoupling Capacitors) - All AV<sub>DD</sub> and AV<sub>SS</sub> pins regardless if ADC module is not used (see 2.2 Decoupling Capacitors) - MCLR pin (see 2.3 Master Clear (MCLR) Pin) - PGCx/PGDx pins used for In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) and debugging purposes (see 2.4 ICSP Pins) - OSCI and OSCO pins when an external oscillator source is used (see 2.5 External Oscillator Pins) #### 2.2 Decoupling Capacitors The use of decoupling capacitors on every pair of power supply pins, such as $V_{DD}$ , $V_{SS}$ , $AV_{DD}$ and $AV_{SS}$ is required. Consider the following criteria when using decoupling capacitors: - Value and type of capacitor: Recommendation of 0.1 μF (100 nF), 10-20V. This capacitor should be a low-ESR and have resonance frequency in the range of 20 MHz and higher. It is recommended to use ceramic capacitors. - Placement on the Printed Circuit Board: The decoupling capacitors should be placed as close to the pins as possible. It is recommended to place the capacitors 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 one-quarter inch (6 mm) in length. - Handling high-frequency noise: If the board is experiencing high-frequency noise above 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. © 2021 Microchip Technology Inc. Datasheet 70005452B-page 30 Figure 2-1. Recommended Minimum Connection Note 1: 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 1Ω and the inductor capacity greater than 10 mA. Where $$f = \frac{FCNV}{2} \qquad \text{(i.e., ADC Conversion Rate/2)}$$ $$f = \frac{1}{(2\pi\sqrt{LC})}$$ $$L = \left(\frac{1}{(2\pi f\sqrt{C})}\right)^2$$ ## 2.3 Master Clear (MCLR) Pin The MCLR pin provides two specific device functions: - Device Reset - Device Programming and Debugging. 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 $\overline{MCLR}$ pin. Consequently, specific voltage levels (V<sub>IH</sub> and V<sub>IL</sub>) 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 shown 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, as shown in Figure 2-2, within one-quarter inch (6 mm) from the MCLR pin. Figure 2-2. Example of MCLR Pin Connections #### Notes: - R ≤ 10 kΩ is recommended. A suggested starting value is 10 kΩ. Ensure that the MCLR pin V<sub>IH</sub> and V<sub>IL</sub> specifications are met. - R1 ≤ 470Ω will limit any current flowing into MCLR from the external capacitor, C, in the event of MCLR pin breakdown due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS). Ensure that the MCLR pin V<sub>IH</sub> and V<sub>II</sub> specifications are met. #### 2.4 ICSP Pins The PGCx and PGDx 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 PGCx and PGDx 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 Voltage Input High ( $V_{IH}$ ) and Voltage Input Low ( $V_{IL}$ ) requirements. Ensure that the "Communication Channel Select" (i.e., PGCx/PGDx pins) programmed into the device matches the physical connections for the ICSP to PICkit™ 3, MPLAB® ICD 3 or MPLAB REAL ICE™ emulator. For more information on MPLAB ICD 2, MPLAB ICD 3 and REAL ICE emulator connection requirements, refer to the following documents that are available on the Microchip website. - "Using MPLAB" ICD 3 In-Circuit Debugger" (poster) (DS51765) - "Development Tools Design Advisory" (DS51764) - "MPLAB<sup>®</sup> REAL ICE™ In-Circuit Emulator User's Guide for MPLAB X IDE" (DS50002085) - "Using MPLAB® REAL ICE™ In-Circuit Emulator" (poster) (DS51749) #### 2.5 External Oscillator Pins When the Primary Oscillator (POSC) circuit is used to connect a crystal oscillator, special care and consideration is needed to ensure proper operation. The POSC circuit should be tested across the environmental conditions that the end product is intended to be used. The load capacitors specified in the crystal oscillator data sheet can be used as a starting point, however, the parasitic capacitance from the PCB traces can affect the circuit, and the values may need to be altered to ensure proper start-up and operation. Excessive trace length and other physical interaction can lead to poor signal quality. Poorly tuned oscillator circuits can have reduced amplitude, incorrect frequency (runt pulses), distorted waveforms and long start-up times that may result in unpredictable application behavior, such as instruction misexecution, illegal opcode fetch, etc. Ensure that the crystal oscillator circuit is at full amplitude and correct frequency before the system begins to execute code. In planning the application's routing and I/O assignments, ensure that adjacent port pins, and other signals in close proximity to the oscillator, do not have © 2021 Microchip Technology Inc. Datasheet 70005452B-page 32 high frequencies, short rise and fall times, and other similar noise. For further information on the Primary Oscillator, see 9.4 Primary Oscillator (POSC). #### 2.6 External Oscillator Layout Guidance Use best practices during PCB layout to ensure robust start-up and operation. 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. If using a two-sided board, avoid any traces on the other side of the board where the crystal is placed. A suggested layouts are shown in Figure 2-3. With fine-pitch packages, it is not always possible to completely surround the pins and components. A suitable solution is to tie the broken guard sections to a mirrored ground layer. In all cases, the guard trace(s) must be returned to ground. For additional information and design guidance on oscillator circuits, please refer to these Microchip Application Notes, available at the Microchip website (<a href="https://www.microchip.com">www.microchip.com</a>): - AN943, "Practical PICmicro<sup>®</sup> Oscillator Analysis and Design" - AN949, "Making Your Oscillator Work" - AN1798, "Crystal Selection for Low-Power Secondary Oscillator Figure 2-3. Suggested Placement of the Oscillator Circuit #### Single-Sided and In-Line Layouts: #### Copper Pour **Primary Oscillator** vstal (tied to ground) **DEVICE PINS** $\boxtimes$ $\times$ $\times$ Primary Oscillator OSCI C OSCO GND $\times$ $\boxtimes$ $\boxtimes$ #### Fine-Pitch (Dual-Sided) Layouts: #### 2.7 Oscillator Value Conditions on Device Start-up If the PLL of the target device is enabled and configured for the device start-up oscillator, the maximum oscillator source frequency must be limited to a certain frequency (see 9. Oscillator with High-Frequency PLL) to comply with device PLL start-up conditions. This means that if the external oscillator frequency is outside this range, the application must start up in the FRC mode first. The default PLL settings after a POR with an oscillator frequency outside this range will violate the device operating speed. Once the device powers up, the application firmware can initialize the PLL SFRs, CLKDIV and PLLFBD, to a suitable value, and then perform a clock switch to the Oscillator + PLL clock source. Note that clock switching must be enabled in the device Configuration Word. #### Guidelines for Getting Started with 16-Bit D... #### 2.8 Unused I/Os Unused I/O pins should be configured as outputs and driven to a logic low state. Alternatively, connect a 1k to 10k resistor between V<sub>SS</sub> and unused pins, and drive the output to logic low. #### 2.9 Bulk Capacitors On boards with power traces running longer than six inches in length, it is suggested to use a bulk capacitor for integrated circuits, including DSCs, to supply a local power source. The value of the bulk capacitor should be determined based on the trace resistance that connects the power supply source to the device and the maximum current drawn by the device in the application. In other words, select the bulk capacitor so that it meets the acceptable voltage sag at the device. Typical values range from 4.7 µF to 47 µF. #### 2.10 Targeted Applications - · Power Factor Correction (PFC): - Interleaved PFC - Critical Conduction PFC - Bridgeless PFC - DC/DC Converters: - Buck, Boost, Forward, Flyback, Push-Pull - Half/Full-Bridge - Phase-Shift Full-Bridge - Resonant Converters - · DC/AC: - Half/Full-Bridge Inverter - Resonant Inverter - Motor Control: - BLDC - PMSM - SR - ACIM Examples of typical application connections are shown in Figure 2-4 through Figure 2-6. Figure 2-4. Interleaved PFC Figure 2-5. Phase-Shifted Full-Bridge Converter Figure 2-6. Off-Line UPS ### 3. CPU **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Enhanced CPU" (www.microchip.com/DS70005158) in the "dsPIC33/PIC24 Family Reference Manual". The dsPIC33CK512MP608 family CPU has a 16-bit (data) modified Harvard architecture with an enhanced instruction set, including significant support for Digital Signal Processing (DSP). The CPU has a 24-bit instruction word with a variable length opcode field. The Program Counter (PC) is 23 bits wide and addresses up to 4M x 24 bits of user program memory space. An instruction prefetch mechanism helps maintain throughput and provides predictable execution. Most instructions execute in a single-cycle effective execution rate, with the exception of instructions that change the program flow, the double-word move (MOV.D) instruction, PSV accesses and the table instructions. Overhead-free program loop constructs are supported using the DO and REPEAT instructions, both of which are interruptible at any point. ### 3.1 Registers The dsPIC33CK512MP608 devices have sixteen, 16-bit Working registers in the programmer's model. Each of the Working registers can act as a Data, Address or Address Offset register. The 16th Working register (W15) operates as a Software Stack Pointer (SSP) for interrupts and calls. In addition, the dsPIC33CK512MP608 devices include four Alternate Working register sets, which consist of W0 through W14. The Alternate Working registers can be made persistent to help reduce the saving and restoring of register content during Interrupt Service Routines (ISRs). The Alternate Working registers can be assigned to a specific Interrupt Priority Level (IPL1 through IPL6) by configuring the CTXTx[2:0] bits in the FALTREG Configuration register. The Alternate Working registers can also be accessed manually by using the CTXTSWP instruction. The CCTXI[2:0] and MCTXI[2:0] bits in the CTXTSTAT register can be used to identify the current, and most recent, manually selected Working register sets. ### 3.2 Instruction Set The instruction set for dsPIC33CK512MP608 devices has two classes of instructions: the MCU class of instructions and the DSP class of instructions. These two instruction classes are seamlessly integrated into the architecture and execute from a single execution unit. The instruction set includes many addressing modes and was designed for optimum C compiler efficiency. Refer to the 31. Instruction Set Summary for more information. ### 3.3 Data Space Addressing The base Data Space can be addressed as up to 4K words or 8 Kbytes, and is split into two blocks, referred to as X and Y data memory. Each memory block has its own independent Address Generation Unit (AGU). The MCU class of instructions operates solely through the X memory AGU, which accesses the entire memory map as one linear Data Space. Certain DSP instructions operate through the X and Y AGUs to support dual operand reads, which splits the data address space into two parts. The X and Y Data Space boundary is device-specific. The upper 32 Kbytes of the Data Space memory map can optionally be mapped into Program Space (PS) at any 16K program word boundary. The program-to-Data Space mapping feature, known as Program Space Visibility (PSV), lets any instruction access Program Space as if it were Data Space. Refer to "Data Memory" (www.microchip.com/DS70595) in the "dsPIC33/PIC24 Family Reference Manual" for more details on PSV and table accesses. On dsPIC33CK512MP608 family devices, overhead-free circular buffers (Modulo Addressing) are supported in both X and Y address spaces. The Modulo Addressing removes the software boundary checking overhead for DSP algorithms. The X AGU Circular Addressing can be used with any of the MCU class of instructions. The X AGU also supports Bit-Reversed Addressing to greatly simplify input or output data re-ordering for radix-2 FFT algorithms. ### 3.4 Addressing Modes The CPU supports these addressing modes: - Inherent (no operand) - Relative - Literal - Memory Direct - Register Direct - · Register Indirect Each instruction is associated with a predefined addressing mode group, depending upon its functional requirements. As many as six addressing modes are supported for each instruction. Figure 3-1. dsPIC33CK512MP608 Family CPU Block Diagram #### 3.4.1 Programmer's Model The programmer's model for the dsPIC33CK512MP608 family is shown in Figure 3-2. All registers in the programmer's model are memory-mapped and can be manipulated directly by instructions. Table 3-1 lists a description of each register. In addition to the registers contained in the programmer's model, the dsPIC33CK512MP608 devices contain control registers for Modulo Addressing, Bit-Reversed Addressing and interrupts. These registers are described in subsequent sections of this document. All registers associated with the programmer's model are memory-mapped, as shown in Figure 3-2. Table 3-1. Programmer's Model Register Descriptions | Register(s) Name | Description | |-----------------------------------|---------------------------------------------------------------| | W0 through W15 <sup>(1)</sup> | Working Register Array | | W0 through W14 <sup>(1)</sup> | Alternate Working Register Array 1 | | W0 through W14 <sup>(1)</sup> | Alternate Working Register Array 2 | | W0 through W14 <sup>(1)</sup> | Alternate Working Register Array 3 | | W0 through W14 <sup>(1)</sup> | Alternate Working Register Array 4 | | ACCA, ACCB | 40-Bit DSP Accumulators (Additional 4 Alternate Accumulators) | | PC | 23-Bit Program Counter | | SR | ALU and DSP Engine STATUS Register | | SPLIM | Stack Pointer Limit Value Register | | TBLPAG | Table Memory Page Address Register | | DSRPAG | Extended Data Space (EDS) Read Page Register | | RCOUNT | REPEAT Loop Counter Register | | DCOUNT | DO Loop Counter Register | | DOSTARTH, DOSTARTL <sup>(2)</sup> | DO Loop Start Address Register (High and Low) | | DOENDH, DOENDL | DO Loop End Address Register (High and Low) | | CORCON | Contains DSP Engine, DO Loop Control and Trap Status bits | | Matan | | #### Notes: - 1. Memory-mapped W0 through W14 represent the value of the register in the currently active CPU context. - 2. The DOSTARTH and DOSTARTL registers are read-only. **Datasheet** Figure 3-2. Programmer's Model # dsPIC33CK512MP608 Family ### 3.4.2 CPU Resources Many useful resources are provided on the main product page of the Microchip website for the devices listed in this data sheet. This product page contains the latest updates and additional information. # 3.5 CPU Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------------------------------------|-----------------------------------------|-------------------|---------------------------|--------------|---|-------|------------------------|---|-----|------------|--| | 000 | WDEGO | 15:8 | | | | WREG | 60[15:8] | | | | | | 0x00 | WREG0 | 7:0 | | | | | 30[7:0] | | | | | | 0,,00 | WDEC4 | 15:8 | | | | WREG | 61[15:8] | | | | | | 0x02 | WREG1 | 7:0 | | | | WREG | G1[7:0] | | | | | | 0x04 | WREG2 | 15:8 | | | | WREG | 62[15:8] | | | | | | 0.04 | WREGZ | 7:0 | | | | WREG | G2[7:0] | | | | | | 0x06 | WREG3 | 15:8 | | | | WREG | 3[15:8] | | | | | | UXUU | WKEGS | 7:0 | | | | | G3[7:0] | | | | | | 0x08 | WREG4 | 15:8 | | | | | 64[15:8 <mark>]</mark> | | | | | | 0,00 | WILCH | 7:0 | | WREG4[7:0] | | | | | | | | | 0x0A | WREG5 | 15:8 | | WREG5[15:8] | | | | | | | | | UNUA | WINEGO | 7:0 | | WREG5[7:0] | | | | | | | | | 0x0C | WREG6 | 15:8 | | | | WREG | 6[15:8] | | | | | | UNUU | WINEGO | 7:0 | | | | WREC | 36[7:0] | | | | | | 0x0E | WREG7 | 15:8 | | | | WREG | 67[15:8] | | | | | | OXOL | WILEO | 7:0 | | | | | G7[7:0] | | | | | | 0x10 | WREG8 | 15:8 | | | | | 8[15:8] | | | | | | OXIO | WILEGO | 7:0 | | | | | 38[7:0] | | | | | | 0x12 | WREG9 | 15:8 | | | | | 9[15:8] | | | | | | OXIL | MALOO | 7:0 | | | | | G9[7:0] | | | | | | 0x14 | WREG10 | 15:8 | | | | | 10[15:8] | | | | | | JATT. | *************************************** | 7:0 | | | | | 10[7:0] | | | | | | 0x16 | WREG11 | 15:8 WREG11[15:8] | | | | | | | | | | | | 130303474.024.45 | 7:0 | WREG11[7:0] | | | | | | | | | | 0x18 | WREG12 | 15:8 | | WREG12[15:8] | | | | | | | | | 50.13 | 111111111111111111111111111111111111111 | 7:0 | | | | | 312[7:0] | | | | | | 0x1A | WREG13 | 15:8 | | | | | 13[15:8] | | | | | | | NO. 1. WILLIAM ST. | 7:0 | WREG13[7:0] | | | | | | | | | | 0x1C | WREG14 | 15:8 | WREG14[15:8] | | | | | | | | | | 000000000000000000000000000000000000000 | to one they a s | 7:0 | | | | | 614[7:0] | | | | | | 0x1E | WREG15 | 15:8 | | | | | 15[15:8] | | | | | | | 15/10/2005/200109 | 7:0 | | | | | 15[7:0] | | | | | | 0x20 | SPLIM | 15:8 | | | | | M[15:8] | | | | | | | | 7:0 | | | | SPLII | | | | | | | 0x22 | ACCAL | 15:8 | | | | | L[15:8] | | | | | | | | 7:0 | | | | | AL[7:0] | | | | | | 0x24 | ACCAH | 15:8 | | | | | H[15:8] | | | | | | | | 7:0 | | | | ACCA | | | | | | | 0x26 | ACCAU | 15:8 | | | | | 39[7:0] | | | | | | | | 7:0 | | | | | NU[7:0] | | | | | | 0x28 | ACCBL | 15:8 | | | | | L[15:8] | | | | | | | 110000000000 | 7:0 | | | | | BL[7:0] | | | | | | 0x2A | ACCBH | 15:8 | | | | ACCB | | | | | | | | | 7:0 | | | | | 3H[7:0] | | | | | | 0x2C | ACCBU | 15:8 | ACCB39[7:0]<br>ACCBU[7:0] | | | | | | | | | | | | 7:0 | | | | | | | | | | | 0x2E | PCL | 15:8 | | | | | [15:8] | | | | | | | **** | 7:0 | | | | PCL | .[7:0] | | | | | | 0x30 | PCH | 15:8 | | | | DOL | 1[7:0] | | | | | | | MIL-ACCID. | 7:0 | | | | PCF | 1[7:0] | | Don | DA C(0:01 | | | 0x32 | DSRPAG | 15:8 | | | | 2022 | A 017.01 | | DSR | RPAG[9:8] | | | | | 7:0 | | | | DSRP | AG[7:0] | | | DOM/DA OFS | | | 0x33 DSWPAG 7:0 DSWPAG[7:0] | | | | DSWPAG[8] | | | | | | | | | | D | 7:0 | | | | DSWP | AG[/:0] | | | | | | 0x35 | Reserved | | | | | | | | | | | | conti | nued | | | | | | | | | | |--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------|----------|-------|-----------------------------------------------|--------------|---------|------------|-------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x36 | RCOUNT | 15:8 | | | | RCOU | NT[15:8] | | | | | UX36 | RCOUNT | 7:0 | | | | RCOU | NT[7:0] | | | | | 020 | DCOUNT | 15:8 | | | | DCOU | NT[15:8] | | | | | 0x38 | DCOUNT | 7:0 | | | | DCOU | NT[7:0] | | | | | 024 | DOCTABLE | 15:8 | | | | DOSTA | RTL[15:8] | | | | | 0x3A | DOSTARTL | 7:0 | | | | DOSTA | RTL[7:0] | | | | | 020 | DOCTABIL | 15:8 | | | | | | | | | | 0x3C | DOSTARTH | 7:0 | | | | | DOSTARTH[6:0 | ] | | | | 005 | DOENDI | 15:8 | | | | DOENI | DL[15:8] | | | | | 0x3E | DOENDL | 7:0 | | | | DOEN | IDL[7:0] | | | | | 0.40 | DOENBU | 15:8 | | | | | | | | | | 0x40 | DOENDH | 7:0 | | | | | DOENDH[6:0] | | | | | | | 15:8 | OA | ОВ | SA | SB | OAB | SAB | DA | DC | | 0x42 | SR | 7:0 | | IPL[2:0] | | RA | N | OV | Z | С | | | 22222 | 15:8 | VAR US[1:0] EDT | | | | | | | | | 0x44 | CORCON | 7:0 | SATA | SATB | SATDW | ACCSAT | IPL3 | SFA | RND | IF | | | | 15:8 | XMODEN | YMODEN | | | | BWI | M[3:0] | | | 0x46 MODCON 7:0 YWM[3:0] | | | | | | M[3:0] | | | | | | 0v49 VMODERT | 15:8 | | | | XS[ | 15:8] | | | | | | 0x48 | XMODSRT | 7:0 | | | | | | | | | | | DAMESTICAL COSTS. | 15:8 | XE[15:8] | | | | | | | | | 0x4A | XMODEND | 7:0 | | | | XE | [7:0] | | | | | | | 15:8 | YS[15:8] | | | | | | | | | 0x4C | YMODSRT | 7:0 | | | | YS | [7:0] | | | | | | | 15:8 | | | | | 15:8] | | | | | 0x4E | YMODEND | 7:0 | | | | | [7:0] | | | | | | Will are declarated as | 15:8 | BREN | | | | XB[14:8] | | | | | 0x50 | XBREV | 7:0 | | | | XB | [7:0] | | | | | | and the same of th | 15:8 | | | | 9700-1 | DISICN | T[13:8] | | | | 0x52 | DISICNT | 7:0 | | | | DISIC | NT[7:0] | | | | | | | 15:8 | | | | | | | | | | 0x54 | TBLPAG | 7:0 | | | | TBLPA | AG[7:0] | | | | | | (Wownburlings) | 15:8 | | | | | | | | | | 0x56 | YPAG | 7:0 | | | | YPA | G[7:0] | | | | | | 2000000 | 15:8 | | | | | | | | | | 0x58 | MSTRPR | 7:0 | | | DMAPR | CANPR | CAN2PR | | | NVMPR | | 200 | | 15:8 | | | | (Fig. 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, | | | CCTXI[2:0] | | | 0x5A | CTXTSTAT | 7:0 | | | | | | | MCTXI[2:0] | | # 3.5.1 Working Register x Name: WREGx **Offset:** 0x00, 0x02, 0x04, 0x06, 0x08, 0x0A, 0x0C, 0x0E, 0x10, 0x12, 0x14, 0x16, 0x18, 0x1A, 0x1C, 0x1E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|---------|-----|-----|-----|--|--| | | WREGx[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | WREC | 3x[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - WREGx[15:0] Data bits # 3.5.2 Stack Pointer Limit Value Register Name: SPLIM Offset: 0x20 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | SPLIM[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | SPLI | M[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - SPLIM[15:0] Stack Limit Address bits # 3.5.3 Accumulator A Low Register Name: ACCAL Offset: 0x22 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | ACCAL[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | ACCA | L[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - ACCAL[15:0] Accumulator A Low Register bits # 3.5.4 Accumulator A High Register Name: ACCAH Offset: 0x24 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | ACCAH[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | ACCA | H[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - ACCAH[15:0] Accumulator A High Register bits # 3.5.5 Accumulator A Upper Register Name: ACCAU Offset: 0x26 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-------------|-----|-----|------|---------|-----|-----|-----|--| | | ACCA39[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | ACCA | .U[7:0] | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:8 - ACCA39[7:0] Accumulator A bits Bits 7:0 - ACCAU[7:0] Accumulator A bits # 3.5.6 Accumulator B Low Register Name: ACCBL Offset: 0x28 Property: R/W | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|----|----|------|---------|----|----|----|--|--| | | ACCBL[15:8] | | | | | | | | | | | Access | RW | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | ACCE | BL[7:0] | | | | | | | Access | RW | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - ACCBL[15:0] Accumulator B Low Register bits # 3.5.7 Accumulator B High Register Name: ACCBH Offset: 0x2A Property: R/W | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | ACCBH[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | ACCB | H[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - ACCBH[15:0] Accumulator B High Register bits # 3.5.8 Accumulator B Upper Address Register Name: ACCBU Offset: 0x2C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--| | | ACCB39[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | ACCB | U[7:0] | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:8 - ACCB39[7:0] Accumulator B bits Bits 7:0 - ACCBU[7:0] Accumulator B bits # 3.5.9 Program Counter Low Register Name: PCL Offset: 0x2E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----------|-----|-----|-----|-------|-----|-----|-----|--|--| | | PCL[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PCL | [7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - PCL[15:0] Program Counter Low Value bits # 3.5.10 Program Counter High Register Name: PCH Offset: 0x30 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-----|-------|-----|-----|-----| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PCH | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - PCH[7:0] Program Counter High Value bits #### 3.5.11 Data Space Read Page Register **DSRPAG** Name: Offset: 0x32 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-------|---------| | | | | | | | | DSRPA | \G[9:8] | | Access | | , | | ). | | | R/W | R/W | | Reset | | | | | | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DSRPA | AG[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 9:0 - DSRPAG[9:0] Data Space Read Page Value bits # 3.5.12 Data Space Write Page Register Name: DSWPAG Offset: 0x33 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|---------|-----|-----|-----------| | | | | | | | | | DSWPAG[8] | | Access | | | | | | | , | R/W | | Reset | | | | | | | | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DSWP | 4G[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 8:0 - DSWPAG[8:0] Data Space Write Page Value bits # 3.5.13 REPEAT Loop Counter Register Name: RCOUNT Offset: 0x36 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|----------|-----|-----|-----| | | | | | RCOUN | NT[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RCOU | NT[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 – RCOUNT[15:0] Current Loop Counter Value for REPEAT Instruction bits # 3.5.14 DO Loop Iteration Count Register Name: DCOUNT Offset: 0x38 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|----------|-----|-----|-----| | | | | | DCOUN | NT[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DCOU | NT[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - DCOUNT[15:0] DO Loop Iteration Count Register bits # 3.5.15 DO Loop Start Address Register Low Name: DOSTARTL Offset: 0x3A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|--------|-----------|----|---|---| | | | | | DOSTAF | RTL[15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DOSTA | RTL[7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - DOSTARTL[15:0] Current DO Loop Start Address bits Note: DOSTART[0] always reads as '0'; DOSTART is a read-only register. # 3.5.16 DO Loop Start Address Register High Name: DOSTARTH Offset: 0x3C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|----|---------------|----|---|---| | | | | | | | | | | | Access | | | | ). | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 1 | DOSTARTH[6:0] | | | | | Access | | R | R | R | R | R | R | R | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 6:0 - DOSTARTH[6:0] Current DO Loop Start Address bits Note: DOSTART[0] always reads as '0'; DOSTART is a read-only register. # 3.5.17 DO Loop End Address Register Low Name: DOENDL Offset: 0x3E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|------|----------|----|---|---| | | | | | DOEN | DL[15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DOEN | DL[7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - DOENDL[15:0] Current DO Loop End Address bits Note: DOEND[0] always reads as '0'. # 3.5.18 DO Loop End Address Register High Name: DOENDH Offset: 0x40 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|----|----|----|----|-------------|----|---|---| | Access<br>Reset | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | DOENDH[6:0] | | | | | Access | | R | R | R | R | R | R | R | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 6:0 - DOENDH[6:0] Current DO Loop End Address bits Note: DOEND[0] always reads as '0'. ### 3.5.19 CPU STATUS Register Name: SR Offset: 0x42 #### Notes: - 1. The IPL[2:0] bits are concatenated with the IPL[3] bit (CORCON[3]) to form the CPU Interrupt Priority Level. The value in parentheses indicates the IPL, if IPL[3] = 1. User interrupts are disabled when IPL[3] = 1. - 2. The IPL[2:0] Status bits are read-only when the NSTDIS bit (INTCON1[15]) = 1. - 3. A data write to the SR register can modify the SA and SB bits by either a data write to SA and SB or by clearing the SAB bit. To avoid a possible SA or SB bit write race condition, the SA and SB bits should not be modified using bit operations. #### Legend: C = Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|----------|-----|-----|-----|-----|-----|-----| | | OA | ОВ | SA | SB | OAB | SAB | DA | DC | | Access | R/W | R/W | R/W | R/W | R/C | R/C | R | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | IPL[2:0] | | RA | N | OV | Z | С | | Access | R/W | R/W | R/W | R | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - OA Accumulator A Overflow Status bit | Value | Description | |-------|----------------------------------| | 1 | Accumulator A has overflowed | | 0 | Accumulator A has not overflowed | ### Bit 14 - OB Accumulator B Overflow Status bit | Value | Description | |-------|----------------------------------| | 1 | Accumulator B has overflowed | | 0 | Accumulator B has not overflowed | #### Bit 13 - SA Accumulator A Saturation 'Sticky' Status bit(3) | Value | Description | |-------|---------------------------------------------------------------| | 1 | Accumulator A is saturated or has been saturated at some time | | 0 | Accumulator A is not saturated | #### Bit 12 - SB Accumulator B Saturation 'Sticky' Status bit(3) | Value | Description | |-------|---------------------------------------------------------------| | 1 | Accumulator B is saturated or has been saturated at some time | | 0 | Accumulator B is not saturated | #### Bit 11 - OAB OA || OB Combined Accumulator Overflow Status bit | Value | Description | |-------|-------------------------------------------| | 1 | Accumulator A or B has overflowed | | 0 | Neither Accumulator A or B has overflowed | ### Bit 10 - SAB SA | SB Combined Accumulator 'Sticky' Status bit | Dit IV - C | Bit 10 - GAB GAT GB GOTTISTICA ACCUMULATOR OTICKY OTICKS OTICKS | | |------------|--------------------------------------------------------------------|--| | Value | Description | | | 1 | Accumulator A or B is saturated or has been saturated at some time | | | 0 | Neither Accumulator A or B is saturated | | #### Bit 9 - DA DO Loop Active bit | Value | Description | |-------|----------------------------| | 1 | DO loop is in progress | | 0 | DO loop is not in progress | #### Bit 8 - DC MCU ALU Half Carry/Borrow bit | Value | Description | |-------|-------------------------------------------------------------------------------------------------------------| | 1 | A carry-out from the 4th low-order bit (for byte-sized data) or 8th low-order bit (for word-sized data) of | | | the result occurred | | 0 | No carry-out from the 4th low-order bit (for byte-sized data) or 8th low-order bit (for word-sized data) of | | | the result occurred | #### Bits 7:5 – IPL[2:0] CPU Interrupt Priority Level Status bits<sup>(1,2)</sup> | Value | Description | |-------|----------------------------------------------------------------------| | 111 | CPU Interrupt Priority Level is 7 (15); user interrupts are disabled | | 110 | CPU Interrupt Priority Level is 6 (14) | | 101 | CPU Interrupt Priority Level is 5 (13) | | 100 | CPU Interrupt Priority Level is 4 (12) | | 011 | CPU Interrupt Priority Level is 3 (11) | | 010 | CPU Interrupt Priority Level is 2 (10) | | 001 | CPU Interrupt Priority Level is 1 (9) | | 000 | CPU Interrupt Priority Level is 0 (8) | #### Bit 4 - RA REPEAT Loop Active bit | Value | Description | |-------|--------------------------------| | 1 | REPEAT loop is in progress | | 0 | REPEAT loop is not in progress | ### Bit 3 - N MCU ALU Negative bit | Value | Description | |-------|--------------------------------------------| | 1 | Result was negative | | 0 | Result was non-negative (zero or positive) | ### Bit 2 - OV MCU ALU Overflow bit This bit is used for signed arithmetic (two's complement). It indicates an overflow of the magnitude that causes the sign bit to change state | Value | Description | |-------|------------------------------------------------------------------------| | 1 | Overflow occurred for signed arithmetic (in this arithmetic operation) | | 0 | No overflow occurred | ### Bit 1 - Z MCU ALU Zero bit | Value | Description | |-------|-------------------------------------------------------------------------------------------| | 1 | An operation that affects the Z bit has set it at some time in the past | | 0 | The most recent operation that affects the Z bit has cleared it (i.e., a non-zero result) | ### Bit 0 - C MCU ALU Carry/Borrow bit | Value | Description | |-------|-------------------------------------------------------------------| | 1 | A carry-out from the Most Significant bit of the result occurred | | 0 | No carry-out from the Most Significant bit of the result occurred | ### 3.5.20 Core Control Register Name: CORCON Offset: 0x44 #### Notes: 1. This bit is always read as '0'. 2. The IPL3 bit is concatenated with the IPL[2:0] bits (SR[7:5]) to form the CPU Interrupt Priority Level. #### Legend: C = Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|------|-------|--------|------|-----|---------|-----| | | VAR | | US | [1:0] | EDT | | DL[2:0] | | | Access | R/W | | R/W | R/W | R/W | R | R | R | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SATA | SATB | SATDW | ACCSAT | IPL3 | SFA | RND | IF | | Access | R/W | R/W | R/W | R/W | R/C | R | R/W | R/W | | Reset | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - VAR Variable Exception Processing Latency Control bit | Value | Description | |-------|------------------------------------------| | 1 | Variable exception processing is enabled | | 0 | Fixed exception processing is enabled | #### Bits 13:12 - USI1:01 DSP Multiply Unsigned/Signed Control bits | Bits 10:12 - Co[1:0] Don Mainply Onsigned Control bits | | | |--------------------------------------------------------|--------------------------------------|--| | Value | Description | | | 11 | Reserved | | | 10 | DSP engine multiplies are mixed sign | | | 01 | DSP engine multiplies are unsigned | | | 00 | DSP engine multiplies are signed | | ### Bit 11 - EDT Early DO Loop Termination Control bit(1) | Value | Description | |-------|-----------------------------------------------------------------------| | 1 | Terminates executing DO loop at the end of the current loop iteration | | 0 | No effect | ### Bits 10:8 - DL[2:0] DO Loop Nesting Level Status bits | Value | Description | |-------|-----------------------| | 111 | 7 DO loops are active | | | | | 001 | 1 DO loop is active | | 000 | 0 DO loops are active | #### Bit 7 - SATA ACCA Saturation Enable bit | Value | Description | |-------|--------------------------------------| | 1 | Accumulator A saturation is enabled | | 0 | Accumulator A saturation is disabled | #### Bit 6 - SATB ACCB Saturation Enable bit | Value | Description | |-------|--------------------------------------| | 1 | Accumulator B saturation is enabled | | 0 | Accumulator B saturation is disabled | ### Bit 5 - SATDW Data Space Write from DSP Engine Saturation Enable bit | | - | |---|----| | - | DI | | L | PU | | Value | Description | |-------|-----------------------------------------| | 1 | Data Space write saturation is enabled | | 0 | Data Space write saturation is disabled | ### Bit 4 - ACCSAT Accumulator Saturation Mode Select bit | Value | Description | |-------|-------------------------------------| | 1 | 9.31 saturation (super saturation) | | 0 | 1.31 saturation (normal saturation) | ### Bit 3 - IPL3 CPU Interrupt Priority Level Status bit 3(2) | Value | Description | |-------|------------------------------------------------| | 1 | CPU Interrupt Priority Level is greater than 7 | | 0 | CPU Interrupt Priority Level is 7 or less | #### Bit 2 - SFA Stack Frame Active Status bit | Value | Description | |-------|-----------------------------------------------------------------------------------| | 1 | Stack frame is active; W14 and W15 address 0x0000 to 0xFFFF, regardless of DSRPAG | | 0 | Stack frame is not active; W14 and W15 address the base Data Space | #### Bit 1 - RND Rounding Mode Select bit | Value | Description | |-------|-------------------------------------------| | 1 | Biased (conventional) rounding is enabled | | 0 | Unbiased (convergent) rounding is enabled | ### Bit 0 - IF Integer or Fractional Multiplier Mode Select bit | Value | Description | |-------|---------------------------------------------| | 1 | Integer mode is enabled for DSP multiply | | 0 | Fractional mode is enabled for DSP multiply | ### 3.5.21 Modulo and Bit-Reversed Addressing Control Register Name: MODCON Offset: 0x46 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|-----|-----|-----|--------|-----| | | XMODEN | YMODEN | | | | BWN | 1[3:0] | | | Access | R/W | R/W | | | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | YWN | 1[3:0] | | | XWN | 1[3:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - XMODEN X RAGU and X WAGU Modulus Addressing Enable bit | Value | Description | |-------|-----------------------------------| | 1 | X AGU Modulus Addressing enabled | | 0 | X AGU Modulus Addressing disabled | #### Bit 14 - YMODEN Y AGU Modulus Addressing Enable bit | Value | Description | |-------|-----------------------------------| | 1 | Y AGU Modulus Addressing enabled | | 0 | Y AGU Modulus Addressing disabled | ### Bits 11:8 - BWM[3:0] X WAGU Register Select for Bit-Reversed Addressing bits | Value | Description | |-------|------------------------------------------| | 0000 | W0 selected for Bit-Reversed Addressing | | 1110 | W14 selected for Bit-Reversed Addressing | | 1111 | W15 Bit-Reversed Addressing disabled | #### Bits 7:4 - YWM[3:0] Y AGU W Register Select for Modulo Addressing bits | Value | Description | | |-------|------------------------------------|--| | 0000 | W0 selected for Modulo Addressing | | | 1110 | W14 selected for Modulo Addressing | | | 1111 | W15 Modulo Addressing disabled | | #### Bits 3:0 - XWM[3:0] X RAGU and X WAGU W Register Select for Modulo Addressing bits | Value | Description | |-------|------------------------------------| | 0000 | W0 selected for Modulo Addressing | | 1110 | W14 selected for Modulo Addressing | | 1111 | W15 Modulo Addressing disabled | # 3.5.22 X AGU Modulo Addressing Start Register Name: XMODSRT Offset: 0x48 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|-----|-----|------|-------|-----|-----|-----| | | | | | XS[´ | 15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | XS[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - XS[15:0] X RAGU and X WAGU Modulo Addressing Start Address bits # 3.5.23 X AGU Modulo Addressing End Register Name: XMODEND Offset: 0x4A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------|-----|-----|-----|-----|-----|-----|-----|--|--| | | XE[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | XE[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - XE[15:0] X RAGU and X WAGU Modulo Addressing End Address bits # 3.5.24 Y AGU Modulo Addressing Start Register Name: YMODSRT Offset: 0x4C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----------|-----|-----|-----|-----|-----|-----|-----|--| | | YS[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | YS[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - YS[15:0] Y AGU Modulo Addressing Start Address bits ### **CPU** # 3.5.25 Y AGU Modulo Addressing End Register Name: YMODEND Offset: 0x4E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|-----|-----|-----|-------|-----|-----|-----| | | | | | YE[ | 15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | YE[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - YE[15:0] X AGU Modulo Addressing End Address bits ## 3.5.26 X AGU Bit Reversal Addressing Control Register Name: XBREV Offset: 0x50 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|-----|-----|-----|----------|-----|-----|-----| | | BREN | | | | XB[14:8] | | | | | Access | R/W | Reset | 0 | X | X | X | X | X | X | X | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | XB[ | 7:0] | | | | | Access | R/W | Reset | X | X | X | X | X | X | X | X | Bit 15 - BREN Bit-Reversed Addressing (X AGU) Enable bit | Value | Description | |-------|----------------------------------| | 1 | Bit-Reversed Addressing enabled | | 0 | Bit-Reversed Addressing disabled | Bits 14:0 - XB[14:0] X AGU Bit-Reversed Modifier bits ## 3.5.27 Disable Interrupt Count Register Name: DISICNT Offset: 0x52 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|---------|-----|-----| | | | | | | DISICN | T[13:8] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DISIC | NT[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:0 - DISICNT[13:0] Current Counter Value for DISI Instruction bits ## 3.5.28 Table Memory Page Address Register Name: TBLPAG Offset: 0x54 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | | | | | | | Access | | | | ** | | | - | - | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TBLPA | \G[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - TBLPAG[7:0] Table Memory Page Value bits ## 3.5.29 Y Page Register Name: YPAG Offset: 0x56 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | | | | | | | | | | | Access | | | | | | | | - | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | YPAG | S[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - YPAG[7:0] Y Page bits **Note:** When implemented, YPAG is a R/W SFR register which resets to 0x0001. When not implemented, YPAG is a read-only SFR register which will always return the fixed Y RAM page value, 0x0001. ## 3.5.30 EDS Bus Initiator Priority Control Register Name: MSTRPR Offset: 0x58 ## Bit 5 - DMAPR Modify DMA Controller Bus Initiator Priority Relative to CPU bit | Value | Description | |-------|-----------------------------------------------------------------------| | 1 | Raises DMA Controller bus Initiator priority to above that of the CPU | | 0 | No change to DMA Controller bus Initiator priority | ### Bit 4 - CANPR Modify CAN1 Bus Initiator Priority Relative to CPU bit | Value | Description | |-------|-------------------------------------------------------------| | 1 | Raises CAN1 bus Initiator priority to above that of the CPU | | 0 | No change to CAN1 bus Initiator priority | ### Bit 3 - CAN2PR Modify CAN2 Bus Initiator Priority Relative to CPU bit | Value | Description | |-------|-------------------------------------------------------------| | 1 | Raises CAN2 bus Initiator priority to above that of the CPU | | 0 | No change to CAN2 bus Initiator priority | ## Bit 0 - NVMPR Modify NVM Controller Bus Initiator Priority Relative to CPU bit | Value | Description | |-------|-----------------------------------------------------------------------| | 1 | Raises NVM Controller bus Initiator priority to above that of the CPU | | 0 | No change to NVM Controller bus Initiator priority | #### 3.5.31 **CPU W Register Context Status Register** **CTXTSTAT** Name: Offset: 0x5A Bits 10:8 - CCTXI[2:0] Current (W Register) Context Identifier bits | Value | Description | |-------|------------------------------------------------------| | 111 | Reserved | | | | | 100 | Alternate Working Register Set 4 is currently in use | | 011 | Alternate Working Register Set 3 is currently in use | | 010 | Alternate Working Register Set 2 is currently in use | | 001 | Alternate Working Register Set 1 is currently in use | | 000 | Default register set is currently in use | Bits 2:0 - MCTXI[2:0] Manual (W Register) Context Identifier bits | Value | Description | |-------|----------------------------------------------------------------------| | 111 | Reserved | | | | | 100 | Alternate Working Register Set 4 was most recently manually selected | | 011 | Alternate Working Register Set 3 was most recently manually selected | | 010 | Alternate Working Register Set 2 was most recently manually selected | | 001 | Alternate Working Register Set 1 was most recently manually selected | | 000 | Default register set was most recently manually selected | #### 3.6 **Arithmetic Logic Unit (ALU)** The dsPIC33CK512MP608 family ALU is 16 bits wide and is capable of addition, subtraction, bit shifts and logic operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. Depending on the operation, the ALU can affect the values of the Carry (C), Zero (Z), Negative (N), Overflow (OV) and Digit Carry (DC) Status bits in the SR register. The C and DC Status bits operate as Borrow and Digit Borrow bits, respectively, for subtraction operations. The ALU can perform 8-bit or 16-bit operations, depending on the mode of the instruction that is used. Data for the ALU operation can come from the W register array or data memory, depending on the addressing mode of the instruction. Likewise, output data from the ALU can be written to the W register array or a data memory location. Refer to the "16-Bit MCU and DSC Programmer's Reference Manual" (www.microchip.com/DS70000157) for information on the SR bits affected by each instruction. The core CPU incorporates hardware support for both multiplication and division. This includes a dedicated hardware multiplier and support hardware for 16-bit divisor division. #### 3.6.1 Multiplier Using the high-speed, 17-bit x 17-bit multiplier, the ALU supports unsigned, signed or mixed-sign operation in several MCU Multiplication modes: - 16-bit x 16-bit signed - · 16-bit x 16-bit unsigned - 16-bit signed x 5-bit (literal) unsigned - · 16-bit signed x 16-bit unsigned - 16-bit unsigned x 5-bit (literal) unsigned - · 16-bit unsigned x 16-bit signed - · 8-bit unsigned x 8-bit unsigned #### 3.6.2 Divider The divide block supports 32-bit/16-bit and 16-bit/16-bit signed and unsigned integer divide operations with the following data sizes: - 32-bit signed/16-bit signed divide - · 32-bit unsigned/16-bit unsigned divide - 16-bit signed/16-bit signed divide - · 16-bit unsigned/16-bit unsigned divide The 16-bit signed and unsigned DIV instructions can specify any W register for both the 16-bit divisor (Wn) and any W register (aligned) pair (W(m + 1):Wm) for the 32-bit dividend. The divide algorithm takes one cycle per bit of divisor, so both 32-bit/16-bit and 16-bit/16-bit instructions take the same number of cycles to execute. There are additional instructions: DIV2 and DIVF2. Divide instructions will complete in six cycles. ## 3.7 DSP Engine The DSP engine consists of a high-speed 17-bit x 17-bit multiplier, a 40-bit barrel shifter and a 40-bit adder/subtracter (with two target accumulators, round and saturation logic). The DSP engine can also perform inherent accumulator-to-accumulator operations that require no additional data. These instructions are: ADD, SUB, NEG, MIN and MAX. The DSP engine has options selected through bits in the CPU Core Control register (CORCON), as listed below: - · Fractional or integer DSP multiply (IF) - Signed, unsigned or mixed-sign DSP multiply (USx) - Conventional or convergent rounding (RND) - Automatic saturation on/off for ACCA (SATA) - · Automatic saturation on/off for ACCB (SATB) - Automatic saturation on/off for writes to data memory (SATDW) - Accumulator Saturation mode selection (ACCSAT) | Instruction | Algebraic Operation | ACC Write-Back | |-------------|-----------------------|----------------| | CLR | A = 0 | Yes | | ED | $A = (x - y)^2$ | No | | EDAC | $A = A + (x - y)^2$ | No | | MAC | $A = A + (x \cdot y)$ | Yes | | MAC | $A = A + x^2$ | No | | MOVSAC | No change in A | Yes | | MPY | $A = x \cdot y$ | No | | MPY | $A = x^2$ | No | | MPY.N | $A = -x \cdot y$ | No | | MSC | $A = A - x \cdot y$ | Yes | ## 4. Memory Organization **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "dsPIC33/PIC24 Program Memory" (www.microchip.com/DS70000613) in the "dsPIC33/PIC24 Family Reference Manual". The dsPIC33CK512MP608 family architecture features separate program and data memory spaces, and buses. This architecture also allows the direct access of program memory from the Data Space (DS) during code execution. ## 4.1 Program Address Space The program address memory space of the dsPIC33CK512MP608 family devices is 4M instructions. The space is addressable by a 24-bit value derived either from the 23-bit PC during program execution, or from table operation or Data Space remapping, as described in 4.4.5 Interfacing Program and Data Memory Spaces. User application access to the program memory space is restricted to the lower half of the address range (0x000000 to 0x7FFFFF). The exception is the use of TBLRD operations, which use TBLPAG[7] to permit access to calibration data and Device ID sections of the configuration memory space. The program memory maps for the dsPIC33CK512MP608 devices are shown in Figure 4-1 through Figure 4-3. Figure 4-1. Program Memory Map for dsPIC33CK512MP608 Device<sup>(1)</sup> #### Notes: - 1. Memory areas are not shown to scale. - 2. Calibration data area must be maintained during programming. - 3. Calibration data area includes UDID, ICSP™ Write Inhibit and FBOOT registers' locations. - 4. See Figure 4-2 and Figure 4-3 for details Figure 4-2. Program Memory Map for dsPIC33CK512MP60X/30X Devices<sup>(1)</sup> #### Note: 1. Memory areas are not shown to scale. Figure 4-3. Program Memory Map for dsPIC33CK256MP60X/30X Devices<sup>(1)</sup> #### Note: 1. Memory areas are not shown to scale. ## 4.1.1 Program Memory Organization The program memory space is organized in word-addressable blocks. Although it is treated as 24 bits wide, it is more appropriate to think of each address of the program memory as a lower and upper word, with the upper byte of the upper word being unimplemented. The lower word always has an even address, while the upper word has an odd address (4.1.2 Interrupt and Trap Vectors). Program memory addresses are always word-aligned on the lower word, and addresses are incremented or decremented, by two, during code execution. This arrangement provides compatibility with data memory space addressing and makes data in the program memory space accessible. #### 4.1.2 Interrupt and Trap Vectors All dsPIC33CK512MP608 family devices reserve the addresses between 0x000000 and 0x000200 for hard-coded program execution vectors. A hardware Reset vector is provided to redirect code execution from the default value of the PC on device Reset to the actual start of code. A GOTO instruction is programmed by the user application at address, 0x000000, of Flash memory, with the actual address for the start of code at address, 0x000002, of Flash memory. A more detailed discussion of the Interrupt Vector Tables (IVTs) is provided in 7. Interrupt Controller. Figure 4-4. Program Memory Organization ### 4.1.3 Unique Device Identifier (UDID) All dsPIC33CK512MP608 family devices are individually encoded during final manufacturing with a Unique Device Identifier or UDID. The UDID cannot be erased by a bulk erase command or any other user-accessible means. This feature allows for manufacturing traceability of Microchip Technology devices in applications where this is a requirement. It may also be used by the application manufacturer for any number of things that may require unique identification, such as: - Tracking the device - Unique identifying number - · Unique security key The UDID comprises five 24-bit program words. When taken together, these fields form a unique 120-bit identifier. The UDID is stored in five read-only locations, located between 0x801200 and 0x801208 in the device configuration space. Table 4-1 lists the addresses of the identifier words and shows their contents. Table 4-1. UDID Addresses | UDID | Address | Description | |-------|----------|-------------| | UDID1 | 0x801200 | UDID Word 1 | | UDID2 | 0x801202 | UDID Word 2 | | UDID3 | 0x801204 | UDID Word 3 | | UDID4 | 0x801206 | UDID Word 4 | | UDID5 | 0x801208 | UDID Word 5 | **Memory Organization** ## 4.2 Data Address Space The dsPIC33CK512MP608 family CPU has a separate 16-bit wide data memory space. The Data Space is accessed using separate Address Generation Units (AGUs) for read and write operations. The data memory map is shown in Figure 4-5. All Effective Addresses (EAs) in the data memory space are 16 bits wide and point to bytes within the Data Space. This arrangement gives a base Data Space address range of 64 Kbytes or 32K words. The lower half of the data memory space (i.e., when EA[15] = 0) is used for implemented memory addresses, while the upper half (EA[15] = 1) is reserved for the Program Space Visibility (PSV). The dsPIC33CK512MP608 family devices implement up to 48 Kbytes of data memory. If an EA points to a location outside of this area, an all-zero word or byte is returned. #### 4.2.1 Data Memory Organization and Alignment To maintain backward compatibility with PIC® MCU devices and improve Data Space memory usage efficiency, the dsPIC33CK512MP608 family instruction set supports both word and byte operations. As a consequence of byte accessibility, all Effective Address calculations are internally scaled to step through word-aligned memory. For example, the core recognizes that Post-Modified Register Indirect Addressing mode [Ws++] results in a value of Ws + 1 for byte operations and Ws + 2 for word operations. A data byte read, reads the complete word that contains the byte, using the LSb of any EA to determine which byte to select. The selected byte is placed onto the LSB of the data path. That is, data memory and registers are organized as two parallel, byte-wide entities with shared (word) address decode, but separate write lines. Data byte writes only write to the corresponding side of the array or register that matches the byte address. All word accesses must be aligned to an even address. Misaligned word data fetches are not supported, so care must be taken when mixing byte and word operations, or translating from 8-bit MCU code. If a misaligned read or write is attempted, an address error trap is generated. If the error occurred on a read, the instruction underway is completed. If the error occurred on a write, the instruction is executed but the write does not occur. In either case, a trap is then executed, allowing the system and/or user application to examine the machine state prior to execution of the address Fault. All byte loads into any W register are loaded into the LSB; the MSB is not modified. A Sign-Extend (SE) instruction is provided to allow user applications to translate 8-bit signed data to 16-bit signed values. Alternatively, for 16-bit unsigned data, user applications can clear the MSB of any W register by executing a Zero-Extend (ZE) instruction on the appropriate address. #### 4.2.2 Near Data Space The 8-Kbyte area, between 0x0000 and 0x1FFF, is referred to as the Near Data Space. Locations in this space are directly addressable through a 13-bit absolute address field within all memory direct instructions. Additionally, the whole Data Space is addressable using MOV instructions, which support Memory Direct Addressing mode with a 16-bit address field, or by using Indirect Addressing mode using a Working register as an Address Pointer. Figure 4-5. Data Memory Map for dsPIC33CKXXXMPX0X Devices Note: Memory areas are not shown to scale. #### 4.2.3 X and Y Data Spaces The dsPIC33CK512MP608 family core has two Data Spaces, X and Y. These Data Spaces can be considered either separate (for some DSP instructions) or as one unified linear address range (for MCU instructions). The Data Spaces are accessed using two Address Generation Units (AGUs) and separate data paths. This feature allows certain instructions to concurrently fetch two words from RAM, thereby enabling efficient execution of DSP algorithms, such as Finite Impulse Response (FIR) filtering and Fast Fourier Transform (FFT). The X Data Space is used by all instructions and supports all addressing modes. X Data Space has separate read and write data buses. The X read data bus is the read data path for all instructions that view Data Space as combined X and Y address space. It is also the X data prefetch path for the dual operand DSP instructions (MAC class). The Y Data Space is used in concert with the X Data Space by the MAC class of instructions (CLR, ED, EDAC, MAC, MOVSAC, MPY, MPY. N and MSC) to provide two concurrent data read paths. Both the X and Y Data Spaces support Modulo Addressing mode for all instructions, subject to addressing mode restrictions. Bit-Reversed Addressing mode is only supported for writes to X Data Space. All data memory writes, including in DSP instructions, view Data Space as combined X and Y address space. The boundary between the X and Y Data Spaces is device-dependent and is not user-programmable. ### 4.3 BIST Overview The dsPIC33CK512MP608 family features a data memory Built-In Self-Test (BIST) that has the option to be run at start-up or run time. The memory test checks that all memory locations are functional and provides a pass/fail status of the RAM that can be used by software to take action if needed. If a failure is reported, the specific location(s) are not identified. The MBISTCON register (4.3.3 MBISTCON) contains control and status bits for BIST operation. The MBISTDONE bit (MBISTCON[7]) indicates if a BIST was run since the last Reset and the MBISTSTAT bit (MBISTCON[4]) provides the pass fail result. #### 4.3.1 BIST at Start-up The BIST can be configured to automatically run on a POR-type Reset, as shown in Figure 4-6. By default, when BISTDIS (FPOR[6]) = 1, the BIST is disabled and will not be part of device start-up. If the BISTDIS bit is cleared during device programming, the BIST will run after all Configuration registers have been loaded and before code execution begins. BIST will always run on FRC+PLL with PLL settings resulting in a 125 MHz clock rate. Figure 4-6. BIST Flowchart #### 4.3.2 BIST at Run Time The BIST can also be run at any time during code execution. Note that a BIST will corrupt all of the RAM contents, including the Stack Pointer, and requires a subsequent Reset. The system should be prepared for a Reset before a BIST is performed. The BIST is invoked by setting the MBISTEN bit (MBISTCON[0]). The MBISTCON register is protected against accidental writes and requires an unlock sequence prior to writing. Only one bit can be set per unlock sequence. The procedure for a run-time BIST is as follows: - 1. Execute the unlock sequence by consecutively writing 0x55 and 0xAA to the NVMKEY register. - 2. Write 0x0001 to the MBISTCON SFR. - 3. Execute a Software Reset command. - 4. Verify a Software Reset has occurred by reading SWR (RCON[6]) (optional). - 5. Verify that the MBISTDONE bit is set. - 6. Take action depending on test result indicated by MBISTSTAT. **Memory Organization** ### 4.3.2.1 Fault Simulation A mechanism is available to simulate a BIST failure to allow testing of Fault handling software. When the FLTINJ bit is set during a run-time BIST, the MBISTSTAT bit will be set regardless of the test result. The procedure for a BIST Fault simulation is as follows: - 1. Execute the unlock sequence by consecutively writing 0x55 and 0xAA to the NVMKEY register. - 2. Set the MBISTEN bit (MBISTCON[0]). - 3. Execute 2nd unlock sequence by consecutively writing 0x55 and 0xAA to the NVMKEY register. - Set the FLTINJ bit (MBISTCON[8]). - 5. Execute a Software Reset command. - 6. Verify a Software Reset has occurred by reading SWR (RCON[6]) (optional). - 7. Verify the MBISTDONE, MBSITSTAT and FLTINJ bits are all set. ### 4.3.3 MBIST Control Register Name: MBISTCON Offset: 0EFC #### Notes: - 1. Resets only on a true POR Reset. - 2. This bit will self-clear when the MBIST test is complete. Legend: HS = Hardware Settable bit; HC = Hardware Clearable bit ## Bit 8 - FLTINJ MBIST Fault Inject Control bit(1) | Value | Description | |-------|--------------------------------------------------------------------------------------| | 1 | The MBIST test will complete and sets MBISTSTAT = 1, simulating an SRAM test failure | | 0 | The MBIST test will execute normally | #### Bit 7 - MBISTDONE MBIST Done Status bit | Value | Description | |-------|------------------------------------------------------------| | 1 | An MBIST operation has been executed | | 0 | No MBIST operation has occurred on the last Reset sequence | #### Bit 4 - MBISTSTAT MBIST Status bit | Value | Description | |-------|------------------------------------------------------------| | 1 | The last MBIST failed | | 0 | The last MBIST passed; all memory may not have been tested | #### Bit 0 - MBISTEN MBIST Enable bit(2) | Value | Description | |-------|--------------------------------------------------------------------------| | 1 | MBIST test is armed; an MBIST test will execute at the next device Reset | | 0 | MBIST test is disarmed | ## 4.4 Memory Resources Many useful resources are provided on the main product page of the Microchip website for the devices listed in this data sheet. This product page contains the latest updates and additional information. ### 4.4.1 Paged Memory Scheme The dsPIC33CK512MP608 architecture extends the available Data Space through a paging scheme, which allows the available Data Space to be accessed using MOV instructions in a linear fashion for pre- and post-modified Effective Addresses (EAs). The upper half of the base Data Space address is used in conjunction with the Data Space Read Page (DSRPAG) register to form the Program Space Visibility (PSV) address. The Data Space Read Page (DSRPAG) register is located in the SFR space. When DSRPAG[9] = 1 and the base address bit, EA[15] = 1, the DSRPAG[8:0] bits are concatenated onto EA[14:0] to form the 24-bit PSV read address. ## **Memory Organization** The paged memory scheme provides access to multiple 32-Kbyte windows in the PSV memory. The Data Space Read Page (DSRPAG) register, in combination with the upper half of the Data Space address, can provide up to 8 Mbytes of PSV address space. The paged data memory space is shown in Figure 4-8. The Program Space (PS) can be accessed with a DSRPAG of 0x200 or greater. Only reads from PS are supported using the DSRPAG. Figure 4-7. Program Space Visibility (PSV) Read Address Generation **Note:** DS read access when DSRPAG = 0x000 will force an address error trap. Figure 4-8. Paged Data Memory Space When a PSV page overflow or underflow occurs, EA[15] is cleared as a result of the register indirect EA calculation. An overflow or underflow of the EA in the PSV pages can occur at the page boundaries when: - · The initial address, prior to modification, addresses the PSV page - The EA calculation uses Pre- or Post-Modified Register Indirect Addressing; however, this does not include Register Offset Addressing In general, when an overflow is detected, the DSRPAG register is incremented and the EA[15] bit is set to keep the base address within the PSV window. When an underflow is detected, the DSRPAG register is decremented and the EA[15] bit is set to keep the base address within the PSV window. This creates a linear PSV address space, but only when using Register Indirect Addressing modes. Exceptions to the operation described above arise when entering and exiting the boundaries of Page 0 and PSV spaces. Table 4-2 lists the effects of overflow and underflow scenarios at different boundaries. In the following cases, when overflow or underflow occurs, the EA[15] bit is set and the DSRPAG is not modified; therefore, the EA will wrap to the beginning of the current page: - · Register Indirect with Register Offset Addressing - Modulo Addressing - Bit-Reversed Addressing Table 4-2. Overflow and Underflow Scenarios at Page 0 and PSV Space Boundaries (2,3,4) | | | | Before | | After | | | | |------------|--------------|-------------------|--------------|------------------------|-------------------|--------------|-----------------------|--| | O/U, R/W | Operation | DSRPAG | DS<br>EA[15] | Page Description | DSRPAG | DS<br>EA[15] | Page Description | | | O,<br>Read | [++Wn]<br>or | DSRPAG =<br>0x2FF | 1 | PSV: Last Isw<br>page | DSRPAG =<br>0x300 | 1 | PSV: First MSB page | | | O,<br>Read | [Wn++] | DSRPAG =<br>0x3FF | 1 | PSV: Last MSB page | DSRPAG =<br>0x3FF | 0 | See Note 1 | | | U,<br>Read | [Wn] | DSRPAG =<br>0x001 | 1 | PSV page | DSRPAG =<br>0x001 | 0 | See Note 1 | | | U,<br>Read | [Wn] | DSRPAG = 0x200 | 1 | PSV: First Isw<br>page | DSRPAG =<br>0x200 | 0 | See Note 1 | | | U,<br>Read | | DSRPAG =<br>0x300 | 1 | PSV: First MSB page | DSRPAG =<br>0x2FF | 1 | PSV: Last Isw<br>page | | Legend: O = Overflow, U = Underflow, R = Read, W = Write #### Notes: - 1. The Register Indirect Addressing now addresses a location in the base Data Space (0x0000-0x8000). - 2. An EDS access, with DSRPAG = 0x000, will generate an address error trap. - 3. Only reads from PS are supported using DSRPAG. - 4. Pseudolinear Addressing is not supported for large offsets. #### 4.4.1.1 Extended X Data Space The lower portion of the base address space range, between 0x0000 and 0x7FFF, is always accessible, regardless of the contents of the Data Space Read Page register. It is indirectly addressable through the register indirect instructions. It can be regarded as being located in the default EDS Page 0 (i.e., EDS address range of 0x0000000 to 0x007FFF with the base address bit, EA[15] = 0, for this address range). However, Page 0 cannot be accessed through the upper 32 Kbytes, 0x8000 to 0xFFFF, of base Data Space in combination with DSRPAG = 0x00. Consequently, DSRPAG is initialized to 0x001 at Reset. #### Notes: - 1. DSRPAG should not be used to access Page 0. An EDS access with DSRPAG set to 0x000 will generate an address error trap. - 2. Clearing the DSRPAG in software has no effect. The remaining PSV pages are only accessible using the DSRPAG register in combination with the upper 32 Kbytes, 0x8000 to 0xFFFF, of the base address, where the base address bit, EA[15] = 1. #### 4.4.1.2 Software Stack The W15 register serves as a dedicated Software Stack Pointer (SSP), and is automatically modified by exception processing, subroutine calls and returns; however, W15 can be referenced by any instruction in the same manner as all other W registers. This simplifies reading, writing and manipulating the Stack Pointer (for example, creating stack frames). Note: To protect against misaligned stack accesses, W15[0] is fixed to '0' by the hardware. W15 is initialized to 0x1000 during all Resets. This address ensures that the SSP points to valid RAM in all dsPIC33CK512MP608 devices and permits stack availability for non-maskable trap exceptions. These can occur before the SSP is initialized by the user software. You can reprogram the SSP during initialization to any location within Data Space. The Software Stack Pointer always points to the first available free word and fills the software stack, working from lower toward higher addresses. Figure 4-9 illustrates how it pre-decrements for a stack pop (read) and post-increments for a stack push (writes). When the PC is pushed onto the stack, PC[15:0] are pushed onto the first available stack word, then PC[22:16] are pushed into the second available stack location. For a PC push during any CALL instruction, the MSB of the PC is zero-extended before the push, as shown in Figure 4-9. During exception processing, the MSB of the PC is concatenated with the lower eight bits of the CPU STATUS Register, SR. This allows the contents of SRL to be preserved automatically during interrupt processing. #### Notes: - To maintain system Stack Pointer (W15) coherency, W15 is never subject to (EDS) paging, and is therefore, restricted to an address range of 0x0000 to 0xFFFF. The same applies to the W14 when used as a Stack Frame Pointer (SFA = 1). - As the stack can be placed in, and can access X and Y spaces, care must be taken regarding its use, particularly with regard to local automatic variables in a C development environment. Figure 4-9. CALL Stack Frame ## 4.4.2 Instruction Addressing Modes The addressing modes shown in Table 4-3 form the basis of the addressing modes optimized to support the specific features of individual instructions. The addressing modes provided in the MAC class of instructions differ from those in the other instruction types. Table 4-3. Fundamental Addressing Modes Supported | Addressing Mode | Description | |-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------| | File Register Direct | The address of the file register is specified explicitly. | | Register Direct | The contents of a register are accessed directly. | | Register Indirect | The contents of Wn form the Effective Address (EA). | | Register Indirect Post-Modified | The contents of Wn form the EA. Wn is post-modified (incremented or decremented) by a constant value. | | Register Indirect Pre-Modified | Wn is pre-modified (incremented or decremented) by a signed constant value to form the EA. | | Register Indirect with Register Offset (Register Indexed) | The sum of Wn and Wb forms the EA. | | Register Indirect with Literal Offset | The sum of Wn and a literal forms the EA. | #### 4.4.2.1 File Registration Instructions Most file register instructions use a 13-bit address field (f) to directly address data present in the first 8192 bytes of data memory (Near Data Space). Most file register instructions employ a Working register, W0, which is denoted as WREG in these instructions. The destination is typically either the same file register or WREG (with the exception **Memory Organization** of the MUL instruction), which writes the result to a register or register pair. The MOV instruction allows additional flexibility and can access the entire Data Space. #### 4.4.2.2 MCU Instructions The three-operand MCU instructions are of the form: Operand 3 = Operand 1 [function] Operand 2 where Operand 1 is always a Working register (that is, the addressing mode can only be Register Direct), which is referred to as Wb. Operand 2 can be a W register fetched from data memory or a 5-bit literal. The result location can either be a W register or a data memory location. The following addressing modes are supported by MCU instructions: - · Register Direct - Register Indirect - · Register Indirect Post-Modified - · Register Indirect Pre-Modified - 5-Bit or 10-Bit Literal **Note:** Not all instructions support all the addressing modes given above. Individual instructions can support different subsets of these addressing modes. #### 4.4.2.3 Move and Accumulator Instructions Move instructions, and the DSP accumulator class of instructions, provide a greater degree of addressing flexibility than other instructions. In addition to the addressing modes supported by most MCU instructions, move and accumulator instructions also support Register Indirect with Register Offset Addressing mode, also referred to as Register Indexed mode. **Note:** For the MOV instructions, the addressing mode specified in the instruction can differ for the source and destination EA. However, the 4-bit Wb (Register Offset) field is shared by both source and destination (but typically only used by one). In summary, the following addressing modes are supported by move and accumulator instructions: - · Register Direct - Register Indirect - Register Indirect Post-Modified - · Register Indirect Pre-Modified - · Register Indirect with Register Offset (Indexed) - · Register Indirect with Literal Offset - 8-Bit Literal - 16-Bit Literal **Note:** Not all instructions support all the addressing modes given above. Individual instructions may support different subsets of these addressing modes. #### 4.4.2.4 MAC Instructions The dual source operand DSP instructions (CLR, ED, EDAC, MAC, MPY, MPY.N, MOVSAC and MSC), also referred to as MAC instructions, use a simplified set of addressing modes to allow the user application to effectively manipulate the Data Pointers through register indirect tables. The two-source operand prefetch registers must be members of the set {W8, W9, W10, W11}. For data reads, W8 and W9 are always directed to the X RAGU, and W10 and W11 are always directed to the Y AGU. The Effective Addresses generated (before and after modification) must therefore, be valid addresses within X Data Space for W8 and W9, and Y Data Space for W10 and W11. **Datasheet** **Note:** Register Indirect with Register Offset Addressing mode is available only for W9 (in X space) and W11 (in Y space). **Memory Organization** In summary, the following addressing modes are supported by the MAC class of instructions: - Register Indirect - · Register Indirect Post-Modified by 2 - Register Indirect Post-Modified by 4 - · Register Indirect Post-Modified by 6 - Register Indirect with Register Offset (Indexed) #### 4.4.2.5 Other Instructions Besides the addressing modes outlined previously, some instructions use literal constants of various sizes. For example, BRA (branch) instructions use 16-bit signed literals to specify the branch destination directly, whereas the DISI instruction uses a 14-bit unsigned literal field. In some instructions, such as ULNK, the source of an operand or result is implied by the opcode itself. Certain operations, such as a NOP, do not have any operands. #### 4.4.3 Modulo Addressing Modulo Addressing mode is a method of providing an automated means to support circular data buffers using hardware. The objective is to remove the need for software to perform data address boundary checks when executing tightly looped code, as is typical in many DSP algorithms. Modulo Addressing can operate in either Data or Program Space (since the Data Pointer mechanism is essentially the same for both). One circular buffer can be supported in each of the X (which also provides the pointers into Program Space) and Y Data Spaces. Modulo Addressing can operate on any W Register Pointer. However, it is not advisable to use W14 or W15 for Modulo Addressing since these two registers are used as the Stack Frame Pointer and Stack Pointer, respectively. In general, any particular circular buffer can be configured to operate in only one direction, as there are certain restrictions on the buffer start address (for incrementing buffers) or end address (for decrementing buffers), based upon the direction of the buffer. The only exception to the usage restrictions is for buffers that have a power-of-two length. As these buffers satisfy the start and end address criteria, they can operate in a Bidirectional mode (that is, address boundary checks are performed on both the lower and upper address boundaries). #### 4.4.3.1 Start and End Address The Modulo Addressing scheme requires that a starting and ending address be specified and loaded into the 16-bit Modulo Buffer Address registers: XMODSRT, XMODEND, YMODSRT and YMODEND. Note: Y space Modulo Addressing EA calculations assume word-sized data (LSb of every EA is always clear). The length of a circular buffer is not directly specified. It is determined by the difference between the corresponding start and end addresses. The maximum possible length of the circular buffer is 32K words (64 Kbytes). #### 4.4.3.2 W Address Register Selection The Modulo and Bit-Reversed Addressing Control register, MODCON[15:0], contains enable flags, as well as a W register field to specify the W Address registers. The XWM and YWM fields select the registers that operate with Modulo Addressing: - If XWM = 1111, X RAGU and X WAGU Modulo Addressing is disabled - If YWM = 1111, Y AGU Modulo Addressing is disabled The X Address Space Pointer W (XWM) register, to which Modulo Addressing is to be applied, is stored in MODCON[3:0]. Modulo Addressing is enabled for X Data Space when XWM is set to any value other than '1111' and the XMODEN bit is set (MODCON[15]). The Y Address Space Pointer W (YWM) register, to which Modulo Addressing is to be applied, is stored in MODCON[7:4]. Modulo Addressing is enabled for Y Data Space when YWM is set to any value other than '1111' and the YMODEN bit (MODCON[14]) is set. Figure 4-10. Modulo Addressing Operation Example ### 4.4.4 Bit-Reversed Addressing Bit-Reversed Addressing mode is intended to simplify data reordering for radix-2 FFT algorithms. It is supported by the X AGU for data writes only. The modifier, which can be a constant value or register contents, is regarded as having its bit order reversed. The address source and destination are kept in normal order. Thus, the only operand requiring reversal is the modifier. #### 4.4.4.1 Bit-Reversed Addressing Implementation Bit-Reversed Addressing mode is enabled in any of these situations: - BWMx bits (W register selection) in the MODCON register are any value other than '1111' (the stack cannot be accessed using Bit-Reversed Addressing) - The BREN bit is set in the XBREV register - · The addressing mode used is Register Indirect with Pre-Increment or Post-Increment If the length of a bit-reversed buffer is $M = 2^N$ bytes, the last 'N' bits of the data buffer start address must be zeros. The XB[14:0] bits are the Bit-Reversed Addressing modifier, or 'pivot point', which is typically a constant. In the case of an FFT computation, its value is equal to half of the FFT data buffer size. **Note:** All bit-reversed EA calculations assume word-sized data (LSb of every EA is always clear). The XB value is scaled accordingly to generate compatible (byte) addresses. When enabled, Bit-Reversed Addressing is executed only for Register Indirect with Pre-Increment or Post-Increment Addressing and word-sized data writes. It does not function for any other addressing mode or for byte-sized data and normal addresses are generated instead. When Bit-Reversed Addressing is active, the W Address Pointer is always added to the address modifier (XB) and the offset associated with the Register Indirect Addressing mode is ignored. In addition, as word-sized data is a requirement, the LSb of the EA is ignored (and always clear). **Note:** Modulo Addressing and Bit-Reversed Addressing can be enabled simultaneously using the same W register, but Bit-Reversed Addressing operation will always take precedence for data writes when enabled. If Bit-Reversed Addressing has already been enabled by setting the BREN (XBREV[15]) bit, a write to the XBREV register should not be immediately followed by an indirect read operation using the W register that has been designated as the Bit-Reversed Pointer. Figure 4-11. Bit-Reversed Addressing Example Table 4-4. Bit-Reversed Addressing Sequence (16-Entry) | | | Norma | l Address | 5 | | E | Bit-Rever | sed Addr | ess | |----|----|-------|-----------|---------|----|----|-----------|----------|---------| | А3 | A2 | A1 | A0 | Decimal | A3 | A2 | A1 | A0 | Decimal | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 8 | | 0 | 0 | 1 | 0 | 2 | 0 | 1 | 0 | 0 | 4 | | 0 | 0 | 1 | 1 | 3 | 1 | 1 | 0 | 0 | 12 | | 0 | 1 | 0 | 0 | 4 | 0 | 0 | 1 | 0 | 2 | | 0 | 1 | 0 | 1 | 5 | 1 | 0 | 1 | 0 | 10 | | 0 | 1 | 1 | 0 | 6 | 0 | 1 | 1 | 0 | 6 | | 0 | 1 | 1 | 1 | 7 | 1 | 1 | 1 | 0 | 14 | | 1 | 0 | 0 | 0 | 8 | 0 | 0 | 0 | 1 | 1 | | 1 | 0 | 0 | 1 | 9 | 1 | 0 | 0 | 1 | 9 | | 1 | 0 | 1 | 0 | 10 | 0 | 1 | 0 | 1 | 5 | | 1 | 0 | 1 | 1 | 11 | 1 | 1 | 0 | 1 | 13 | | 1 | 1 | 0 | 0 | 12 | 0 | 0 | 1 | 1 | 3 | | 1 | 1 | 0 | 1 | 13 | 1 | 0 | 1 | 1 | 11 | | 1 | 1 | 1 | 0 | 14 | 0 | 1 | 1 | 1 | 7 | | 1 | 1 | 1 | 1 | 15 | 1 | 1 | 1 | 1 | 15 | ## 4.4.5 Interfacing Program and Data Memory Spaces The dsPIC33CK512MP608 family architecture uses a 24-bit wide Program Space (PS) and a 16-bit wide Data Space (DS). The architecture is also a modified Harvard scheme, meaning that data can also be present in the Program Space. To use this data successfully, it must be accessed in a way that preserves the alignment of information in both spaces. Aside from normal execution, the architecture of the dsPIC33CK512MP608 family devices provides two methods by which Program Space can be accessed during operation: - Using table instructions to access individual bytes or words anywhere in the Program Space - Remapping a portion of the Program Space into the Data Space (Program Space Visibility) Table instructions allow an application to read or write to small areas of the program memory. This capability makes the method ideal for accessing data tables that need to be updated periodically. It also allows access to all bytes of the program word. The remapping method allows an application to access a large block of data on a read-only basis, which is ideal for look-ups from a large table of static data. The application can only access the least significant word of the program word. Table 4-5. Program Space Address Construction | Access Type | Access | Program Space Address | | | | | | |------------------------|---------------|-------------------------------|------------|------|--------|-----|--| | Access Type | Space | [23] | [22:16] | [15] | [14:1] | [0] | | | Instruction Access | User | 0 | 0 PC[22:1] | | | | | | (Code Execution) | | 0xxx xxxx xxxx xxxx xxxx xxx0 | | | | | | | TBLRD/TBLWT | User | TBLPAG[7:0] Data EA[15:0] | | | | | | | (Byte/Word Read/Write) | | 0xxx xxxx xxxx xxxx xxxx xxxx | | | | | | | | Configuration | TBLPAG[7:0] Data EA[15:0] | | | | | | | | | 1xxx xxxx xxxx xxxx xxxx xxxx | | | | | | Figure 4-12. Data Access from Program Space Address Generation - **Note 1:** The Least Significant bit (LSb) of Program Space addresses is always fixed as '0' to maintain word alignment of data in the Program and Data Spaces. - **2:** Table operations are not required to be word-aligned. Table Read operations are permitted in the configuration memory space. #### 4.4.5.1 Data Access from Program Memory Using Table Instructions The TBLRDL and TBLWTL instructions offer a direct method of reading or writing the lower word of any address within the Program Space without going through Data Space. The TBLRDH and TBLWTH instructions are the only method to read or write the upper eight bits of a Program Space word as data. The PC is incremented by two for each successive 24-bit program word. This allows program memory addresses to directly map to Data Space addresses. Program memory can thus be regarded as two 16-bit wide word address spaces, residing side by side, each with the same address range. TBLRDL and TBLWTL access the space that contains the least significant data word. TBLRDH and TBLWTH access the space that contains the upper data byte. Two table instructions are provided to move byte or word-sized (16-bit) data to and from Program Space. Both function as either byte or word operations. - TBLRDL (Table Read Low): - In Word mode, this instruction maps the lower word of the Program Space location (P[15:0]) to a data address (D[15:0]). - In Byte mode, either the upper or lower byte of the lower program word is mapped to the lower byte of a data address. The upper byte is selected when Byte Select is '1'; the lower byte is selected when it is '0'. - TBLRDH (Table Read High): - In Word mode, this instruction maps the entire upper word of a program address (P[23:16]) to a data address. The 'phantom' byte (D[15:8]) is always '0'. - In Byte mode, this instruction maps the upper or lower byte of the program word to D[7:0] of the data address in the TBLRDL instruction. The data are always '0' when the upper 'phantom' byte is selected (Byte Select = 1). In a similar fashion, two table instructions, TBLWTH and TBLWTL, are used to write individual bytes or words to a Program Space address. The details of their operation are explained in 5. Flash Program Memory. For all table operations, the area of program memory space to be accessed is determined by the Table Page register (TBLPAG). TBLPAG covers the entire program memory space of the device, including user application and configuration spaces. When TBLPAG[7] = 0, the table page is located in the user memory space. When TBLPAG[7] = 1, the page is located in configuration space. Figure 4-13. Accessing Program Memory with Table Instructions **Flash Program Memory** ## 5. Flash Program Memory **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**Dual Partition Flash Program Memory**" (www.microchip.com/DS70005156) in the "dsPIC33/PIC24 Family Reference Manual". Some registers and associated bits described in this section may not be available on all devices. The dsPIC33CK512MP608 family devices contain internal Flash program memory for storing and executing application code. The memory is readable, writable and erasable during normal operation over the entire V<sub>DD</sub> range. Flash memory can be programmed in three ways: - In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) programming capability - Enhanced In-Circuit Serial Programming (Enhanced ICSP) - Run-Time Self-Programming (RTSP) ICSP allows for a dsPIC33CK512MP608 family device to be serially programmed while in the end application circuit. This is done with a Programming Clock and Programming Data (PGCx/PGDx) line, and three other lines for power ( $V_{DD}$ ), ground ( $V_{SS}$ ) and Master Clear ( $\overline{MCLR}$ ). This allows customers to manufacture boards with unprogrammed devices and then program the device just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed. Enhanced In-Circuit Serial Programming uses an on-board bootloader, known as the Program Executive, to manage the programming process. Using an SPI data frame format, the Program Executive can erase, program and verify program memory. For more information on Enhanced ICSP, see the device programming specification. RTSP allows the Flash user application code to update itself during run time. The feature is capable of writing a single program memory word (two instructions) or an entire row as needed. ## 5.1 Table Instructions and Flash Programming Regardless of the method used, all programming of Flash memory is done with the Table Read and Table Write instructions. These allow direct read and write access to the program memory space from the data memory while the device is in normal operating mode. The 24-bit target address in the program memory is formed using bits[7:0] of the TBLPAG register and the Effective Address (EA) from a W register, specified in the table instruction, as shown in Figure 5-1. The TBLRDL and TBLWTL instructions are used to read or write to bits[15:0] of program memory. TBLRDL and TBLWTL can access program memory in both Word and Byte modes. The TBLRDH and TBLWTH instructions are used to read or write to bits[23:16] of program memory. TBLRDH and TBLWTH can also access program memory in Word or Byte mode. Figure 5-1. Addressing for Table Registers ## 5.2 RTSP Operation RTSP allows the user application to program one double instruction word or one row at a time. The double instruction word write blocks and single row write blocks are edge-aligned, from the beginning of program memory, on boundaries of one double instruction word and 64 double instruction words, respectively. The basic sequence for RTSP programming is to first load two 24-bit instructions into the NVM write latches found in configuration memory space. Then, the WR bit in the NVMCON register is set to initiate the write process. The processor stalls (waits) until the programming operation is finished. The WR bit is automatically cleared when the operation is finished. Double instruction word writes are performed by manually loading both write latches, using $\mathtt{TBLWTL}$ and $\mathtt{TBLWTH}$ instructions, and then initiating the NVM write while the NVMOPx bits are set to ' $\mathtt{0x1}$ '. The program space destination address is defined by the NVMADR/U registers. Row programming is performed by first loading 128 instructions into data RAM and then loading the address of the first instruction in that row into the NVMSRCADRL/H registers. Once the write has been initiated, the device will automatically load two instructions into the write latches and write them to the program space destination address defined by the NVMADR/U registers. The operation will increment the NVMSRCADRL/H and the NVMADR/U registers until all double instruction words have been programmed. The RPDF bit (NVMCON[9]) selects the format of the stored data in RAM to be either compressed or uncompressed. See Figure 5-2 for data formatting. Compressed data help to reduce the amount of required RAM by using the upper byte of the second word for the MSB of the second instruction. All erase and program operations may optionally use the NVM interrupt to signal the successful completion of the operation. Figure 5-2. Uncompressed/Compressed Format #### UNCOMPRESSED FORMAT (RPDF = 0) ### COMPRESSED FORMAT (RPDF = 1) ## Example 5-1. Flash Write/Read ``` NVMCON = 0x4001; TBLPAG = 0xFA; // write latch upper address NVMADR = 0x0000; // set target write address of general segment NVMADRU = 0x0001; builtin tblwtl(0, 0x3456); // load write latches __builtin_tblwth (0,0x12); builtin tblwtl(2, 0x3456); builtin tblwth (2,0x12); asm volatile ("disi #5"); // load write latches _builtin_write_NVM(); while(_WR == 1 ) ; TBLPAG = 0x0001; readDataL = __builtin_tblrdl(0x0000); readDataH = __builtin_tblrdh(0x0000); ``` ## 5.3 Error Correcting Code (ECC) In order to improve program memory performance and durability, the devices include Error Correcting Code functionality (ECC) as an integral part of the Flash memory controller. ECC can determine the presence of single bit errors in program data, including which bit is in error, and correct the data automatically without user intervention. ECC cannot be disabled. When data are written to program memory, ECC generates a 7-bit Hamming code parity value for every two (24-bit) instruction words. The data are stored in blocks of 48 data bits and seven parity bits; parity data are not memory-mapped and are inaccessible. When the data are read back, the ECC calculates the parity on them and compares it to the previously stored parity value. If a parity mismatch occurs, there are two possible outcomes: - · Single bit error has occurred and has been automatically corrected on read-back. - · Double-bit error has occurred and the read data are not changed. Single bit error occurrence can be identified by the state of the ECCSBEIF (IFS0[13]) bit. An interrupt can be generated when the corresponding interrupt enable bit is set, ECCSBEIE (IEC0[13]). The ECCSTATL register contains the parity information for single bit errors. The SECOUT[7:0] bit field contains the expected calculated SEC parity and SECIN[7:0] bits contain the actual value from a Flash read operation. The SECSYNDx bits (ECCSTATH[7:0]) indicate the bit position of the single bit error within the 48-bit pair of instruction words. When no error is present, SECINx equals SECOUTx and SECSYNDx is zero. Double-bit errors result in a generic hard trap. The ECCDBE bit (INTCON4[1]) will be set to identify the source of the hard trap. If no Interrupt Service Routine is implemented for the hard trap, a device Reset will also occur. The ECCSTATH register contains double-bit error status information. The DEDOUT bit is the expected calculated DED parity and DEDIN is the actual value from a Flash read operation. When no error is present, DEDIN equals DEDOUT. ## 5.4 ECC Fault Injection To test Fault handling, an EEC error can be generated. Both single and double-bit errors can be generated in both the read and write data paths. Read path Fault injection first reads the Flash data and then modifies them prior to entering the ECC logic. Write path Fault injection modifies the actual data prior to them being written into the target Flash and will cause an EEC error on a subsequent Flash read. The following procedure is used to inject a Fault: - Load the Flash target address into the ECCADDR register. - 2. Select 1st Fault bit determined by FLT1PTRx (ECCCONH[7:0]). The target bit is inverted to create the Fault. - 3. If a double Fault is desired, select the 2nd Fault bit determined by FLT2PTRx (ECCCONH[15:8]); otherwise, set to all '1's. - 4. Write 0x55 to NVMKEY. - 5. Write 0xAA to NVMKEY. - 6. Set the FLTINJ bit (ECCCONL[0]) in a single operation to enable the ECC Fault injection logic. - 7. Perform a read or write to the Flash target address. ## 5.5 Flash OTP by ICSP™ Write Inhibit ICSP Write Inhibit is an access restriction feature, that when activated, restricts all of Flash memory. Once activated, ICSP Write Inhibit permanently prevents ICSP Flash programming and erase operations, and cannot be deactivated. This feature is intended to prevent alteration of Flash memory contents, with behavior similar to One-Time-Programmable (OTP) devices. RTSP, including erase and programming operations, is not restricted when ICSP Write Inhibit is activated; however, code to perform these actions must be programmed into the device before ICSP Write Inhibit is activated. This allows for a bootloader-type application to alter Flash contents with ICSP Write Inhibit activated. Entry into ICSP and Enhanced ICSP modes is not affected by ICSP Write Inhibit. In these modes, it will continue to be possible to read configuration memory space and any user memory space regions which are not code-protected. With ICSP writes inhibited, an attempt to set WR (NVMCON[15]) = 1 will maintain WR = 0, and instead, set WRERR (NVMCON[13]) = 1. All Enhanced ICSP erase and programming commands will have no effect with self-checked **Flash Program Memory** programming commands returning a FAIL response opcode (PASS if the destination already exactly matched the requested programming data). Once ICSP Write Inhibit is activated, it is not possible for a device executing in Debug mode to erase/write Flash, nor can a debug tool switch the device to Production mode. ICSP Write Inhibit should therefore only be activated on devices programmed for production. ### 5.6 Dual Partition Flash Configuration For dsPIC33CK512MP608 devices operating in Dual Partition Flash Program Memory modes, the Inactive Partition can be erased and programmed without stalling the processor. The same programming algorithms are used for programming and erasing the Flash in the Inactive Partition, as described in 5.2 RTSP Operation. On top of the page erase option, the entire Flash memory of the Inactive Partition can be erased by configuring the NVMOP[3:0] bits in the NVMCON register. **Note:** The application software to be loaded into the Inactive Partition will have the address of the Active Partition. The bootloader firmware will need to offset the address by 0x400000 in order to write to the Inactive Partition. #### 5.6.1 Flash Partition Swapping The Boot Sequence Number is used for determining the Active Partition at start-up and is encoded within the FBTSEQ Configuration register bits. Unlike most Configuration registers, which only utilize the lower 16 bits of the program memory, FBTSEQ is a 24-bit Configuration Word. The Boot Sequence Number (BSEQ) is a 12-bit value and is stored in FBTSEQ twice. The true value is stored in bits, FBTSEQ[11:0], and its complement is stored in bits, FBTSEQ[23:12]. At device Reset, the sequence numbers are read and the partition with the lowest sequence number becomes the Active Partition. If one of the Boot Sequence Numbers is invalid, the device will select the partition with the valid Boot Sequence Number, or default to Partition 1 if both sequence numbers are invalid. See 30. Special Features for more information. The BOOTSWP instruction provides an alternative means of swapping the Active and Inactive Partitions (soft swap) without the need for a device Reset. The BOOTSWP must always be followed by a GOTO instruction. The BOOTSWP instruction swaps the Active and Inactive Partitions, and the PC vectors to the location specified by the GOTO instruction in the newly Active Partition. It is important to note that interrupts should temporarily be disabled while performing the soft swap sequence and that after the partition swap, all peripherals and interrupts which were enabled remain enabled. Additionally, the RAM and stack will maintain state after the switch. As a result, it is recommended that applications using soft swaps jump to a routine that will reinitialize the device in order to ensure the firmware runs as expected. The Configuration registers will have no effect during a soft swap. For robustness of operation, in order to execute the BOOTSWP instruction, it is necessary to execute the NVM unlocking sequence as follows: - 1. Write 0x55 to NVMKEY. - 2. Write 0xAA to NVMKEY. - 3. Execute the BOOTSWP instruction. If the unlocking sequence is not performed, the BOOTSWP instruction will be executed as a forced NOP and a GOTO instruction, following the BOOTSWP instruction, will be executed, causing the PC to jump to that location in the current operating partition. The SFTSWP and P2ACTIV bits in the NVMCON register are used to determine a successful swap of the Active and Inactive Partitions, as well as which partition is active. After the BOOTSWP and GOTO instructions, the SFTSWP bit should be polled to verify the partition swap has occurred and then cleared for the next panel swap event. **Flash Program Memory** ### 5.6.2 Dual Partition Modes While operating in Dual Partition mode, the dsPIC33CK512MP608 family devices have the option for both partitions to have their own defined security segments, as shown in 30.10 Code Protection and CodeGuard™ Security. Alternatively, the device can operate in Protected Dual Partition mode, where Partition 1 becomes permanently erase/write-protected. Protected Dual Partition mode allows for a "Factory Default" mode, which provides a fail-safe backup image to be stored in Partition 1. dsPIC33CK512MP608 family devices can also operate in Privileged Dual Partition mode, where additional security protections are implemented to allow for protection of intellectual property when multiple parties have software within the device. In Privileged Dual Partition mode, both partitions place additional restrictions on the FBSLIM register. These prevent changes to the size of the Boot Segment and General Segment, ensuring that neither segment will be altered. Figure 5-3. Relationship Between Partitions 1/2 and Active/Inactive Partitions ## 5.7 NVM/ECC Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------------------|---------------|-------------------|----|-------------|-------|---------|------------|---------|---------|--------|--| | 0xF0 | ECCCONL | 15:8 | | | | | | | | | | | UXFU | ECCCONL | 7:0 | | | | | | | | FLTINJ | | | 0xF2 | ECCCONH | 15:8 | | | | FLT2P | TR[7:0] | | | | | | UXFZ | ECCCONH | 7:0 | | | | FLT1P | TR[7:0] | | | | | | 0xF4 | ECCADDRL | 15:8 | | | | ECCAD | DR[15:8] | | | | | | UXI 4 | LCCADDILL | 7:0 | | | | ECCAD | DR[7:0] | | | | | | 0xF6 | ECCADDRH | 15:8 | | | | | | | | | | | OXI O | LCCADDINIT | 7:0 | | | | ECCADE | DR[23:16] | | | | | | 0xF8 | ECCSTATL | 15:8 | | SECOUT[7:0] | | | | | | | | | UXI O | LCCSTATE | 7:0 | | | | SECI | N[7:0] | | | | | | 0xFA | ECCSTATH | 15:8 | | | | | | | DEDOUT | DEDIN | | | UXITA | ECCSTATH | 7:0 | | | | SECSY | ND[7:0] | | | | | | 0xFC<br><br>0x08CF | Reserved | | | | | | | | | | | | 00000 | AD MACCAL | 15:8 | WR | WREN | WRERR | NVMSIDL | SFTSWP | P2ACTIV | RPDF | URERR | | | 0x08D0 | NVMCON | 7:0 | | | | | | NVMC | DP[3:0] | | | | 0x08D2 | NVMADR | 15:8 | | | | NVMAD | DR[15:8] | | | | | | UXUODZ | INVINIADA | 7:0 | | | | NVMA | DR[7:0] | | | | | | 0x08D4 | NVMADRU | 15:8 | | | | | | | | | | | 000004 | INVINIADIO | 7:0 | | | | NVMADE | RU[23:16] | | | | | | 0x08D6 | NVMKEY | 15 <sup>.</sup> 8 | | | | | | | | | | | OXOODO | INVIVINCE | 7:0 | | | | NVMK | EY[7:0] | | | | | | 0x08D8 | NVMSRCADRL | 15:8 | | | | NVMSRC | ADR[15:8] | | | | | | 0,00000 | INVIVIONOMURE | 7:0 | | | | NVMSRC | ADR[7:0] | | | | | | 0x08DA | NVMSRCADRH | 15:8 | | | | | | | | | | | OXUODA | INVINIORCADRE | 7:0 | | | | NVMSRC | ADR[23:16] | | | | | ## 5.7.1 Nonvolatile Memory (NVM) Control Register Name: NVMCON Offset: 0x8D0 #### Notes: - 1. These bits can only be reset on a POR. - 2. If this bit is set, there will be minimal power savings (I<sub>IDLE</sub>), and upon exiting Idle mode, there is a delay (T<sub>VREG</sub>) before Flash memory becomes operational. - 3. All other combinations of NVMOP[3:0] are unimplemented. - 4. Execution of the PWRSAV instruction is ignored while any of the NVM operations are in progress. - 5. Two adjacent words on a 4-word boundary are programmed during execution of this operation. ## Legend: C = Clearable bit; SO = Settable Only bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|------|-------|---------|--------|---------|--------|-------| | | WR | WREN | WRERR | NVMSIDL | SFTSWP | P2ACTIV | RPDF | URERR | | Access | R/SO | R/W | R/W | R/W | R/C | R | R/W | R/C | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | NVMC | P[3:0] | | | Access | | | | | R/W | R/W | R/W | R/W | | Reset | | | | | 0 | 0 | 0 | 0 | #### Bit 15 - WR Write Control bit(1) | Value | Description | |-------|---------------------------------------------------------------------------------------------------------| | 1 | Initiates a Flash memory program or erase operation; the operation is self-timed and the bit is cleared | | | by hardware once the operation is complete | | 0 | Program or erase operation is complete and inactive | ### Bit 14 - WREN Write Enable bit(1) | Value | Description | |-------|-----------------------------------------| | 1 | Enables Flash program/erase operations | | 0 | Inhibits Flash program/erase operations | ## Bit 13 - WRERR Write Sequence Error Flag bit(1) | Value | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------| | 1 | An improper program or erase sequence attempt, or termination has occurred (bit is set automatically on any set attempt of the WR bit) | | 0 | The program or erase operation completed normally | ### Bit 12 - NVMSIDL NVM Stop in Idle Control bit(2) | Value | Description | |-------|-----------------------------------------------------------------| | 1 | Flash voltage regulator goes into Standby mode during Idle mode | | 0 | Flash voltage regulator is active during Idle mode | ### Bit 11 - SFTSWP Partition Soft Swap Status bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Partitions have been successfully swapped using the BOOTSWP instruction (soft swap) | | 0 | Awaiting successful partition swap using the BOOTSWP instruction or a device Reset will determine the Active Partition based on the FBTSEQ register | #### Bit 10 - P2ACTIV Partition 2 Active Status bit | Value | Description | |-------|----------------------------------------------------| | 1 | Partition 2 Flash is mapped into the active region | ## **Flash Program Memory** | Value | Description | |-------|----------------------------------------------------| | value | Beschiption | | 0 | Partition 1 Flash is mapped into the active region | | U | Talition Trastris mapped into the active region | ## Bit 9 - RPDF Row Programming Data Format bit | Value | Description | |-------|---------------------------------------------------------| | 1 | Row data to be stored in RAM are in compressed format | | 0 | Row data to be stored in RAM are in uncompressed format | ## Bit 8 - URERR Row Programming Data Underrun Error bit | V | alue | Description | |---|------|---------------------------------------------------------| | 1 | | Indicates row programming operation has been terminated | | 0 | | No data underrun error is detected | ## Bits 3:0 – NVMOP[3:0] NVM Operation Select bits(1,3,4) | Value | Description | |-------|-------------------------------------------------| | 1111 | Reserved | | 1110 | User memory bulk erase operation | | 1101 | Reserved | | 1100 | Reserved | | 1011 | Reserved | | 1010 | Reserved | | 1001 | Reserved | | 1000 | Boot mode (FBOOT) double-word program operation | | 0111 | Reserved | | 0101 | Reserved | | 0100 | Inactive Partition memory erase operation | | 0011 | Memory page erase operation | | 0010 | Memory row program operation | | 0001 | Memory double-word operation <sup>(5)</sup> | | 0000 | Reserved | and its subsidiaries **Flash Program Memory** ## 5.7.2 Nonvolatile Memory Lower Address Register Name: NVMADR Offset: 0x8D2 **Legend:** x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|--------------|-----|-----|-------|---------|-----|-----|-----|--|--|--| | | NVMADR[15:8] | | | | | | | | | | | | Access | R/W | | | | Reset | X | X | X | X | X | X | X | X | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | NVMAI | DR[7:0] | | | | | | | | Access | R/W | | | | Reset | X | X | X | X | X | X | X | X | | | | **Bits 15:0 – NVMADR[15:0]** Nonvolatile Memory Lower Write Address bits Selects the lower 16 bits of the location to program or erase in Program Flash Memory. This register may be read or written to by the user application. **Flash Program Memory** ## 5.7.3 Nonvolatile Memory Upper Address Register Name: NVMADRU Offset: 0x8D4 **Legend:** x = Bit is unknown **Bits 7:0 – NVMADRU[23:16]** Nonvolatile Memory Upper Write Address bits Selects the upper eight bits of the location to program or erase in Program Flash Memory. This register may be read or written to by the user application. ## **Flash Program Memory** ## 5.7.4 Nonvolatile Memory Key Register Name: NVMKEY Offset: 0x8D6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-------------|----|----|----|----|----|---|---|--|--|--| | Access | | , | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | NVMKEY[7:0] | | | | | | | | | | | | Access | W | W | W | W | W | W | W | W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 7:0 - NVMKEY[7:0] NVM Key Register bits (write-only) **Flash Program Memory** ## 5.7.5 NVM Source Data Address Register Low Name: NVMSRCADRL Offset: 0x8D8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----------------|-----|-----|--------|-----------|-----|-----|-----|--|--|--| | | NVMSRCADR[15:8] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | NVMSRC | :ADR[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:0 - NVMSRCADR[15:0] NVM Source Data Address bits The RAM address of the data to be programmed into Flash when the NVMOP[3:0] bits are set to row programming. ## **Flash Program Memory** ## 5.7.6 NVM Source Data Address Register High Name: NVMSRCADRH Offset: 0x8DA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|------------------|-----|-----|-----|-----|-----|-----|-----|--|--|--| | | | | | | | | | | | | | | Access | | | | | | >- | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | NVMSRCADR[23:16] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 7:0 - NVMSRCADR[23:16] NVM Source Data Address bits The RAM address of the data to be programmed into Flash when the NVMOP[3:0] bits are set to row programming. **Flash Program Memory** ## 5.7.7 ECC Fault Injection Configuration Register Low Name: ECCCONL Offset: 0x0F0 Bit 0 - FLTINJ Fault Injection Sequence Enable bit | Value | Description | |-------|-------------| | 1 | Enabled | | 0 | Disabled | **Flash Program Memory** ## 5.7.8 ECC Fault Injection Configuration Register High Name: ECCCONH Offset: 0x0F2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|--------------|-----|-----|-----|-----|-----|-----|-----|--|--|--| | | FLT2PTR[7:0] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FLT1PTR[7:0] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 - FLT2PTR[7:0] ECC Fault Injection Bit Pointer 2 bits | Value | Description | |-------------------|-------------------------------------------------------------------| | 11111111-00111000 | No Fault injection occurs | | 00110111 | Fault injection (bit inversion) occurs on bit 55 of ECC bit order | | | | | 00000001 | Fault injection (bit inversion) occurs on bit 1 of ECC bit order | | 0000000 | Fault injection (bit inversion) occurs on bit 0 of ECC bit order | Bits 7:0 - FLT1PTR[7:0] ECC Fault Injection Bit Pointer 1 bits | Value | Description | |-------------------|---------------------------------------------------| | 11111111-00111000 | No Fault injection occurs | | 00110111 | Fault injection occurs on bit 55 of ECC bit order | | | | | 00000001 | Fault injection occurs on bit 1 of ECC bit order | | 0000000 | Fault injection occurs on bit 0 of ECC bit order | **Flash Program Memory** ## 5.7.9 ECC Fault Inject Address Compare Register Low Name: ECCADDRL Offset: 0x0F4 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|---------------|-----|-----|-------|---------|-----|-----|-----|--|--|--| | | ECCADDR[15:8] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | ECCAD | DR[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:0 - ECCADDR[15:0] ECC Fault Injection NVM Address Match Compare bits ## **Flash Program Memory** ## 5.7.10 ECC Fault Inject Address Compare Register High Name: ECCADDRH Offset: 0x00F6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--|--| | | | | | | | | | | | | | | Access | | | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | ECCADDR[23:16] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 7:0 - ECCADDR[23:16] ECC Fault Injection NVM Address Match Compare bits **Flash Program Memory** ## 5.7.11 ECC System Status Display Register Low Name: ECCSTATL Offset: 0x0F8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--|--| | | SECOUT[7:0] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | SECI | N[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 - SECOUT[7:0] Calculated Single Error Correction Parity Value bits **Bits 7:0 – SECIN[7:0]** Read Single Error Correction Parity Value bits SECIN[7:0] bits are the actual parity value of a Flash read operation. **Flash Program Memory** ## 5.7.12 ECC System Status Display Register High Name: ECCSTATH Offset: 0x00FA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|--------|-------| | | | | | | | | DEDOUT | DEDIN | | Access | | | | | | >- | R/W | R/W | | Reset | | | | | | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | SECSY | ND[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bit 9 - DEDOUT Calculated Dual Bit Error Detection Parity bit **Bit 8 – DEDIN** Read Dual Bit Error Detection Parity bit DEDIN is the actual parity value of a Flash read operation. **Bits 7:0 – SECSYND[7:0]** Calculated ECC Syndrome Value bits Indicates the bit location that contains the error. ## 6. Resets **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Reset" (www.microchip.com/DS70602) in the "dsPIC33/PIC24 Family Reference Manual". The Reset module combines all Reset sources and controls the device Reset Signal, SYSRST. The following is a list of device Reset sources: - POR: Power-on Reset - BOR: Brown-out Reset - MCLR: Master Clear Pin Reset - SWR: RESET Instruction - WDTO: Watchdog Timer Time-out Reset - · CM: Configuration Mismatch Reset - · TRAPR: Trap Conflict Reset - · IOPUWR: Illegal Condition Device Reset - Illegal Opcode Reset - Uninitialized W Register Reset - Security Reset A simplified block diagram of the Reset module is shown in Figure 6-1. Figure 6-1. Reset System Block Diagram Any active source of Reset will make the SYSRST signal active. On system Reset, some of the registers associated with the CPU and peripherals are forced to a known Reset state, and some are unaffected. Note: Refer to the specific peripheral section or 4. Memory Organization of this data sheet for register Reset states. All types of device Reset set a corresponding status bit in the RCON register to indicate the type of Reset. A POR clears all the bits, except for the BOR and POR bits (RCON[1:0]) that are set. The user application can set or clear any bit, at any time, during code execution. The RCON bits only serve as status bits. Setting a particular Reset status bit in software does not cause a device Reset to occur. The RCON register also has other bits associated with the Watchdog Timer and device power-saving states. The function of these bits is discussed in other sections of this manual. Resets **Note:** The status bits in the RCON register should be cleared after they are read so that the next RCON register value after a device Reset is meaningful. For all Resets, the default clock source is determined by the FNOSC[2:0] bits in the FOSCSEL Configuration register. The value of the FNOSCx bits is loaded into the NOSC[2:0] (OSCCON[10:8]) bits on Reset, which in turn, initializes the system clock. ## 6.1 Reset Resources Many useful resources are provided on the main product page of the Microchip website for the devices listed in this data sheet. This product page contains the latest updates and additional information. ### 6.1.1 Key Resources - "Reset" (www.microchip.com/DS70602) in the "dsPIC33/PIC24 Family Reference Manual" - Code Samples - Application Notes - · Software Libraries - Webinars - · All Related "dsPIC33/PIC24 Family Reference Manual" sections - · Development Tools ## 6.1.2 Reset Control Register Name: RCON<sup>(1)</sup> Offset: 0xF80 #### Notes: - 1. All of the Reset status bits can be set or cleared in software. Setting one of these bits in software does not cause a device Reset. - 2. If the FWDTEN Configuration bit is '1' (unprogrammed), the WDT is always enabled, regardless of the SWDTEN bit setting. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|--------|--------|------|-------|------|-----|-------| | | TRAPR | IOPUWR | | | | | CM | VREGS | | Access | R/W | R/W | | | | | R/W | R/W | | Reset | 0 | 0 | | | | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | EXTR | SWR | SWDTEN | WDTO | SLEEP | IDLE | BOR | POR | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | ### Bit 15 - TRAPR Trap Reset Flag bit | Value | Description | |-------|----------------------------------------| | 1 | A Trap Conflict Reset has occurred | | 0 | A Trap Conflict Reset has not occurred | ## Bit 14 - IOPUWR Illegal Opcode or Uninitialized W Register Access Reset Flag bit | Value | Description | | | |-------|---------------------------------------------------------------------------------------------------|--|--| | 1 | An Illegal Opcode, an Illegal Address mode or Uninitialized W Register used as an Address Pointer | | | | | caused a Reset | | | | 0 | An Illegal Opcode or Uninitialized W Register Reset has not occurred | | | ## Bit 9 - CM Configuration Mismatch Flag bit | Value | Description | |-------|-------------------------------------------------| | 1 | A Configuration Mismatch Reset has occurred | | 0 | A Configuration Mismatch Reset has not occurred | ### Bit 8 - VREGS Voltage Regulator Standby During Sleep bit | Value | Description | |-------|-------------------------------------------------------| | 1 | Voltage regulator is active during Sleep | | 0 | Voltage regulator goes into Standby mode during Sleep | ### Bit 7 - EXTR External Reset (MCLR) Pin bit | Value | Description | | |-------|---------------------------------------------|--| | 1 | A Master Clear (pin) Reset has occurred | | | 0 | A Master Clear (pin) Reset has not occurred | | ### Bit 6 - SWR Software RESET (Instruction) Flag bit | Value | Description | |-------|-------------------------------------------| | 1 | A RESET instruction has been executed | | 0 | A RESET instruction has not been executed | ### Bit 5 - SWDTEN Software Enable/Disable of WDT bit(2) | Value | Description | |-------|-----------------| | 1 | WDT is enabled | | 0 | WDT is disabled | Resets ## Bit 4 - WDTO Watchdog Timer Time-out Flag bit | Value | Description | |-------|-------------------------------| | 1 | WDT time-out has occurred | | 0 | WDT time-out has not occurred | ### Bit 3 - SLEEP Wake-up from Sleep Flag bit | Value | Description | |-------|-----------------------------------| | 1 | Device has been in Sleep mode | | 0 | Device has not been in Sleep mode | ## Bit 2 - IDLE Wake-up from Idle Flag bit | Value Description | | |-------------------|----------------------------------| | 1 | Device has been in Idle mode | | 0 | Device has not been in Idle mode | ### Bit 1 - BOR Brown-out Reset Flag bit | Value | Description | | | |-------|------------------------------------|--|--| | 1 | A Brown-out Reset has occurred | | | | 0 | A Brown-out Reset has not occurred | | | ## Bit 0 - POR Power-on Reset Flag bit | Value | Description | |-------|-----------------------------------| | 1 | A Power-on Reset has occurred | | 0 | A Power-on Reset has not occurred | **Interrupt Controller** ## 7. Interrupt Controller **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Interrupts" (www.microchip.com/DS70000600) in the "dsPIC33/PIC24 Family Reference Manual". The dsPIC33CK512MP608 family interrupt controller reduces the numerous peripheral interrupt request signals to a single interrupt request signal to the dsPIC33CK512MP608 family CPU. The interrupt controller has the following features: - · Six Processor Exceptions and Software Traps - · Seven User-Selectable Priority Levels - Interrupt Vector Table (IVT) with a Unique Vector for each Interrupt or Exception Source - · Fixed Priority within a Specified User Priority Level - · Fixed Interrupt Entry and Return Latencies - · Alternate Interrupt Vector Table (AIVT) for Debug Support ## 7.1 Interrupt Vector Table The dsPIC33CK512MP608 family Interrupt Vector Table (IVT), shown in Figure 7-1, resides in program memory, starting at location, 000004h. The IVT contains six non-maskable trap vectors and up to 246 sources of interrupts. In general, each interrupt source has its own vector. Each interrupt vector contains a 24-bit wide address. The value programmed into each interrupt vector location is the starting address of the associated Interrupt Service Routine (ISR). Figure 7-1. dsPIC33CK512MP608 Family Interrupt Vector Table (IVT)<sup>(1)</sup> #### Notes: - 1. In Dual Partition modes, each partition has a dedicated Interrupt Vector Table. - 2. See Trap Vector Details. Interrupt vectors are prioritized in terms of their natural priority. This priority is linked to their position in the vector table. Lower addresses generally have a higher natural priority. For example, the interrupt associated with Vector 0 takes priority over interrupts at any other vector address. ## 7.2 Alternate Interrupt Vector Table The Alternate Interrupt Vector Table (AIVT), shown in Figure 7-2, is available only when the Boot Segment (BS) is defined and the AIVT has been enabled. To enable the Alternate Interrupt Vector Table, the Configuration bit, AIVTDIS in the FSEC register, must be programmed and the AIVTEN bit must be set (INTCON2[8] = 1). When the AIVT is enabled, all interrupt and exception processes use the alternate vectors instead of the default vectors. The AIVT begins at the start of the last page of the Boot Segment, defined by BSLIM[12:0]. The second half of the page is no longer usable space. The Boot Segment must be at least two pages to enable the AIVT. **Note:** Although the Boot Segment must be enabled in order to enable the AIVT, application code does not need to be present inside of the Boot Segment. The AIVT (and IVT) will inherit the Boot Segment code protection. Figure 7-2. dsPIC33CK512MP608 Alternate Interrupt Vector Table<sup>(2)</sup> #### Notes: - The address depends on the size of the Boot Segment defined by BSLIM[12:0]: [(BSLIM[12:0] 1) x 0x800] + Offset. - 2. In Dual Partition modes, each partition has a dedicated Alternate Interrupt Vector Table (if enabled). - 3. See Trap Vector Details. The AIVT supports debugging by providing a means to switch between an application and a support environment without requiring the interrupt vectors to be reprogrammed. This feature also enables switching between applications for evaluation of different software algorithms at run time. ## 7.3 Reset Sequence A device Reset is not a true exception because the interrupt controller is not involved in the Reset process. The dsPIC33CK512MP608 family devices clear their registers in response to a Reset, which forces the PC to zero. The device then begins program execution at location, 0x000000. A GOTO instruction at the Reset address can redirect program execution to the appropriate start-up routine. **Note:** Any unimplemented or unused vector locations in the IVT should be programmed with the address of a default interrupt handler routine that contains a RESET instruction. Table 7-1. Trap Vector Details | Trap Description | MPLAB <sup>®</sup> XC16 | Vector# | IVT | | Trap Bit Location | | Priority | |-------------------------------------------|-------------------------|---------|----------|----------------|-------------------|-------------|----------| | Trap Description | Trap ISR Name | vector# | Address | Interrupt Flag | Туре | Enable | Priority | | Oscillator Failure | _OscillatorFail | 0 | 0x000004 | INTCON1[1] | _ | _ | 15 | | Address Error | _AddressError | 1 | 0x000006 | INTCON1[3] | _ | _ | 14 | | ECC Double-Bit<br>Error | _HardTrapError | 2 | 0x000008 | INTCON4[1] | _ | _ | 13 | | Software Generated<br>Trap | _HardTrapError | 2 | 0x000008 | INTCON4[0] | _ | INTCON2[13] | 13 | | Stack Error | _StackError | 3 | 0x00000A | INTCON1[2] | _ | _ | 12 | | Overflow<br>Accumulator A | _MathError | 4 | 0x00000C | INTCON1[4] | INTCON1[14] | INTCON1[10] | 11 | | Overflow<br>Accumulator B | _MathError | 4 | 0x00000C | INTCON1[4] | INTCON1[13] | INTCON1[9] | 11 | | Catastrophic<br>Overflow<br>Accumulator A | _MathError | 4 | 0x00000C | INTCON1[4] | INTCON1[12] | INTCON1[8] | 11 | | Catastrophic<br>Overflow<br>Accumulator B | _MathError | 4 | 0x00000C | INTCON1[4] | INTCON1[11] | INTCON1[8] | 11 | | Shift Accumulator<br>Error | _MathError | 4 | 0x00000C | INTCON1[4] | INTCON1[7] | INTCON1[8] | 11 | | Divide-by-Zero<br>Error | _MathError | 4 | 0x00000C | INTCON1[4] | INTCON1[6] | INTCON1[8] | 11 | | Reserved | _Reserved | 5 | 0x00000E | _ | _ | _ | - | | DMT Software Error | _SoftTrapError | 6 | 0x000010 | INTCON3[15] | _ | _ | 9 | | CAN Address Error | _SoftTrapError | 6 | 0x000010 | INTCON3[9] | - | _ | 6 | | NVM Address Error | _SoftTrapError | 6 | 0x000010 | INTCON3[8] | _ | _ | 9 | | DO Stack Overflow | _SoftTrapError | 6 | 0x000010 | INTCON3[4] | _ | _ | 9 | | Reserved | Reserved | 7 | 0x000012 | _ | _ | _ | _ | Table 7-2. Interrupt Vector Details | Interrupt Source | MPLAB <sup>®</sup> XC16 ISR | Voctor # | IRQ# | IVT Address | Int | errupt Bit Loc | ation | |---------------------------------------------|-----------------------------|----------|------|-------------|----------|----------------|-------------| | Interrupt Source | Name | Vector # | TRQ# | IVT Address | Flag | Enable | Priority | | External<br>Interrupt 0 | _INT0Interrupt | 8 | 0 | 0x000014 | IFS0[0] | IEC0[0] | IPC0[2:0] | | Timer1 | _T1Interrupt | 9 | 1 | 0x000016 | IFS0[1] | IEC0[1] | IPC0[6:4] | | Change Notice<br>Interrupt A | _CNAInterrupt | 10 | 2 | 0x000018 | IFS0[2] | IEC0[2] | IPC0[10:8] | | Change Notice<br>Interrupt B | _CNBInterrupt | 11 | 3 | 0x00001A | IFS0[3] | IEC0[3] | IPC0[14:12] | | DMA Channel 0 | _DMA0Interrupt | 12 | 4 | 0x00001C | IFS0[4] | IEC0[4] | IPC1[2:0] | | Reserved | Reserved | 13 | 5 | 0x00001E | _ | _ | _ | | Input Capture/<br>Output Compare 1 | _CCP1Interrupt | 14 | 6 | 0x000020 | IFS0[6] | IEC0[6] | IPC1[10:8] | | CCP1 Timer | _CCT1Interrupt | 15 | 7 | 0x000022 | IFS0[7] | IEC0[7] | IPC1[14:12] | | DMA Channel 1 | _DMA1Interrupt | 16 | 8 | 0x000024 | IFS0[8] | IEC0[8] | IPC2[2:0] | | SPI1 Receiver | _SPI1RXInterrupt | 17 | 9 | 0x000026 | IFS0[9] | IEC0[9] | IPC2[6:4] | | SPI1 Transmitter | _SPI1TXInterrupt | 18 | 10 | 0x000028 | IFS0[10] | IEC0[10] | IPC2[10:8] | | JART1 Receiver | _U1RXInterrupt | 19 | 11 | 0x00002A | IFS0[11] | IEC0[11] | IPC2[14:12] | | JART1 Transmitter | _U1TXInterrupt | 20 | 12 | 0x00002C | IFS0[12] | IEC0[12] | IPC3[2:0] | | ECC Single-Bit<br>Error | _ECCSBEInterrupt | 21 | 13 | 0x00002E | IFS0[13] | IEC0[13] | IPC3[6:4] | | NVM Write<br>Complete | _NVMInterrupt | 22 | 14 | 0x000030 | IFS0[14] | IEC0[14] | IPC3[10:8] | | External<br>Interrupt 1 | _INT1Interrupt | 23 | 15 | 0x000032 | IFS0[15] | IEC0[15] | IPC3[14:12] | | I2C1 Client Event | _SI2C1Interrupt | 24 | 16 | 0x000034 | IFS1[0] | IEC1[0] | IPC4[2:0] | | I2C1 Host Event | _MI2C1Interrupt | 25 | 17 | 0x000036 | IFS1[1] | IEC1[1] | IPC4[6:4] | | DMA Channel 2 | _DMA2Interrupt | 26 | 18 | 0x000038 | IFS1[2] | IEC1[2] | IPC4[10:8] | | Change Notice<br>Interrupt C <sup>(1)</sup> | _CNCInterrupt | 27 | 19 | 0x00003A | IFS1[3] | IEC1[3] | IPC4[14:12] | | External<br>Interrupt 2 | _INT2Interrupt | 28 | 20 | 0x00003C | IFS1[4] | IEC1[4] | IPC5[2:0] | | DMA Channel 3 | _DMA3Interrupt | 29 | 21 | 0x00003E | IFS1[5] | IEC1[5] | IPC5[6:4] | | DMA Channel 4 | _DMA4Interrupt | 30 | 22 | 0x000040 | IFS1[6] | IEC1[6] | IPC5[10:8] | | Input Capture/<br>Output Compare 2 | _CCP2Interrupt | 31 | 23 | 0x000042 | IFS1[7] | IEC1[7] | IPC5[14:12] | | CCP2 Timer | _CCT2Interrupt | 32 | 24 | 0x000044 | IFS1[8] | IEC1[8] | IPC6[2:0] | | CAN1 Combined<br>Error | _CAN1Interrupt | 33 | 25 | 0x000046 | IFS1[9] | IEC1[9] | IPC6[6:4] | | External<br>Interrupt 3 | _INT3Interrupt | 34 | 26 | 0x000048 | IFS1[10] | IEC1[10] | IPC6[10:8] | | | MPLAB <sup>®</sup> XC16 ISR | | 15.6 // | | Int | errupt Bit Loc | ation | |------------------------------------|-----------------------------|----------|---------|-------------|----------|----------------|-------------| | Interrupt Source | Name | Vector # | IRQ# | IVT Address | Flag | Enable | Priority | | U2RX – UART2<br>Receiver | _U2RXInterrupt | 35 | 27 | 0x00004A | IFS1[11] | IEC1[11] | IPC6[14:12] | | U2TX – UART2<br>Transmitter | _U2TXInterrupt | 36 | 28 | 0x00004C | IFS1[12] | IEC1[12] | IPC7[2:0] | | SPI2 Receiver | _SPI2RXInterrupt | 37 | 29 | 0x00004E | IFS1[13] | IEC1[13] | IPC7[6:4] | | SPI2 Transmitter | _SPI2TXInterrupt | 38 | 30 | 0x000050 | IFS1[14] | IEC1[14] | IPC7[10:8] | | CAN1 RX Data<br>Ready <b>(2)</b> | _C1RXInterrupt | 39 | 31 | 0x000052 | IFS1[15] | IEC1[15] | IPC7[14:12] | | CAN2 RX Data<br>Ready <b>(2)</b> | _C2RXInterrupt | 40 | 32 | 0x000054 | IFS2[0] | IEC2[0] | IPC8[2:0] | | CAN2 Combined<br>Error | _CAN2Interrupt | 41 | 33 | 0x000056 | IFS2[1] | IEC2[1] | IPC8[6:4] | | DMA Channel 5 | _DMA5Interrupt | 42 | 34 | 0x000058 | IFS2[2] | IEC2[2] | IPC8[10:8] | | Input Capture/<br>Output Compare 3 | _CCP3Interrupt | 43 | 35 | 0x00005A | IFS2[3] | IEC2[3] | IPC8[14:12 | | CCP3 Timer | _CCT3Interrupt | 44 | 36 | 0x00005C | IFS2[4] | IEC2[4] | IPC9[2:0] | | I2C2 Client Event | _SI2C2Interrupt | 45 | 37 | 0x00005E | IFS2[5] | IEC2[5] | IPC9[6:4] | | I2C2 Host Event | _MI2C2Interrupt | 46 | 38 | 0x000060 | IFS2[6] | IEC2[6] | IPC9[10:8] | | Reserved | Reserved | 47 | 39 | 0x000062 | _ | _ | _ | | Input Capture/<br>Output Compare 4 | _CCP4Interrupt | 48 | 40 | 0x000064 | IFS2[8] | IEC2[8] | IPC10[2:0] | | CCP4 Timer | _CCT4Interrupt | 49 | 41 | 0x000066 | IFS2[9] | IEC2[9] | IPC10[6:4] | | Reserved | Reserved | 50 | 42 | 0x000068 | _ | _ | _ | | Input Capture/<br>Output Compare 5 | _CCP5Interrupt | 51 | 43 | 0x00006A | IFS2[11] | IEC2[11] | IPC10[14:12 | | CCP5 Timer | _CCT5Interrupt | 52 | 44 | 0x00006C | IFS2[12] | IEC2[12] | IPC11[2:0] | | Deadman Timer | _DMTInterrupt | 53 | 45 | 0x00006E | IFS2[13] | IEC2[13] | IPC11[6:4] | | Input Capture/<br>Output Compare 6 | _CCP6Interrupt | 54 | 46 | 0x000070 | IFS2[14] | IEC2[14] | IPC11[10:8 | | CCP6 Timer | _CCT6Interrupt | 55 | 47 | 0x000072 | IFS2[15] | IEC2[15] | IPC11[14:12 | | QEI Position<br>Counter Compare | _QEI1Interrupt | 56 | 48 | 0x000074 | IFS3[0] | IEC3[0] | IPC12[2:0] | | UART1 Error | _U1EInterrupt | 57 | 49 | 0x000076 | IFS3[1] | IEC3[1] | IPC12[6:4] | | UART2 Error | _U2EInterrupt | 58 | 50 | 0x000078 | IFS3[2] | IEC3[2] | IPC12[10:8 | | CRC Generator | _CRCInterrupt | 59 | 51 | 0x00007A | IFS3[3] | IEC3[3] | IPC12[14:12 | | CAN1 TX Data<br>Request <b>(2)</b> | _C1TXInterrupt | 60 | 52 | 0x00007C | IFS3[4] | IEC3[4] | IPC13[2:0] | | CAN2 TX Data<br>Request <b>(2)</b> | _C2TXInterrupt | 61 | 53 | 0x00007E | IFS3[5] | IEC3[5] | IPC13[6:4] | | continued | | | | | | | | |----------------------------------|-----------------------------|----------|-------|-------------|----------|----------------|--------------| | Interrupt Source | MPLAB <sup>®</sup> XC16 ISR | Vector # | IRQ# | IVT Address | Int | errupt Bit Loc | ation | | interrupt Cource | Name | Vector # | II.O. | IVI Addiess | Flag | Enable | Priority | | QEI2 Position<br>Counter Compare | _QEI2Interrupt | 62 | 54 | 0x000080 | IFS3[6] | IEC3[6] | IPC13[10:8] | | Reserved | Reserved | 63 | 55 | 0x000082 | _ | - | _ | | UART3 Error | _U3EInterrupt | 64 | 56 | 0x000084 | IFS3[8] | IEC3[8] | IPC14[2:0] | | UART3 Receiver | _U3RXInterrupt | 65 | 57 | 0x000086 | IFS3[9] | IEC3[9] | IPC14[6:4] | | UART3 Transmitter | _U3TXInterrupt | 66 | 58 | 0x000088 | IFS3[10] | IEC3[10] | IPC14[10:8] | | SPI3 Receiver | _SPI3RXInterrupt | 67 | 59 | 0x00008A | IFS3[11] | IEC3[11] | IPC14[14:12] | | SPI3 Transmitter | SPI3TXInterrupt | 68 | 60 | 0x00008C | IFS3[12] | IEC3[12] | IPC15[2:0] | | In-Circuit Debugger | _ICDInterrupt | 69 | 61 | 0x00008E | IFS3[13] | IEC3[13] | IPC15[6:4] | | PTG Step | _PTGSTEPInterrupt | 71 | 63 | 0x000092 | IFS3[15] | IEC3[15] | IPC15[14:12] | | I2C1 Bus Collision | _I2C1BCInterrupt | 72 | 64 | 0x000094 | IFS4[0] | IEC4[0] | IPC16[2:0] | | I2C2 Bus Collision | _I2C2BCInterrupt | 73 | 65 | 0x000096 | IFS4[1] | IEC4[1] | IPC16[6:4] | | QEI3 Position<br>Counter Compare | _QEl3Interrupt | 74 | 66 | 0x000098 | IFS4[2] | IEC4[2] | IPC16[10:8] | | PWM Generator 1 | _PWM1Interrupt | 75 | 67 | 0x00009A | IFS4[3] | IEC4[3] | IPC16[14:12] | | PWM Generator 2 | _PWM2Interrupt | 76 | 68 | 0x00009C | IFS4[4] | IEC4[4] | IPC17[2:0] | | PWM Generator 3 | _PWM3Interrupt | 77 | 69 | 0x00009E | IFS4[5] | IEC4[5] | IPC17[6:4] | | PWM Generator 4 | _PWM4Interrupt | 78 | 70 | 0x0000A0 | IFS4[6] | IEC4[6] | IPC17[10:8] | | PWM Generator 5 | _PWM5Interrupt | 79 | 71 | 0x0000A2 | IFS4[7] | IEC4[7] | IPC17[14:12] | | PWM Generator 6 | _PWM6Interrupt | 80 | 72 | 0x0000A4 | IFS4[8] | IEC4[8] | IPC18[2:0] | | PWM Generator 7 | _PWM7Interrupt | 81 | 73 | 0x0000A6 | IFS4[9] | IEC4[9] | IPC18[6:4] | | PWM Generator 8 | _PWM8Interrupt | 82 | 74 | 0x0000A8 | IFS4[10] | IEC4[10] | IPC18[10:8] | | Change<br>Notice D(1) | _CNDInterrupt | 83 | 75 | 0x0000AA | IFS4[11] | IEC4[11] | IPC18[14:12] | | Change<br>Notice E(1) | CNEInterrupt | 84 | 76 | 0x0000AC | IFS4[12] | IEC4[12] | IPC19[2:0] | | Comparator 1 | _CMP1Interrupt | 85 | 77 | 0×0000AE | IFS4[13] | IEC4[13] | IPC19[6:4] | | Comparator 2 | _CMP2Interrupt | 86 | 78 | 0x0000B0 | IFS4[14] | IEC4[14] | IPC19[10:8] | | Comparator 3 | _CMP3Interrupt | 87 | 79 | 0x0000B2 | IFS4[15] | IEC4[15] | IPC19[14:2] | | Comparator 4 | _CMP4Interrupt | 88 | 80 | 0x0000B4 | IFS5[0] | IEC5[0] | IPC20[2:0] | | PTG Watchdog<br>Timer Time-out | _PTGWDTInterrupt | 89 | 81 | 0x0000B6 | IFS5[1] | IEC5[1] | IPC20[6:4] | | PTG Trigger 0 | _PTG0Interrupt | 90 | 82 | 0x0000B8 | IFS5[2] | IEC5[2] | IPC20[10:8] | | PTG Trigger 1 | _PTG1Interrupt | 91 | 83 | 0x0000BA | IFS5[3] | IEC5[3] | IPC20[14:12] | | PTG Trigger 2 | _PTG2Interrupt | 92 | 84 | 0x0000BC | IFS5[4] | IEC5[4] | IPC21[2:0] | | PTG Trigger 3 | _PTG3Interrupt | 93 | 85 | 0x0000BE | IFS5[5] | IEC5[6] | IPC21[6:4] | | SENT1 TX/RX | _SENT1Interrupt | 94 | 86 | 0x0000C0 | IFS5[6] | IEC5[6] | IPC21[10:8] | | continued | | | | | | | | |--------------------------|-----------------------------|----------|------|-------------|----------|----------------|--------------| | Interrupt Source | MPLAB <sup>®</sup> XC16 ISR | Vector # | IRQ# | IVT Address | Int | errupt Bit Loc | ation | | | Name | | | | Flag | Enable | Priority | | SENT1 Error | _SENT1EInterrupt | 95 | 87 | 0x0000C2 | IFS5[7] | IEC5[7] | IPC21[14:12] | | SENT2 TX/RX | _SENT2Interrupt | 96 | 88 | 0x0000C4 | IFS[8] | IEC5[8] | IPC22[2:0] | | SENT2 Error | _SENT2EInterrupt | 97 | 89 | 0x0000C6 | IFS[9] | IEC5[9] | IPC22[6:4] | | ADC Global<br>Interrupt | _ADCInterrupt | 98 | 90 | 0x0000C8 | IFS5[10] | IEC5[10] | IPC22[10:8] | | ADC AN0 Interrupt | _ADCAN0Interrupt | 99 | 91 | 0x0000CA | IFS5[11] | IEC5[11] | IPC22[14:12] | | ADC AN1 Interrupt | _ADCAN1Interrupt | 100 | 92 | 0x0000CC | IFS5[12] | IEC5[12] | IPC23[2:0] | | ADC AN2 Interrupt | _ADCAN2Interrupt | 101 | 93 | 0x0000CE | IFS5[13] | IEC5[13] | IPC23[6:4] | | ADC AN3 Interrupt | _ADCAN3Interrupt | 102 | 94 | 0x0000D0 | IFS5[14] | IEC5[14] | IPC23[10:8] | | ADC AN4 Interrupt | _ADCAN4Interrupt | 103 | 95 | 0x0000D2 | IFS5[15] | IEC5[15] | IPC23[14:12] | | ADC AN5 Interrupt | _ADCAN5Interrupt | 104 | 96 | 0x0000D4 | IFS6[0] | IEC6[0] | IPC24[2:0] | | ADC AN6 Interrupt | _ADCAN6Interrupt | 105 | 97 | 0x0000D6 | IFS6[1] | IEC6[1] | IPC24[6:4] | | ADC AN7<br>Interrupt(3) | _ADCAN7Interrupt | 106 | 98 | 0x0000D8 | IFS6[2] | IEC6[2] | IPC24[10:8] | | ADC AN8 Interrupt | _ADCAN8Interrupt | 107 | 99 | 0x0000DA | IFS6[3] | IEC6[3] | IPC24[14:12] | | ADC AN9 Interrupt | _ADCAN9Interrupt | 108 | 100 | 0x0000DC | IFS6[4] | IEC6[4] | IPC25[2:0] | | ADC AN10 Interrupt | _ADCAN10Interrupt | 109 | 101 | 0x0000DE | IFS6[5] | IEC6[5] | IPC25[6:4] | | ADC AN11 Interrupt | _ADCAN11Interrupt | 110 | 102 | 0x0000E0 | IFS6[6] | IEC6[6] | IPC25[10:8] | | ADC AN12<br>Interrupt(3) | _ADCAN12Interrupt | 111 | 103 | 0x0000E2 | IFS6[7] | IEC6[7] | IPC25[14:12] | | ADC AN13<br>Interrupt(3) | _ADCAN13Interrupt | 112 | 104 | 0x0000E4 | IFS6[8] | IEC6[8] | IPC26[2:0] | | ADC AN14<br>Interrupt(3) | _ADCAN14Interrupt | 113 | 105 | 0x0000E6 | IFS6[9] | IEC6[9] | IPC26[6:4] | | ADC AN15<br>Interrupt(3) | _ADCAN15Interrupt | 114 | 106 | 0x0000E8 | IFS6[10] | IEC6[10] | IPC26[10:8] | | ADC AN16 Interrupt | _ADCAN16Interrupt | 115 | 107 | 0x0000EA | IFS6[11] | IEC6[11] | IPC26[14:12] | | ADC AN17 Interrupt | _ADCAN17Interrupt | 116 | 108 | 0x0000EC | IFS6[12] | IEC6[12] | IPC27[2:0] | | ADC AN18<br>Interrupt(3) | _ADCAN18Interrupt | 117 | 109 | 0x0000EE | IFS6[13] | IEC6[13] | IPC27[6:4] | | ADC AN19<br>Interrupt(3) | _ADCAN19Interrupt | 118 | 110 | 0x0000F0 | IFS6[14] | IEC6[14] | IPC27[10:8] | | ADC AN20<br>Interrupt(3) | _ADCAN20Interrupt | 119 | 111 | 0x0000F2 | IFS6[15] | IEC6[15] | IPC27[14:12] | | ADC AN21<br>Interrupt(3) | _ADCAN21Interrupt | 120 | 112 | 0x0000F4 | IFS7[0] | IEC7[0] | IPC28[2:0] | | ADC AN22<br>Interrupt(3) | _ADCAN22Interrupt | 121 | 113 | 0x0000F6 | IFS7[1] | IEC7[1] | IPC28[6:4] | | ADC AN23<br>Interrupt(3) | _ADCAN23Interrupt | 122 | 114 | 0x0000F8 | IFS7[2] | IEC7[2] | IPC28[10:8] | | continued | | | | | | | | |------------------------------------|-----------------------------|----------|---------|-------------------|----------|----------------|--------------| | Interrupt Source | MPLAB <sup>®</sup> XC16 ISR | Vector # | IRQ# | IVT Address | Int | errupt Bit Loc | ation | | micriapi Source | Name | Vector " | | TV T / tudi ess | Flag | Enable | Priority | | ADC Fault | _ADFLTInterrupt | 123 | 115 | 0x0000FA | IFS7[3] | IEC7[3] | IPC28[14:12] | | ADC Digital<br>Comparator 0 | _ADCMP0Interrupt | 124 | 116 | 0x0000FC | IFS7[4] | IEC7[4] | IPC29[2:0] | | ADC Digital<br>Comparator 1 | _ADCMP1Interrupt | 125 | 117 | 0x0000FE | IFS7[5] | IEC7[5] | IPC29[6:4] | | ADC Digital<br>Comparator 2 | _ADCMP2Interrupt | 126 | 118 | 0x000100 | IFS7[6] | IEC7[6] | IPC29[10:8] | | ADC Digital<br>Comparator 3 | _ADCMP3Interrupt | 127 | 119 | 0x000102 | IFS7[7] | IEC7[7] | IPC29[14:12] | | ADC Oversample<br>Filter 0 | _ADFLTR0Interrupt | 128 | 120 | 0x000104 | IFS7[8] | IEC7[8] | IPC30[2:0] | | ADC Oversample<br>Filter 1 | _ADFLTR1Interrupt | 129 | 121 | 0x000106 | IFS7[9] | IEC7[9] | IPC30[6:4] | | ADC Oversample<br>Filter 2 | _ADFLTR2Interrupt | 130 | 122 | 0x000108 | IFS7[10] | IEC7[10] | IPC30[10:8] | | ADC Oversample<br>Filter 3 | _ADFLTR3Interrupt | 131 | 123 | 0x00010A | IFS7[11] | IEC7[11] | IPC30[14:12] | | CLC1 Positive Edge | _CLC1PInterrupt | 132 | 124 | 0x00010C | IFS7[12] | IEC7[12] | IPC31[2:0] | | CLC2 Positive Edge | _CLC2PInterrupt | 133 | 125 | 0x00010E | IFS7[13] | IEC7[13] | IPC31[6:4] | | SPI1 Error | _SPI1Interrupt | 134 | 126 | 0x000110 | IFS7[14] | IEC7[14] | IPC31[10:8] | | SPI2 Error | _SPI2Interrupt | 135 | 127 | 0x000112 | IFS7[15] | IEC7[15] | IPC31[14:12] | | SPI3 Error | _SPI3Interrupt | 136 | 128 | 0x000114 | IFS8[0] | IEC8[0] | IPC32[2:0] | | Reserved | Reserved | 137-149 | 129-141 | 0x000116-0x000128 | _ | _ | _ | | I2C3 Client Event | _SI2C3Interrupt | 150 | 142 | 0x000130 | IFS8[14] | IEC8[14] | IPC35[10:8] | | I2C3 Host Event | _MI2C3Interrupt | 151 | 143 | 0x000132 | IFS8[15] | IEC8[15] | IPC35[14:12] | | I2C3 Bus Collision | _I2C3BInterrupt | 152 | 144 | 0x000134 | IFS9[0] | IEC9[0] | IPC36[2:0] | | ADC AN27 Interrupt | _ADCAN27Interrupt | 153 | 145 | 0x000136 | IFS9[1] | IEC9[1] | IPC36[6:4] | | Reserved | Reserved | 154-156 | 146-148 | 0x000138-0x00013C | _ | _ | _ | | Input Capture/<br>Output Compare 7 | _CCP7Interrupt | 157 | 149 | 0x00013E | IFS9[5] | IEC9[5] | IPC37[6:4] | | CCP7 Timer | _CCT7Interrupt | 158 | 150 | 0x000140 | IFS9[6] | IEC9[6] | IPC37[10:8] | | ADC AN26 Interrupt | _ADCAN26Interrupt | 159 | 151 | 0x000142 | IFS9[7] | IEC9[7] | IPC37[14:12] | | Input Capture/<br>Output Compare 8 | _CCP8Interrupt | 160 | 152 | 0x000144 | IFS9[8] | IEC9[8] | IPC38[2:0] | | CCP8 Timer | _CCT8Interrupt | 161 | 153 | 0x000146 | IFS9[9] | IEC9[9] | IPC38[6:4] | | DMA Channel 6 | _DMA6Interrupt | 162 | 154 | 0x000148 | IFS9[10] | IEC9[10] | IPC38[10:8] | | DMA Channel 7 | _DMA7Interrupt | 163 | 155 | 0x00014A | IFS9[11] | IEC9[11] | IPC38[14:12] | | Reserved | Reserved | 164-176 | 156-168 | _ | _ | _ | _ | ## **Interrupt Controller** | continued | | | | | | | | |------------------------|-----------------------------|----------|----------|-------------------|--------------|----------------|---------------| | Interrupt Source | MPLAB <sup>®</sup> XC16 ISR | Vector # | IRQ# | IVT Address | Into | errupt Bit Loc | ation | | interrupt Course | Name | Vector # | II (SQ # | IVI Addiess | Flag | Enable | Priority | | PEVTA – PWM<br>Event A | _PEVTAInterrupt | 177 | 169 | 0x000166 | IFS10[9] | IEC10[9] | IPC42[6:4] | | PEVTB – PWM<br>Event B | _PEVTBInterrupt | 178 | 170 | 0x000168 | IFS10[10] | IEC10[10] | IPC42[10:8] | | PEVTC – PWM<br>Event C | _PEVTCInterrupt | 179 | 171 | 0x00016A | IFS10[11] | IEC10[11] | IPC42[14:12] | | PEVTD – PWM<br>Event D | _PEVTDInterrupt | 180 | 172 | 0x00016C | IFS10[12] | IEC10[12] | IPC43[2:0] | | PEVTE – PWM<br>Event E | _PEVTEInterrupt | 181 | 173 | 0x00016E | IFS10[13] | IEC10[13] | IPC43[6:4] | | PEVTF – PWM<br>Event F | _PEVTFInterrupt | 182 | 174 | 0x000170 | IFS10[14] | IEC10[14] | IPC43[10:8] | | CLC3 Positive Edge | _CLC3PInterrupt | 183 | 175 | 0x000172 | IFS10[15] | IEC10[15] | IPC43[14:12] | | CLC4 Positive Edge | _CLC4PInterrupt | 184 | 176 | 0x000174 | IFS11[0] | IEC11[0] | IPC44[2:0] | | CLC1 Negative<br>Edge | _CLC1NInterrupt | 185 | 177 | 0x000176 | IFS11[1] | IEC11[1] | IPC44[6:4] | | CLC2 Negative<br>Edge | _CLC2NInterrupt | 186 | 178 | 0x000178 | IFS11[2] | IEC11[2] | IPC44[10:8] | | CLC3 Negative<br>Edge | _CLC3NInterrupt | 187 | 179 | 0x00017A | IFS11[3] | IEC11[3] | IPC44[14:]12] | | CLC4 Negative<br>Edge | _CLC4NInterrupt | 188 | 180 | 0x00017C | IFS11[4] | IEC11[4] | IPC45[2:0] | | Reserved | Reserved | 189-194 | 181-186 | 0x00017E-0x000188 | <del>-</del> | _ | _ | | Comparator 5 | _CMP5Interrupt | 195 | 187 | 0x00018A | IFS11[11] | IEC11[11] | IPC46[14:12] | | Comparator 6 | _CMP6Interrupt | 196 | 188 | 0x00018C | IFS11[12] | IEC11[12] | IPC47[2:0] | | UART1 Event | _U1EVTInterrupt | 197 | 189 | 0x00018E | IFS11[13] | IF2C11[13] | IPC47[6:4] | | UART2 Event | _U2EVTInterrupt | 198 | 190 | 0x000190 | IFS11[14] | IF2C11[14] | IPC47[12:8] | | UART3 Event | _U3EVTInterrupt | 199 | 191 | 0x000192 | IFS11[15] | IF2C11[15] | IPC47[14:12] | | Reserved | Reserved | 200-255 | 192-247 | 0x000194-0x0001FE | _ | _ | _ | #### Note: - 1. Availability dependent on supported I/O ports. Refer to Table 8-1 for availability on device variants. - 2. Availability dependent on supported peripherals, refer to Table 1. - 3. Availability dependent on number of supported ADC channels. Refer to Table 1 for ADC channel availability on device variants. ## 7.4 Interrupt Resources Many useful resources are provided on the main product page of the Microchip website for the devices listed in this data sheet. This product page contains the latest updates and additional information. ## 7.5 Interrupt Control and Status Registers The dsPIC33CK512MP608 family devices implement the following registers for the interrupt controller: - INTCON1 - INTCON2 - INTCON3 - INTCON4 - INTTREG #### 7.5.1 INTCON1 through INTCON4 Global interrupt control functions are controlled from INTCON1, INTCON2, INTCON3 and INTCON4. INTCON1 contains the Interrupt Nesting Disable bit (NSTDIS), as well as the control and status flags for the processor trap sources. The INTCON2 register controls external interrupt request signal behavior, contains the Global Interrupt Enable bit (GIE) and the Alternate Interrupt Vector Table Enable bit (AIVTEN). INTCON3 contains the status flags for the Auxiliary PLL and DO stack overflow status trap sources. The INTCON4 register contains the Software Generated Hard Trap Status bit (SGHT). #### 7.5.1.1 IFSx The IFSx registers maintain all of the interrupt request flags. Each source of interrupt has a status bit, which is set by the respective peripherals or external signal and is cleared via software. #### 7.5.1.2 IECx The IECx registers maintain all of the interrupt enable bits. These control bits are used to individually enable interrupts from the peripherals or external signals. #### 7.5.1.3 IPCx The IPCx registers are used to set the Interrupt Priority Level (IPL) for each source of interrupt. Each user interrupt source can be assigned to one of seven priority levels. ### 7.5.1.4 INTTREG The INTTREG register contains the associated interrupt vector number and the new CPU Interrupt Priority Level, which are latched into the Vector Number (VECNUM[7:0]) and Interrupt Level bits (ILR[3:0]) fields in the INTTREG register. The new Interrupt Priority Level is the priority of the pending interrupt. The interrupt sources are assigned to the IFSx, IECx and IPCx registers in the same sequence as they are listed in Table 7-2. For example, INT0 (External Interrupt 0) is shown as having Vector Number 8 and a natural order priority of 0. Thus, the INT0IF bit is found in IFS0[0], the INT0IE bit in IEC0[0] and the INT0IP[2:0] bits in the first position of IPC0 (IPC0[2:0]). ## 7.6 Status/Control Registers Although these registers are not specifically part of the interrupt control hardware, two of the CPU Control registers contain bits that control interrupt functionality. For more information on these registers, refer to "Enhanced CPU" (www.microchip.com/DS70005158) in the "dsPIC33/PIC24 Family Reference Manual". - The CPU STATUS Register, SR, contains the IPL[2:0] bits (SR[7:5]). These bits indicate the current CPU Interrupt Priority Level. The user software can change the current CPU Interrupt Priority Level by writing to the IPLx bits. - The CORCON register contains the IPL3 bit, which together with IPL[2:0], also indicates the current CPU priority level. IPL3 is a read-only bit so that trap events cannot be masked by the user software. ## 7.7 Status/Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|------------|----------|-----------|-----------|-----------------|-----------|-------------|------------------------------------------------|--------------------|---------------------| | 040 | CD. | 15:8 | | | | | | | | | | 0x42 | SR | 7:0 | | IPL[2:0] | , | | | | | | | 044 | OODOON | 15:8 | VAR | | | | | | | | | 0x44 | CORCON | 7:0 | | | | | IPL3 | | | | | 0x46 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x07FF | | | | | | | | | | | | 0x0800 | IFS0 | 15:8 | INT1IF | NVMIF | ECCSBEIF | U1TXIF | U1RXIF | SPI1TXIF | SPI1RXIF | DMA1IF | | UXUOUU | IF30 | 7:0 | CCT1IF | CCP1IF | | DMA0IF | CNBIF | CNAIF | T1IF | INT0IF | | 0x0802 | IFS1 | 15:8 | C1RXIF | SPI2TXIF | SPI2RXIF | U2TXIF | U2RXIF | INT3IF | C1IF | CCT2IF | | 00002 | IFST | 7:0 | CCP2IF | DMA4IF | DMA3IF | INT2IF | CNCIF | DMA2IF | MI2C1IF | SI2C1IF | | 0.,000.4 | IECO | 15:8 | CCT6IF | CCP6IF | DMTIF | CCT5IF | CCP5IF | | CCT4IF | CCP4IF | | 0x0804 | IFS2 | 7:0 | | MI2C2 | SI2C2 | CCT3IF | CCP3IF | DMA5IF | C2IF | C2RXIF | | 0.0000 | IFOO | 15:8 | PTGSTEPIF | | ICDIF | | | U3TXIF | U3RXIF | U3EIF | | 0x0806 | IFS3 | 7:0 | | | | C1TXIF | CRCIF | U2EIF | U1EIF | QEI1IF | | | | 15:8 | CMP3IF | CMP2IF | CMP1IF | CNEIF | CNDIF | PWM8IF | PWM7IF | PWM6IF | | 0x0808 | IFS4 | 7:0 | PWM5IF | PWM4IF | PWM3IF | PWM2IF | PWM1IF | | I2C2BCIF | I2C1BCIF | | | 100 Sec. | 15:8 | ADCAN4IF | ADCAN3IF | ADCAN2IF | ADCAN1IF | ADCAN0IF | ADCIF | SENT2EIF | SENT2IF | | 0x080A | IFS5 | 7:0 | SENT1EIF | SENT1IF | PTG3IF | PTG2IF | PTG1IF | PTG0IF | PTGWDTIF | CMP4IF | | | 5.00 miles | 15:8 | ADCAN20IF | ADCAN19IF | ADCAN18 F | ADCAN17IF | ADCAN16IF | ADCAN15IF | ADCAN14IF | ADCAN13IF | | 0x080C | IFS6 | 7:0 | ADCAN12IF | ADCAN11IF | ADCAN10 F | ADCAN9IF | ADCAN8IF | ADCAN7IF | ADCAN6IF | ADCAN5IF | | | | 15:8 | SPI2GIF | SPI1GIF | CI C2PIF | CI C1PIF | ADCFI TR4IF | ADCFI TR3IF | ADCFI TR2IF | ADCFI TR1IF | | 0x080E | IFS7 | 10.0 | | | ADCS1CMP1I | | | 7.1.7631 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | 7.11.7631.71.71.71 | 7.1.7.2.1.1.1.1.1.1 | | OXOGOL | 07 | 7:0 | F | F | F | F | ADCFLTIF | | | ADCAN21IF | | | | 15:8 | MI2C3IF | SI2C3IF | 1 | 1 | | | | | | 0x0810 | IFS8 | 7:0 | WIIZOOII | GIZCOII | | | | | | SPI3GIF | | | | 15:8 | | | | | DMA7IF | DMA6IF | T8IF | IOC8IF | | 0x0812 | IFS9 | 7:0 | ADCAN26IF | T7IF | IOC7IF | | DIVIATIF | DIVIAGIF | ADCAN27IF | I2C3BCIF | | | | | CLC3PIF | PEVTFIF | PEVTEIF | DEVIDIE | PEVTCIF | PEVTBIF | PEVTAIF | IZCOBCII | | 0x0814 | IFS10 | 15:8 | CLCSPIF | PEVIFIF | PEVIEIR | PEVTDIF | PEVICIF | PEVIBIE | | ADCCOFIE | | | | 7:0 | LIGENITIE | LIGENITIE | HAENTIE | | | | ADCC1EIF | ADCC0EIF | | 0x0816 | IFS11 | 15:8 | U3ENTIF | U2ENTIF | U1ENTIF | 01.04115 | OL CONUE | 01.001.115 | 01.041115 | OL O IDIE | | | | 7:0 | | | | CLC4NIF | CLC3NIF | CLC2NIF | CLC1NIF | CLC4PIF | | 0x0818 | IFS12 | 15:8 | | | | | DIADELE | DIADIE | 1001110515 | 4504110415 | | | 12222424 | 7:0 | | | | | PMPEIF | PMPIF | ADCAN25IF | ADCAN24IF | | 0x081A | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x081F | | | | | | | | | | | | 0x0820 | IEC0 | 15:8 | INT1IE | NVMIE | ECCSBEIE | U1TXIE | U1RXIE | SPI1TXIE | SPI1RXIE | DMA1IE | | | 82761 | 7:0 | CCT1IE | IOC1IE | | DMA0IE | CNBIE | CNAIE | T1IE | INT0IE | | 0x0822 | IEC1 | 15:8 | C1RXIE | SPI2TXIE | SPI2RXIE | U2TXIE | U2RXIE | INT3IE | C1IE | CCT2IE | | | | 7:0 | IOC2IE | CCP2IE | DMA3IE | INT2IE | CNCIE | DMA2IE | MI2C1IE | SI2C1IE | | 0x0824 | IEC2 | 15:8 | CCT6IE | CCP6IE | DMTIE | CCT5IE | CCP5IE | | CCT4IE | CCP4IE | | OXOGE 1 | il COL | 7:0 | | MI2C2IE | SI2C2IE | CCT3IE | CCP3IE | DMA5IE | C2IE | C2RXIE | | 0x0826 | IEC3 | 15:8 | PTGSTEPIE | | ICDIE | | | U3TXIE | U3RXIE | U3EIE | | 0,0020 | ILOS | 7.0 | | | | C1TXIE | CRCIE | U2EIE | U1EIE | QEI1IE | | 0x0828 | IEC4 | 15:8 | CMP3IE | CMP2IE | CMP1IE | CNEIE | CNDIE | PWM8IE | PWM7IE | PWM6IE | | 00020 | IEC4 | 7:0 | PWM5IE | PWM4IE | PWM3IE | PWM2IE | PWM1IE | | I2C2BCIE | I2C1BCIE | | 00004 | IFOF | 15:8 | ADCAN4IE | ADCAN3IE | ADCAN2IE | ADCAN1IE | ADCAN0IE | ADCIE | SENT2EIE | SENT2IE | | 0x082A | IEC5 | 7:0 | SENT1EIE | SENT1IE | PTG3IE | PTG2IE | PTG1IE | PTG0IE | PTGWDTIE | CMP4IE | | 0,0000 | IEOC | 15:8 | ADCAN20IE | ADCAN19IE | ADCAN18IE | ADCAN17IE | ADCAN16IE | ADCAN15IE | ADCAN14IE | ADCAN13IE | | 0x082C | IEC6 | 7:0 | ADCAN12IE | ADCAN11IE | ADCAN10IE | ADCAN9IE | ADCAN8IE | ADCAN7IE | ADCAN6IE | ADCAN5IE | | | | 15:8 | SPI2GIE | SPI1GIE | CLC2PIE | CLC1PIE | ADCFLTR4IE | ADCFLTR3IE | ADCFLTR2IE | ADCFLTR1IE | | 0x082E | IEC7 | 7:0 | | | ADCS1CMP1I<br>E | | | | | ADCAN21IE | | | | 15:8 | MI2C3IE | SI2C3IE | _ | | | | | | | 0x0830 | IEC8 | 7:0 | IIIZOOIL | SIZOUL | | | | | | SPI3GIE | | | | 1.0 | | | | | | | | SFISGIE | | conti | nued | | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-------------|-----------|--------------------|------------------------------|-------------------------------------------|----------|-------------------|------------------------------|-----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0832 | IEC9 | 15:8 | | | | | DMA7IE | DMA6IE | T8IE | IOC8IE | | 0,0002 | 1200 | 7:0 | ADCAN26IE | T7IE | IOC7IE | 31.00 × 8.00 × 0.00 | | 200 M M M M M M M | ADCAN27IE | I2C3BCIE | | 0x0834 | IEC10 | 15:8 | CLC3PIE | PEVTFIE | PEVTEIE | PEVTDIE | PEVTCIE | PEVTBIE | PEVTAIE<br>ADCC1EIE | | | | | 7:0<br>15:8 | U3EVTIE | U2EVTIE | U1EVTIE | CMP6IE | CMP5IE | | ADCCTEIE | | | 0x0836 | IEC11 | 7:0 | OOLVIIL | CCT9IE | CCP9IE | CLC4NIE | CLC3NIE | | CLC1NIE | CLC2NIE | | 0x0838 | IEC12 | 15:8 | | S. C. St. Pirakino | | N. 14. 14. 14. 14. 14. 14. 14. 14. 14. 14 | | | | | | | ILC 12 | 7:0 | | | | | PMPEIE | PMPIE | ADCAN25IE | ADCAN24IE | | 0x083A | Reserved | | | | | | | | | | | 0x083F | Reserved | | | | | | | | | | | 0x0840 | IPC0 | 15:8 | | | CNBIP[2:0] | | | | CNAIP[2:0] | | | | 11 11.00 | 7:0 | | | T1IP[2:0] | | | | INT0IP[2:0] | | | 0x0842 | IPC1 | 15:8<br>7:0 | | | CCT1IP[2:0] | | | | CCP1IP[2:0]<br>DMA0IP[2:0] | | | | | 15:8 | | | U1RXIP[2:0] | | | | SPI1TXIP[2:0] | | | 0x0844 | IPC2 | 7:0 | | | SPI1RXIP[2:0 | ] | | | DMA1IP[2:0] | | | 0.0040 | IDOS | 15:8 | | | INT1IP[2:0] | | | | NVMIP[2:0] | | | 0x0846 | IPC3 | 7:0 | | | ECCSBIP[2:0] | | | | U1TXIP[2:0] | | | 0x0848 | IPC4 | 15:8 | | | CNCIP[2:0] | | | | DMA2IP[2:0] | | | 0,00010 | | 7:0 | | | MI2C1IP[2:0] | | | | SI2C1IP[2:0] | | | 0x084A | IPC5 | 15:8 | | | CCP2IP[2:0] | | | | DMA4IP[2:0] | | | | | 7:0<br>15:8 | | | DMA3IP[2:0]<br>U2RXIP[2:0] | | | | INT2IP[2:0]<br>INT3IP[2:0] | | | 0x084C | IPC6 | 7:0 | | | C1IP[2:0] | | | | CCT2IP[2:0] | | | | 5200E3 | 15:8 | | | C1RXIP[2:0] | | | | SPI2TXIP[2:0] | | | 0x084E | IPC7 | 7:0 | | | SPI2RXIP[2:0 | | | | U2TXIP[2:0] | | | 0x0850 | IPC8 | 15:8 | | | CCP3IP[2:0] | | | | DMA5IP[2:0] | | | 0x0650 | IPC6 | 7:0 | | | C2IP[2:0] | | | | C2RXIP[2:0] | | | 0x0852 | IPC9 | 15:8 | | | | | | | MI2C2IP[2:0] | | | | 77 4.355 | 7:0 | | | SI2C2IP[2:0] | | | | CCT3IP[2:0] | | | 0x0854 | IPC10 | 15:8<br>7:0 | | | CCP5IP[2:0]<br>CCT4IP[2:0] | | | | CCP4IP[2:0] | | | | 11 17 18 18 11 11 11 11 11 11 11 11 11 11 11 | 15:8 | | | CCT4IP[2:0] | | | | CCP6IP[2:0] | | | 0x0856 | IPC11 | 7:0 | | | DMTIP[2:0] | | | | CCT5IP[2:0] | | | 0x0858 | IDC40 | 15:8 | | | CRCIP[2:0] | | | | U2EIP[2:0] | | | 00000 | IPC12 | 7:0 | | | U1EIP[2:0] | | | | QEI1IP[2:0] | | | 0x085A | IPC13 | 15:8 | | | | | | | QEI2IP[2:0] | | | THE PROPERTY OF THE PARTY TH | (D) 40.29 (C). | 7:0 | | | C2TXIP[2:0] | 1 | | | C1TXIP[2:0] | | | 0x085C | IPC14 | 15:8<br>7:0 | | | SPI3RXIP[2:0] | | | | U3TXIP[2:0]<br>U3EIP[2:0] | | | | 6400 p. 1500 p. 1 | 15:8 | | | PTGSTEPIP[2: | n1 | | | USEIF[2.0] | | | 0x085E | IPC15 | 7:0 | | · · · · · | ICDIP[2:0] | ~] | | | SPI3TXIP[2:0] | | | 00000 | IDO4C | 15:8 | | | PWM1IP[2:0] | | | | QEI3IP[2:0] | | | 0x0860 | IPC16 | 7:0 | | | I2C2BCIP[2:0] | | | | I2C1BCIP[2:0] | | | 0x0862 | IPC17 | 15:8 | | | PWM5IP[2:0] | | | | PWM4IP[2:0] | | | | 17 7577 | 7:0 | | | PWM3IP[2:0] | | | | PWM2IP[2:0] | | | 0x0864 | IPC18 | 15:8<br>7:0 | | | CNDIP[2:0]<br>PWM7IP[2:0] | | | | PWM8IP[2:0] | | | | | 15:8 | | | CMP3IP[2:0] | | <u> </u> | | PWM6IP[2:0]<br>CMP2IP[2:0] | | | 0x0866 | IPC19 | 7:0 | | | CMP1IP[2:0] | | | | CNEIP[2:0] | | | 00000 | IDCCC | 15:8 | | | PTG1IP[2:0] | | | | PTG0IP[2:0] | | | 0x0868 | IPC20 | 7:0 | | | PTGWDTIP[2:0 | | | | CMP4IP[2:0] | | | 0x086A | IPC21 | 15:8 | | | SENT1EIP[2:0 | ] | | | SENT1IP[2:0] | | | 5,050/1 | 521 | 7:0 | | | PTG3IP[2:0] | _ | | | PTG2IP[2:0] | | | 0x086C | IPC22 | 15:8 | | | ADCAN0IP[2:0 | | | | ADCIP[2:0] | | | | | 7:0<br>15:8 | | | SENT2EIP[2:0<br>ADCAN4IP[2:0 | | | | SENT2IP[2:0]<br>ADCAN3IP[2:0 | 1 | | 0x086E | IPC23 | 7:0 | | | ADCAN4IF[2:0 | - | | | ADCANSIF[2:0 | | | | | 1.0 | | | | | | 1 | | | | contii | nued | | | | | | | | | | |------------|-----------------|-------------|----------|----------|-------------------------------|---------|-------------|----------------|--------------------------------|--------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 15:8 | | - 107100 | ADCAN8IP[2:0 | | | | ADCAN7IP[2:0] | | | 0x0870 | IPC24 | 7:0 | | | ADCAN6IP[2:0 | | | | ADCAN7IP[2:0] | | | | 00.000 | 15:8 | | | ADCAN12IP[2: | | | | ADCAN11IP[2:0 | | | 0x0872 | IPC25 | 7:0 | | | ADCAN10IP[2: | | | | ADCAN9IP[2:0] | | | 0x0874 | IPC26 | 15:8 | | | ADCAN16IP[2: | 0] | | ADCAN15IP[2:0] | | | | 000074 | IFC20 | 7:0 | | | ADCAN14IP[2: | | | | ADCAN13IP[2:0 | • | | 0x0876 | IPC27 | 15:8 | | | ADCAN20IP[2: | | | | ADCAN19IP[2:0 | | | 0.001.0 | | 7:0 | | , | ADCAN18IP[2: | | | | ADCAN17IP[2:0 | | | 0x0878 | IPC28 | 15:8 | | | ADFLTIP[2:0] | | | | ADCAN23IP[2:0 | | | | | 7:0<br>15:8 | | | ADCAN22IP[2:0<br>ADCMP3IP[2:0 | | | | ADCAN21IP[2:0<br>ADCMP2IP[2:0 | | | 0x087A | IPC29 | 7:0 | | | ADCMP3IP[2:0 | | | | ADCMP2IP[2:0]<br>ADCMP0IP[2:0] | | | | | 15:8 | | | ADCMF 11F[2:0 | | | | DCFLTR2IP[2:0] | | | 0x087C | IPC30 | 7:0 | | | ADCFLTR1IP[2: | | | | DCFLTR0IP[2:0 | | | | Total Section 1 | 15.8 | | | SPI2IP[2:0] | ۰, | | | SPI1IP[2:0] | 1 | | 0x087E | IPC31 | 7:0 | | | CLC2PIP[2:0] | | | | CLC1PIP[2:0] | | | | 10000 | 15:8 | | | | | | | | | | 0x0880 | IPC32 | 7:0 | | | | | | | SPI3IP[2:0] | | | 0x0882 | | | | | | | | | | | | <br>0x0885 | Reserved | | | | | | | | | | | 0x0886 | IPC35 | 15:8 | | | MI2C3IP[2:0] | | | | SI2C3IP[2:0] | | | 000000 | 11 000 | 7:0 | | | | | | | | | | 0x0888 | IPC36 | 15:8 | | | | | | | | | | | | 7:0 | | | ADCAN27IP[2: | - | | | 12C3BCIP[2:0] | | | 0x088A | IPC37 | 15:8 | | , | ADCAN26IP[2: | 0] | | | CCT7IP[2:0] | | | | | 7:0 | | | CCP7IP[2:0] | | | | DAMA OLDIO OL | | | 0x088C | IPC38 | 15:8 | | | DMA7IP[2:0] | | | | DMA6IP[2:0] | | | 0x088E | | 7:0 | | | CCT8IP[2:0] | 1 | | | CCP8IP[2:0] | | | | Reserved | | | | | | | | | | | 0x0893 | reserved | | | | | | | | | | | | 62 5 72 | 15:8 | | | PEVTCIP[2:0] | | | | PEVTBIP[2:0] | | | 0x0894 | IPC42 | 7:0 | | | PEVTAIP[2:0] | | | | | | | 0x0896 | IPC43 | 15:8 | | | CLC3PEIP[2:0 | | | | PEVTFIP[2:0] | | | 0.0030 | IF 043 | 7:0 | | | PEVTEIP[2:0] | | | | PEVTDIP[2:0] | | | 0x0898 | IPC44 | 15:8 | | | CLC3NEIP[2:0 | | | | CLC2NEIP[2:0] | | | UNUUUU | | 7:0 | | | CLC1NEIP[2:0 | ] | | | CLC4PEIP[2:0] | | | 0x089A | IPC45 | 15:8 | | | | | | | CCT9IP[2:0] | | | | | 7:0 | | | CCP9IP[2:0] | | | | CLC4NEIP[2:0] | | | 0x089C | IPC46 | 15:8 | | | CMP5IP[2:0] | | | | | | | | | 7:0<br>15:8 | | | U3EVTIP[2:0] | | | | U2EVTIP[2:0] | | | 0x089E | IPC47 | 7:0 | | | U1EVTIP[2:0] | | | | CMP6IP[2:0] | | | | | 15:8 | | | PMPEIP[2:0] | | | | PMPIP[2:0] | | | 0x089E | IPC48 | 7:0 | | | ADCAN25IP[2: | วา | | | ADCAN24IP[2:0 | 1 | | 0x08A0 | | 10 | | | I SOTTI EST | -1 | | | 1507,112111 [2:0 | 1 | | | Reserved | | | | | | | | | | | 0x08BF | | | | | | | | | | | | 0x08C0 | INTCON1 | 15:8 | NSTDIS | OVAERR | OVBERR | COVAERR | COVBERR | OVATE | OVBTE | COVTE | | UXUUCU | INTOONT | 7:0 | SFTACERR | DIV0ERR | | MATHERR | ADDRERR | STKERR | OSCFAIL | | | 0x08C2 | INTCON2 | 15:8 | GIE | DISI | SWTRAP | | | | | | | J | | 7:0 | | | | | INT3EP | INT2EP | INT1EP | INT0EP | | 0x08C4 | INTCON3 | 15:8 | | | | | | | | NAE | | | | 7:0 | | | | DOOVR | | | | APLL | | 0x08C6 | INTCON4 | 15:8 | | | | | | | E00555 | 06:17 | | | | 7:0<br>15:8 | | | VIIOLD | | | 11.5 | ECCDBE | SGHT | | 0x08C8 | INTTREG | 7:0 | | | VHOLD | VECNI | <br>JM[7:0] | ILK | [3:0] | | | | | 7.0 | | | | VECINI | נט. זןואוכ | | | | ## 7.7.1 Interrupt Request Flags Register 0 Name: IFS0 Offset: 0x800 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|----------|--------|--------|----------|----------|--------| | | INT1IF | NVMIF | ECCSBEIF | U1TXIF | U1RXIF | SPI1TXIF | SPI1RXIF | DMA1IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCT1IF | CCP1IF | | DMA0IF | CNBIF | CNAIF | T1IF | INT0IF | | Access | R/W | R/W | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - INT1IF External Interrupt 1 bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 14 - NVMIF Nonvolatile Memory Write Complete Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 13 - ECCSBEIF ECC Single Bit Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 12 - U1TXIF UART1 Transmitter Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 11 - U1RXIF UART1 Receiver Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 10 - SPI1TXIF SPI1 Transfer Done Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - SPI1RXIF SPI1 Receive Done Interrupt bit | Dit 9 - St | bit 9 – 9FITINALI SETT Necelve Dolle Interrupt bit | | |------------|----------------------------------------------------|--| | Value | Description | | | 1 | Interrupt has occurred | | | 0 | Interrupt has not occurred | | ### Bit 8 - DMA1IF Direct Memory Access 1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | © 2021 Microchip Technology Inc. and its subsidiaries ## **Interrupt Controller** ## Bit 7 - CCT1IF Capture/Compare/Timer1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 6 - CCP1IF Input Capture/Output Compare 1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 4 - DMA0IF Direct Memory Access 0 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 3 - CNBIF Change Notice Interrupt B bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 2 - CNAIF Change Notice Interrupt A bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 1 - T1IF Timer1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - INTOIF External Interrupt 0 bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.2 Interrupt Request Flags Register 1 Name: IFS1 Offset: 0x802 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----------|----------|--------|--------|--------|---------|---------| | | C1RXIF | SPI2TXIF | SPI2RXIF | U2TXIF | U2RXIF | INT3IF | C1IF | CCT2IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCP2IF | DMA4IF | DMA3IF | INT2IF | CNCIF | DMA2IF | MI2C1IF | SI2C1IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - C1RXIF CAN1 RX Data Ready Interrupt bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ### Bit 14 - SPI2TXIF SPI2 Transfer Done Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 13 - SPI2RXIF SPI2 Receiver Done Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 12 - U2TXIF UART2 Transmitter Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 11 - U2RXIF UART2 Receiver Interrupt bit | DIL III – U | Bit II - OZKAN OAKTZ Neceiver interrupt bit | | |-------------|---------------------------------------------|--| | Value | Description | | | 1 | Interrupt has occurred | | | 0 | Interrupt has not occurred | | #### Bit 10 - INT3IF External Interrupt 3 bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - C1IF CAN1 Combined Error Interrupt Bit | Dit 5 - C II | CANT Combined Error interrupt bit | |--------------|-----------------------------------| | Value | Description | | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 8 - CCT2IF Capture/Compare/Timer2 Interrupt bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## **Interrupt Controller** ### Bit 7 - CCP2IF Input Capture/Output Compare 2 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 6 - DMA4IF Direct Memory Access 4 Interrupt bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 5 - DMA3IF Direct Memory Access 3 Interrupt bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 4 - INT2IF External Interrupt 2 bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 3 - CNCIF Change Notice Interrupt C bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 2 - DMA2IF Direct Memory Access 2 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 1 - MI2C1IF I2C1 Host Event Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - SI2C1IF I2C1 Client Event Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.3 Interrupt Request Flags Register 2 Name: IFS2 Offset: 0x804 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|-------|--------|--------|--------|--------|--------| | | CCT6IF | CCP6IF | DMTIF | CCT5IF | CCP5IF | | CCT4IF | CCP4IF | | Access | R/W | R/W | R/W | R/W | R/W | - | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | MI2C2 | SI2C2 | CCT3IF | CCP3IF | DMA5IF | C2IF | C2RXIF | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - CCT6IF Capture/Compare/Timer6 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 14 - CCP6IF Input Capture/Output Compare 6 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 13 - DMTIF Deadman Timer Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 12 - CCT5IF Capture/Compare/Timer5 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 11 - CCP5IF Input Capture/Output Compare 5 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 9 - CCT4IF Capture/Compare/Timer4 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 8 - CCP4IF Input Capture/Output Compare 4 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 6 - MI2C2 I2C2 Host Event Interrupt bit | Value | Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | ## **Interrupt Controller** ### Bit 5 - SI2C2 I2C2 Client Interrupt bit | Value | Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | #### Bit 4 - CCT3IF Capture/Compare/Timer3 Interrupt bit | Value Description | | | | | |-------------------|----------------------------|--|--|--| | 1 | Interrupt has occurred | | | | | 0 | Interrupt has not occurred | | | | ### Bit 3 - CCP3IF Input Capture/Output Compare 3 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 2 - DMA5IF Direct Memory Access 5 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 1 - C2IF CAN2 Combined Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - C2RXIF CAN2 RX Data Ready Interrupt bit | Value | Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | ## 7.7.4 Interrupt Request Flags Register 3 Name: IFS3 Offset: 0x806 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|----|-------|--------|-------|--------|--------|--------| | | PTGSTEPIF | | ICDIF | | | U3TXIF | U3RXIF | U3EIF | | Access | R/W | | R/W | 90 | | R/W | R/W | R/W | | Reset | 0 | | 0 | | | 0 | 0 | 0 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | C1TXIF | CRCIF | U2EIF | U1EIF | QEI1IF | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - PTGSTEPIF PTG Step Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 13 - ICDIF In-Circuit Debugger Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 10 - U3TXIF UART3 Transmitter Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - U3RXIF UART3 Receiver Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ### Bit 8 - U3EIF UART3 Error Interrupt bit | Bit 6 = 65Eii 6Ait 15 Eiroi interrupt bit | | |-------------------------------------------|----------------------------| | Value | Description | | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 4 - C1TXIF CAN1 TX Data Request Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 3 - CRCIF Cyclic Redundancy Check Interrupt bit | DIL 3 - CI | Bit 3 - Chair Cyclic Neduridancy Check Interrupt bit | | |------------|------------------------------------------------------|--| | Value | Description | | | 1 | Interrupt has occurred | | | 0 | Interrupt has not occurred | | ## Bit 2 - U2EIF UART2 Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | # **Interrupt Controller** ## Bit 1 - U1EIF UART1 Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - QEI1IF QEI1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | # 7.7.5 Interrupt Request Flags Register 4 Name: IFS4 Offset: 0x808 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|----------|----------| | | CMP3IF | CMP2IF | CMP1IF | CNEIF | CNDIF | PWM8IF | PWM7IF | PWM6IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PWM5IF | PWM4IF | PWM3IF | PWM2IF | PWM1IF | | I2C2BCIF | I2C1BCIF | | Access | R/W | R/W | R/W | R/W | R/W | | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | ## Bit 15 - CMP3IF Comparator 3 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 14 - CMP2IF Comparator 2 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 13 - CMP1IF Comparator 1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 12 - CNEIF Change Notice E Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 11 - CNDIF Change Notice D Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 10 - PWM8IF PWM Generator 8 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - PWM7IF PWM Generator 7 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 8 - PWM6IF PWM Generator 6 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | # **Interrupt Controller** #### Bit 7 - PWM5IF PWM Generator 5 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 6 - PWM4IF PWM Generator 4 Interrupt bit | Value | Description | | | | |-------|----------------------------|--|--|--| | 1 | Interrupt has occurred | | | | | 0 | Interrupt has not occurred | | | | #### Bit 5 - PWM3IF PWM Generator 3 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 4 - PWM2IF PWM Generator 2 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 3 - PWM1IF PWM Generator 1 Interrupt bit | Value | Description | | | | |-------|----------------------------|--|--|--| | 1 | Interrupt has occurred | | | | | 0 | Interrupt has not occurred | | | | ## Bit 1 - I2C2BCIF I2C2 Bus Collision Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - I2C1BCIF I2C1 Bus Collision Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.6 Interrupt Request Flags Register 5 Name: IFS5 Offset: 0x80A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|----------|----------|----------|----------|--------|----------|---------| | | ADCAN4IF | ADCAN3IF | ADCAN2IF | ADCAN1IF | ADCAN0IF | ADCIF | SENT2EIF | SENT2IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SENT1EIF | SENT1IF | PTG3IF | PTG2IF | PTG1IF | PTG0IF | PTGWDTIF | CMP4IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - ADCAN4IF ADC AN4 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 14 - ADCAN3IF ADC AN3 Interrupt bit | Value | Description | | | | |-------|----------------------------|--|--|--| | 1 | Interrupt has occurred | | | | | 0 | Interrupt has not occurred | | | | ## Bit 13 - ADCAN2IF ADC AN2 Interrupt bit | Value | Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | ## Bit 12 - ADCAN1IF ADC AN1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 11 - ADCANOIF ADC ANO Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 10 - ADCIF ADC Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - SENT2EIF SENT2 Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 8 - SENT2IF SENT2 TX/RX Interrupt bit | Value | Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | # **Interrupt Controller** ## Bit 7 - SENT1EIF SENT1 Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 6 - SENT1IF SENT1 TX/RX Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 5 - PTG3IF PTG3 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 4 - PTG2IF PTG2 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 3 - PTG1IF PTG Trigger 1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 2 - PTG0IF PTG Trigger 0 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 1 - PTGWDTIF PTG Watchdog Timer Time-out Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - CMP4IF Comparator 4 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.7 Interrupt Request Flags Register 6 Name: IFS6 Offset: 0x80C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | ADCAN20IF | ADCAN19IF | ADCAN18IF | ADCAN17IF | ADCAN16IF | ADCAN15IF | ADCAN14IF | ADCAN13IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ADCAN12IF | ADCAN11IF | ADCAN10IF | ADCAN9IF | ADCAN8IF | ADCAN7IF | ADCAN6IF | ADCAN5IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - ADCAN20IF ADC AN20 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 14 - ADCAN19IF ADC AN19 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 13 - ADCAN18IF ADC AN18 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 12 - ADCAN17IF ADC AN17 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 11 - ADCAN16IF ADC AN16 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 10 - ADCAN15IF ADC AN15 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - ADCAN14IF ADC AN14 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 8 - ADCAN13IF ADC AN13 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | # **Interrupt Controller** ## Bit 7 - ADCAN12IF ADC AN12 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 6 - ADCAN11IF ADC AN11 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 5 - ADCAN10IF ADC AN10 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 4 - ADCAN9IF ADC AN9 Interrupt bit | I | Value | Description | |---|-------|----------------------------| | | 1 | Interrupt has occurred | | | 0 | Interrupt has not occurred | ## Bit 3 - ADCAN8IF ADC AN8 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 2 - ADCAN7IF ADC AN7 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 1 - ADCAN6IF ADC AN6 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - ADCAN5IF ADC AN5 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.8 Interrupt Request Flags Register 7 Name: IFS7 Offset: 0x80E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|-------------|-------------|-------------|------------|------------|------------|------------| | | SPI2GIF | SPI1GIF | CLC2PIF | CLC1PIF | ADCFLTR4IF | ADCFLTR3IF | ADCFLTR2IF | ADCFLTR1IF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ADCS1CMP3IF | ADCS1CMP2IF | ADCS1CMP1IF | ADCS1CMP0 F | ADCFLTIF | | | ADCAN21IF | | Access | R/W | R/W | R/W | R/W | R/W | | | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | | 0 | ## Bit 15 - SPI2GIF SPI2 Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 14 - SPI1GIF SPI1 Error Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 13 - CLC2PIF CLC2 Positive Edge Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 12 - CLC1PIF CLC1 Positive Edge Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 11 - ADCFLTR4IF ADC Oversample Filter 4 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 10 - ADCFLTR3IF ADC Oversample Filter 3 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - ADCFLTR2IF ADC Oversample Filter 2 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 8 - ADCFLTR1IF ADC Oversample Filter 1 Interrupt bit | Value | Description | | | | | | |-------|----------------------------|--|--|--|--|--| | 1 | Interrupt has occurred | | | | | | | 0 | Interrupt has not occurred | | | | | | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 152 # **Interrupt Controller** ## Bit 7 - ADCS1CMP3IF ADC Digital Comparator 3 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 6 - ADCS1CMP2IF ADC Digital Comparator 2 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 5 - ADCS1CMP1IF ADC Digital Comparator 1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 4 - ADCS1CMP0IF ADC Digital Comparator 0 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 3 - ADCFLTIF ADC Fault Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - ADCAN21IF ADC AN21 Interrupt bit | Value | Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | # **Interrupt Controller** # 7.7.9 Interrupt Request Flags Register 8 Name: IFS8 Offset: 0x810 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|---------|----|----|----|----|---|---------| | | MI2C3IF | SI2C3IF | | | | | | | | Access | R/W | R/W | | | | >- | | | | Reset | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | SPI3GIF | | Access | | | | | | | | R/W | | Reset | | | | | | | | 0 | Bit 15 - MI2C3IF I2C3 Host Event Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 14 - SI2C3IF I2C3 Client Event Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - SPI3GIF SPI3 Error Interrupt bit | Value | Description | | | | | | |-------|----------------------------|--|--|--|--|--| | 1 | Interrupt has occurred | | | | | | | 0 | Interrupt has not occurred | | | | | | ## 7.7.10 Interrupt Request Flags Register 9 Name: IFS9 Offset: 0x812 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|------|--------|----|--------|--------|-----------|----------| | | | | | | DMA7IF | DMA6IF | T8IF | IOC8IF | | Access | | | | 22 | R/W | R/W | R/W | R/W | | Reset | | | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ADCAN26IF | T7IF | IOC7IF | | | | ADCAN27IF | I2C3BCIF | | Access | R/W | R/W | R/W | | | | R/W | R/W | | Reset | 0 | 0 | 0 | | | | 0 | 0 | ## Bit 11 - DMA7IF Direct Memory Access 7 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 10 - DMA6IF Direct Memory Access 6 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - T8IF CCP8 (Timer8) Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 8 - IOC8IF Interrupt-on-Change 8 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 7 - ADCAN26IF ADC AN26 Interrupt bit | DIL I - AL | SCANZOII ADO ANZO III. CITUPI DIL | |------------|-----------------------------------| | Value | Description | | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 6 - T7IF CCP7 (Timer7) Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 5 - IOC7IF Interrupt-on-Change 7 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 1 - ADCAN27IF ADC AN27 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | **Interrupt Controller** ## Bit 0 - I2C3BCIF I2C3 Bus Collision Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.11 Interrupt Request Flags Register 10 Name: IFS10 Offset: 0x814 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|---------|---------|---------|---------|---------|----------|----------| | | CLC3PIF | PEVTFIF | PEVTEIF | PEVTDIF | PEVTCIF | PEVTBIF | PEVTAIF | | | Access | R/W - | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | ADCC1EIF | ADCC0EIF | | Access | | | | | | | R/W | R/W | | Reset | | | | | | | 0 | 0 | Bit 15 - CLC3PIF CLC3 Positive Edge Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 14 - PEVTFIF PWM Event F Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 13 - PEVTEIF PWM Event E Interrupt bit | Value | ue Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | ## Bit 12 - PEVTDIF PWM Event D Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 11 - PEVTCIF PWM Event C Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | #### Bit 10 - PEVTBIF PWM Event B Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 9 - PEVTAIF PWM Event A Interrupt bit | Value | Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | ## Bit 1 - ADCC1EIF ADC Enable 1 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | **Interrupt Controller** ## Bit 0 - ADCC0EIF ADC Enable 0 Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.12 Interrupt Request Flags Register 11 Name: IFS11 Offset: 0x816 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | | U3ENTIF | U2ENTIF | U1ENTIF | | | | | | | Access | R/W | R/W | R/W | 90 | | | | | | Reset | 0 | 0 | 0 | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | CLC4NIF | CLC3NIF | CLC2NIF | CLC1NIF | CLC4PIF | | Access | - | - | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - U3ENTIF UART3 Event Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 14 - U2ENTIF UART2 Event Interrupt bit | Value Description | | | | |-------------------|----------------------------|--|--| | 1 | Interrupt has occurred | | | | 0 | Interrupt has not occurred | | | #### Bit 13 - U1ENTIF UART1 Event Interrupt bit | Value | ue Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | ## Bit 4 - CLC4NIF CLC4 Negative Edge Interrupt bit | Value | Description | | | |-------|---------------------|---------|--| | 1 | Interrupt has occur | red | | | 0 | Interrupt has not o | ccurred | | ## Bit 3 - CLC3NIF CLC3 Negative Edge Interrupt bit | Value | e Description | | | |-------|----------------------------|--|--| | 1 | Interrupt has occurred | | | | 0 | Interrupt has not occurred | | | #### Bit 2 - CLC2NIF CLC2 Negative Edge Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 1 - CLC1NIF CLC1 Negative Edge Interrupt bit | Value Description | | |-------------------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 0 - CLC4PIF CLC4 Positive Edge Interrupt bit | Value | lue Description | | | | | |-------|----------------------------|--|--|--|--| | 1 | Interrupt has occurred | | | | | | 0 | Interrupt has not occurred | | | | | # **Interrupt Controller** # 7.7.13 Interrupt Request Flags Register 12 Name: IFS12 Offset: 0x818 #### Bit 3 - PMPEIF Parallel Main Port External Interrupt bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## Bit 2 - PMPIF Parallel Main Port Interrupt bit | Value | Value Description | | | | |-------|----------------------------|--|--|--| | 1 | Interrupt has occurred | | | | | 0 | Interrupt has not occurred | | | | ## Bit 1 - ADCAN25IF ADC AN25 Interrupt bit | Value | Description | | | | |-------|----------------------------|--|--|--| | 1 | Interrupt has occurred | | | | | 0 | Interrupt has not occurred | | | | ## Bit 0 - ADCAN24IF ADC AN24 Interrupt bit | Value | lue Description | | | | |-------|----------------------------|--|--|--| | 1 | Interrupt has occurred | | | | | 0 | Interrupt has not occurred | | | | ## 7.7.14 Interrupt Enable Register 0 Name: IEC0 Offset: 0x820 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|----------|--------|--------|----------|----------|--------| | | INT1IE | NVMIE | ECCSBEIE | U1TXIE | U1RXIE | SPI1TXIE | SPI1RXIE | DMA1IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCT1IE | IOC1IE | | DMA0IE | CNBIE | CNAIE | T1IE | INT0IE | | Access | R/W | R/W | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - INT1IE External Interrupt 1 Enable bit | Value | ue Description | | | | |-------|-----------------------|--|--|--| | 1 | Interrupt enabled | | | | | 0 | Interrupt not enabled | | | | ## Bit 14 - NVMIE NVM Program/Erase Complete Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 13 - ECCSBEIE ECC Single Bit Error Interrupt Enable bit | Value | e Description | | | | | |-------|-----------------------|--|--|--|--| | 1 | Interrupt enabled | | | | | | 0 | Interrupt not enabled | | | | | ## Bit 12 - U1TXIE UART1 Transmitter Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - U1RXIE UART1 Receiver Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 10 - SPI1TXIE SPI1 Transfer Done Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - SPI1RXIE SPI1 Receive Done Interrupt Enable bit | Value | Value Description | | |-------|-----------------------|--| | 1 | Interrupt enabled | | | 0 | Interrupt not enabled | | ## Bit 8 - DMA1IE Direct Memory Access 1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | # **Interrupt Controller** ## Bit 7 - CCT1IE Capture/Compare/Timer1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 6 - IOC1IE Interrupt-on-Change 1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 4 - DMA0IE Direct Memory Access 0 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 3 - CNBIE Change Notice B Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 2 - CNAIE Change Notice A Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 1 - T1IE Timer1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - INTOIE External Interrupt 0 Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## 7.7.15 Interrupt Enable Register 1 Name: IEC1 Offset: 0x822 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----------|----------|--------|--------|--------|---------|---------| | | C1RXIE | SPI2TXIE | SPI2RXIE | U2TXIE | U2RXIE | INT3IE | C1IE | CCT2IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | IOC2IE | CCP2IE | DMA3IE | INT2IE | CNCIE | DMA2IE | MI2C1IE | SI2C1IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - C1RXIE CAN1 RX Data Ready Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - SPI2TXIE SPI2 Transmitter Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 13 - SPI2RXIE SPI2 Receiver Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 12 - U2TXIE UART2 Transmitter Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - U2RXIE UART2 Receiver Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 10 - INT3IE External Interrupt 3 Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - C1IE CAN1 Combined Error Interrupt Enable bit | Dit 9 - C | Bit 9 - CTIL CAN'T Combined Error interrupt Errable bit | | | |-----------|---------------------------------------------------------|--|--| | Value | Description | | | | 1 | Interrupt enabled | | | | 0 | Interrupt not enabled | | | ## Bit 8 - CCT2IE Capture/Compare/Timer2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | # **Interrupt Controller** ## Bit 7 - IOC2IE Interrupt-on-Change 2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 6 - CCP2IE Input Capture/Output Compare 2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 5 - DMA3IE Direct Memory Access 3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 4 - INT2IE External Interrupt 2 Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 3 - CNCIE Change Notice C Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 2 - DMA2IE Direct Memory Access 2 Interrupt bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 1 - MI2C1IE I2C1 Host Events Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - SI2C1IE I2C1 Client Events Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## 7.7.16 Interrupt Enable Register 2 Name: IEC2 Offset: 0x824 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|---------|---------|--------|--------|--------|--------|--------| | | CCT6IE | CCP6IE | DMTIE | CCT5IE | CCP5IE | | CCT4IE | CCP4IE | | Access | R/W | R/W | R/W | R/W | R/W | - | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | MI2C2IE | SI2C2IE | CCT3IE | CCP3IE | DMA5IE | C2IE | C2RXIE | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - CCT6IE Capture/Compare/Timer6 Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - CCP6IE Input Capture/Output Compare 6 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 13 - DMTIE Deadman Timer Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 12 - CCT5IE Capture/Compare/Timer5 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - CCP5IE Input Capture/Output Compare 5 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - CCT4IE Capture/Compare/Timer4 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 8 - CCP4IE Input Capture/Output Compare 4 Interrupt Enable bit | Value Description | | |-------------------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 6 - MI2C2IE I2C2 Host Event Interrupt Enable bit | Value | Description | | |-------|-----------------------|--| | 1 | Interrupt enabled | | | 0 | Interrupt not enabled | | # **Interrupt Controller** ## Bit 5 - SI2C2IE I2C2 Client Event Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 4 - CCT3IE Capture/Compare/Timer3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 3 - CCP3IE Input Capture/Output Compare 3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 2 - DMA5IE Direct Memory Access 5 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 1 - C2IE CAN2 Combined Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - C2RXIE CAN2 RX Data Ready Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## 7.7.17 Interrupt Enable Register 3 Name: IEC3 Offset: 0x826 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|----|-------|--------|-------|--------|--------|--------| | | PTGSTEPIE | | ICDIE | | | U3TXIE | U3RXIE | U3EIE | | Access | R/W | | R/W | 90 | | R/W | R/W | R/W | | Reset | 0 | | 0 | | | 0 | 0 | 0 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | C1TXIE | CRCIE | U2EIE | U1EIE | QEI1IE | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - PTGSTEPIE PTG Step Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 13 - ICDIE ICD Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 10 - U3TXIE UART3 Transmitter Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - U3RXIE UART3 Receiver Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 8 - U3EIE UART3 Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 4 - C1TXIE CAN1 TX Data Request Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 3 - CRCIE CRC Interrupt Enable bit | Dit 3 - Ci | Bit 3 - Choic One Interrupt Enable bit | | | |------------|----------------------------------------|--|--| | Value | Description | | | | 1 | Interrupt enabled | | | | 0 | Interrupt not enabled | | | ## Bit 2 - U2EIE UART2 Error Interrupt Enable bit | Value | Description | | |-------|-----------------------|--| | 1 | Interrupt enabled | | | 0 | Interrupt not enabled | | **Interrupt Controller** ## Bit 1 – U1EIE UART1 Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - QEI1IE QEI1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## 7.7.18 Interrupt Enable Register 4 Name: IEC4 Offset: 0x828 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|----------|----------| | | CMP3IE | CMP2IE | CMP1IE | CNEIE | CNDIE | PWM8IE | PWM7IE | PWM6IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PWM5IE | PWM4IE | PWM3IE | PWM2IE | PWM1IE | | I2C2BCIE | I2C1BCIE | | Access | R/W | R/W | R/W | R/W | R/W | | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | ## Bit 15 - CMP3IE Comparator 3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - CMP2IE Comparator 2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 13 - CMP1IE Comparator 1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 12 - CNEIE Change Notice E Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - CNDIE Change Notice D Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 10 - PWM8IE Pulse-Width Modulation 8 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - PWM7IE Pulse-Width Modulation 7 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 8 - PWM6IE Pulse-Width Modulation 6 Interrupt Enable bit | Value | Description | | | | | |-------|-----------------------|--|--|--|--| | 1 | Interrupt enabled | | | | | | 0 | Interrupt not enabled | | | | | # **Interrupt Controller** ## Bit 7 - PWM5IE Pulse-Width Modulation 5 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 6 - PWM4IE Pulse-Width Modulation 4 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 5 - PWM3IE Pulse-Width Modulation 3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 4 – PWM2IE Pulse-Width Modulation 2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 3 - PWM1IE Pulse-Width Modulation 1 Interrupt Enable bit | Value | Description | | | | | | |-------|-----------------------|--|--|--|--|--| | 1 | Interrupt enabled | | | | | | | 0 | Interrupt not enabled | | | | | | ## Bit 1 - I2C2BCIE I2C2 Bus Collision Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - I2C1BCIE I2C1 Bus Collision Interrupt Enable bit | Value | Description | | | | | | | |-------|-----------------------|--|--|--|--|--|--| | 1 | Interrupt enabled | | | | | | | | 0 | Interrupt not enabled | | | | | | | ## 7.7.19 Interrupt Enable Register 5 Name: IEC5 Offset: 0x82A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|----------|----------|----------|----------|--------|----------|---------| | | ADCAN4IE | ADCAN3IE | ADCAN2IE | ADCAN1IE | ADCAN0IE | ADCIE | SENT2EIE | SENT2IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SENT1EIE | SENT1IE | PTG3IE | PTG2IE | PTG1IE | PTG0IE | PTGWDTIE | CMP4IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - ADCAN4IE ADC AN4 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - ADCAN3IE ADC AN3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 13 - ADCAN2IE ADC AN2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 12 - ADCAN1IE ADC AN1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - ADCAN0IE ADC AN0 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 10 - ADCIE ADC Global Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - SENT2EIE SENT2 Error Interrupt Enable bit | DIL 9 - 31 | BIL 9 - SENTZ EITOT IIILEITUPI EITABIE BIL | | |------------|--------------------------------------------|--| | Value | Description | | | 1 | Interrupt enabled | | | 0 | Interrupt not enabled | | ## Bit 8 - SENT2IE SENT2 TX/RX Interrupt Enable bit | Value | Description | | |-------|-----------------------|--| | 1 | Interrupt enabled | | | 0 | Interrupt not enabled | | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 171 # **Interrupt Controller** ## Bit 7 - SENT1EIE SENT1 Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 6 - SENT1IE SENT1 TX/RX Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 5 - PTG3IE PTG3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 4 - PTG2IE PTG2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 3 - PTG1IE PTG1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 2 - PTG0IE PTG0 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 1 - PTGWDTIE PTG Watchdog Timer Time-out Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - CMP4IE Comparator 4 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## 7.7.20 Interrupt Enable Register 6 Name: IEC6 Offset: 0x82C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | ADCAN20IE | ADCAN19IE | ADCAN18IE | ADCAN17IE | ADCAN16IE | ADCAN15IE | ADCAN14IE | ADCAN13IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ADCAN12IE | ADCAN11IE | ADCAN10IE | ADCAN9IE | ADCAN8IE | ADCAN7IE | ADCAN6IE | ADCAN5IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - ADCAN20IE ADC AN20 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - ADCAN19IE ADC AN19 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 13 - ADCAN18IE ADC AN18 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 12 - ADCAN17IE ADC AN17 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - ADCAN16IE ADC AN16 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 10 - ADCAN15IE ADC AN15 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - ADCAN14IE ADC AN14 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 8 - ADCAN13IE ADC AN13 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 173 # **Interrupt Controller** ## Bit 7 - ADCAN12IE ADC AN12 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 6 - ADCAN11IE ADC AN11 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 5 - ADCAN10IE ADC AN10 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 4 - ADCAN9IE ADC AN9 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 3 - ADCAN8IE ADC AN8 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 2 - ADCAN7IE ADC AN7 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 1 - ADCAN6IE ADC AN6 Interrupt Enable bit | | 20 Attel 7 Ab 0 Atte International | |-------|------------------------------------| | Value | Description | | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - ADCAN5IE ADC AN5 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## 7.7.21 Interrupt Enable Register 7 Name: IEC7 Offset: 0x82E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|-------------|-------------|-------------|------------|------------|------------|------------| | | SPI2GIE | SPI1GIE | CLC2PIE | CLC1PIE | ADCFLTR4IE | ADCFLTR3IE | ADCFLTR2IE | ADCFLTR1IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ADCS1CMP3IE | ADCS1CMP2IE | ADCS1CMP1IE | ADCS1CMP0IE | ADCFLTIE | | | ADCAN21IE | | Access | R/W | R/W | R/W | R/W | R/W | | | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | | 0 | ## Bit 15 - SPI2GIE SPI2 Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - SPI1GIE SPI1 Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 13 - CLC2PIE CLC2 Positive Edge Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 12 - CLC1PIE CLC1 Positive Edge Interrupt Enable bit | | <u> </u> | |-------|-----------------------| | Value | Description | | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 11 - ADCFLTR4IE ADC Oversample Filter 4 Interrupt Enable bit | DIL II - F | Bit II - ADCI ETRAIL ADC Oversample Filter 4 Interrupt Enable bit | | |------------|-------------------------------------------------------------------|--| | Value | Description | | | 1 | Interrupt enabled | | | 0 | Interrupt not enabled | | #### Bit 10 - ADCFLTR3IE ADC Oversample Filter 3 Interrupt bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - ADCFLTR2IE ADC Oversample Filter 2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 8 - ADCFLTR1IE ADC Oversample Filter 1 Interrupt Enable bit | | The state of s | | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Value | Description | | | 1 | Interrupt enabled | | | 0 | Interrupt not enabled | | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 175 # **Interrupt Controller** ## Bit 7 - ADCS1CMP3IE ADC Digital Comparator 3 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 6 - ADCS1CMP2IE ADC Digital Comparator 2 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 5 - ADCS1CMP1IE ADC Digital Comparator 1 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 4 - ADCS1CMP0IE ADC Digital Comparator 0 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 3 - ADCFLTIE ADC Fault Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - ADCAN21IE ADC AN21 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | # **Interrupt Controller** # 7.7.22 Interrupt Enable Register 8 Name: IEC8 Offset: 0x830 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|---------|----|----|----|----|---|---------| | | MI2C3IE | SI2C3IE | | | | | | | | Access | R/W | R/W | | ). | | | , | | | Reset | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | SPI3GIE | | Access | | | | | | | | R/W | | Reset | | | | | | | | 0 | Bit 15 - MI2C3IE I2C3 Host Event Interrupt Enable bit | | INTEGRAL 1200 Floor Event Interrupt Emails of | |-------|-----------------------------------------------| | Value | Description | | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - SI2C3IE I2C3 Client Event Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 0 - SPI3GIE SPI3 Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | # 7.7.23 Interrupt Enable Register 9 Name: IEC9 Offset: 0x832 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|------|--------|----|--------|--------|-----------|----------| | | | | | | DMA7IE | DMA6IE | T8IE | IOC8IE | | Access | | | | 2 | R/W | R/W | R/W | R/W | | Reset | | | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ADCAN26IE | T7IE | IOC7IE | | | | ADCAN27IE | I2C3BCIE | | Access | R/W | R/W | R/W | | | | R/W | R/W | | Reset | 0 | 0 | 0 | | | | 0 | 0 | ## Bit 11 - DMA7IE Direct Memory Access 7 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 10 - DMA6IE Direct Memory Access 6 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - T8IE Timer8 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 8 - IOC8IE Interrupt-on-Change 8 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 7 - ADCAN26IE ADC AN26 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 6 - T7IE CCP7 (Timer7) Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 5 - IOC7IE Interrupt-on-Change 7 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 1 - ADCAN27IE ADC AN27 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | **Interrupt Controller** ## Bit 0 - I2C3BCIE I2C3 Bus Collision Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | 0 ## 7.7.24 Interrupt Enable Register 10 Name: IEC10 Offset: 0x834 Reset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|---------|---------|---------|---------|---------|----------|---| | | CLC3PIE | PEVTFIE | PEVTEIE | PEVTDIE | PEVTCIE | PEVTBIE | PEVTAIE | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | ADCC1EIE | | | Access | | | | | | | R/W | | Bit 15 - CLC3PIE CLC3 Positive Edge Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 14 - PEVTFIE PWM Event F Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 13 - PEVTEIE PWM Event E Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 12 - PEVTDIE PWM Event D Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - PEVTCIE PWM Event C Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 10 - PEVTBIE PWM Event B Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 9 - PEVTAIE PWM Event A Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## Bit 1 - ADCC1EIE ADC Enable 1 Interrupt Enable bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | **Interrupt Controller** #### Bit 1 - ADCC0EIE ADC Enable 0 Interrupt Enable bit | Value | Description | |-------|----------------------------| | 1 | Interrupt has occurred | | 0 | Interrupt has not occurred | ## 7.7.25 Interrupt Enable Register 11 Name: IEC11 Offset: 0x836 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|---------|---------|---------|---------|----|---------|---------| | | U3EVTIE | U2EVTIE | U1EVTIE | CMP6IE | CMP5IE | | | | | Access | R/W | R/W | R/W | R/W | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | CCT9IE | CCP9IE | CLC4NIE | CLC3NIE | | CLC1NIE | CLC2NIE | | Access | | R/W | R/W | R/W | R/W | | R/W | R/W | | Reset | | 0 | 0 | 0 | 0 | | 0 | 0 | #### Bit 15 - U3EVTIE UART3 Event Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 14 - U2EVTIE UART2 Event Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 13 - U1EVTIE UART1 Event Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ### Bit 12 - CMP6IE Comparator 6 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 11 - CMP5IE Comparator 5 Interrupt Enable bit | DIL II - C | Bit II - CMFSIC Comparator 5 interrupt chable bit | | | | |------------|---------------------------------------------------|--|--|--| | Value | Description | | | | | 1 | Interrupt enabled | | | | | 0 | Interrupt not enabled | | | | #### Bit 6 - CCT9IE Capture/Compare/Timer9 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 5 - CCP9IE Input Capture/Output Compare 9 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 4 - CLC4NIE CLC4 Negative Edge Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | © 2021 Microchip Technology Inc. and its subsidiaries ## **Interrupt Controller** #### Bit 3 - CLC3NIE CLC3 Negative Edge Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 1 - CLC1NIE CLC1 Negative Edge Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 0 - CLC2NIE CLC2 Negative Edge Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 0 - CLC4PIE CLC4 Positive Edge Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## **Interrupt Controller** ## 7.7.26 Interrupt Enable Register 12 Name: IEC12 Offset: 0x838 #### Bit 3 - PMPEIE Parallel Main Port External Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 2 - PMPIE Parallel Main Port Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 1 - ADCAN25IE ADC AN25 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | #### Bit 0 - ADCAN24IE ADC AN24 Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt enabled | | 0 | Interrupt not enabled | ## 7.7.27 Interrupt Priority Register 0 Name: IPC0 Offset: 0x840 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|------------|-----|----|-----|-------------|-----| | | | | CNBIP[2:0] | | | | CNAIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | T1IP[2:0] | | | | INT0IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - CNBIP[2:0] Change Notice B Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - CNAIP[2:0] Change Notice A Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - T1IPI2:01 Timer1 Interrupt Priority bits | The [2.0] Time of the orap of northy site | |-------------------------------------------| | Description | | Interrupt Priority Level 7 (highest) | | Interrupt Priority Level 6 | | Interrupt Priority Level 5 | | Interrupt Priority Level 4 (default) | | Interrupt Priority Level 3 | | Interrupt Priority Level 2 | | Interrupt Priority Level 1 | | Interrupt Priority Level 0 (lowest) | | | Bits 2:0 - INT0IP[2:0] External Interrupt 0 Interrupt Priority bits | DILO L.U | THE TOT [2.0] External interrupt of interrupt 1 flority bits | |----------|--------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.28 Interrupt Priority Register 1 Name: IPC1 Offset: 0x842 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | CCT1IP[2:0] | | | | CCP1IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | DMA0IP[2:0] | | | Access | | | | | | R/W | R/W | R/W | | Reset | | | | | | 1 | 0 | 0 | Bits 14:12 - CCT1IP[2:0] Capture/Compare/Timer1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - CCP1IP[2:0] Input Capture/Output Compare 1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - DMA0IP[2:0] Direct Memory Access 0 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.29 Interrupt Priority Register 2 Name: IPC2 Offset: 0x844 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|---------------|-----| | | | | U1RXIP[2:0] | | | | SPI1TXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SPI1RXIP[2:0] | | | | DMA1IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - U1RXIP[2:0] UART1 Receiver Interrupt Priority bits #### Bits 10:8 - SPI1TXIP[2:0] SPI1 Transfer Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## Bits 6:4 - SPI1RXIP[2:0] SPI1 Receiver Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - DMA1IP[2:0] Direct Memory Access 1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.30 Interrupt Priority Register 3 Name: IPC3 Offset: 0x846 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|--------------|-----|------|-----|-------------|-----| | | | | INT1IP[2:0] | | | | NVMIP[2:0] | | | Access | | R/W | R/W | R/W | **** | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ECCSBIP[2:0] | | | | U1TXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - INT1IP[2:0] External Interrupt 1 Priority bits | int in [and] External interrupt in them, site | | | | |-----------------------------------------------|--|--|--| | Description | | | | | Interrupt Priority Level 7 (highest) | | | | | Interrupt Priority Level 6 | | | | | Interrupt Priority Level 5 | | | | | Interrupt Priority Level 4 (default) | | | | | Interrupt Priority Level 3 | | | | | Interrupt Priority Level 2 | | | | | Interrupt Priority Level 1 | | | | | Interrupt Priority Level 0 (lowest) | | | | | | | | | #### Bits 10:8 - NVMIP[2:0] NVM Program/Erase Complete Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## Bits 6:4 - ECCSBIP[2:0] Error Correcting Code Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 2:0 - U1TXIP[2:0] UART1 Transmitter Interrupt Priority bits | | Transport forth framework from the first forth and | |-------|----------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.31 Interrupt Priority Register 4 Name: IPC4 Offset: 0x848 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|--------------|-----|----|-----|--------------|-----| | | | | CNCIP[2:0] | | | | DMA2IP[2:0] | | | Access | | R/W | R/W | R/W | * | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | MI2C1IP[2:0] | | | | SI2C1IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - CNCIP[2:0] Change Notification C Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - DMA2IP[2:0] Direct Memory Access 2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - MI2C1IP[2:0] I2C1 Host Events Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - SI2C1IP[2:0] I2C1 Client Events Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.32 Interrupt Priority Register 5 Name: IPC5 Offset: 0x84A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | CCP2IP[2:0] | | | | DMA4IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DMA3IP[2:0] | | | | INT2IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - CCP2IP[2:0] Input Capture/Output Compare 2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - DMA4IP[2:0] Direct Memory Access 4 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - DMA3IP[2:0] Direct Memory Access 3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - INT2IP[2:0] External Interrupt 2 Priority bits | Dito L.o | INTER [210] External interrupt 21 Hority bito | |----------|-----------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.33 Interrupt Priority Register 6 Name: IPC6 Offset: 0x84C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | U2RXIP[2:0] | | | | INT3IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | C1IP[2:0] | | | | CCT2IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - U2RXIP[2:0] UART2 Receiver Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - INT3IP[2:0] External Interrupt 3 Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - C1IPI2:01 CAN1 Combined Error Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CCT2IP[2:0] Capture/Compare/Timer2 Interrupt Priority bits | | The Late Compared times and the times and times and times and times and times and the compared times and a | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.34 Interrupt Priority Register 7 Name: IPC7 Offset: 0x84E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|---------------|-----| | | | | C1RXIP[2:0] | | | | SPI2TXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SPI2RXIP[2:0] | | | | U2TXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - C1RXIP[2:0] CAN1 RX Interrupt Priority bits | Description | |--------------------------------------| | Interrupt Priority Level 7 (highest) | | Interrupt Priority Level 6 | | Interrupt Priority Level 5 | | Interrupt Priority Level 4 (default) | | Interrupt Priority Level 3 | | Interrupt Priority Level 2 | | Interrupt Priority Level 1 | | Interrupt Priority Level 0 (lowest) | | | #### Bits 10:8 - SPI2TXIP[2:0] SPI2 Transmitter Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - SPI2RXIPI2:01 SPI2 Receiver Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 2:0 – U2TXIP[2:0] UART2 Transmitter Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.35 Interrupt Priority Register 8 Name: IPC8 Offset: 0x850 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | CCP3IP[2:0] | | | | DMA5IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | C2IP[2:0] | | | | C2RXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - CCP3IP[2:0] Input Capture/Output Compare 3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - DMA5IP[2:0] Direct Memory Access 5 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - C2IPI2:01 CAN2 Combined Error Interrupt Priority bits | | ear [are] of the combined error interrupt i nonty site | |-------|--------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - C2RXIP[2:0] CAN2 RX Interrupt Priority bits | | Caroni [are] Contact of interrupt indity site | |-------|-----------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.36 Interrupt Priority Register 9 Name: IPC9 Offset: 0x852 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|--------------|-----|----|-----|--------------|-----| | | | | | | | | MI2C2IP[2:0] | | | Access | | , | | | | R/W | R/W | R/W | | Reset | | | | | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SI2C2IP[2:0] | | | | CCT3IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 10:8 - MI2C2IP[2:0] Host I2C2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - SI2C2IP[2:0] Client I2C2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CCT3IP[2:0] Capture/Compare/Timer3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.37 Interrupt Priority Register 10 Name: IPC10 Offset: 0x854 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | CCP5IP[2:0] | | | | | | | Access | | R/W | R/W | R/W | | | | | | Reset | | 1 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CCT4IP[2:0] | | | | CCP4IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - CCP5IP[2:0] Input Capture/Output Compare 5 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - CCT4IP[2:0] Capture/Compare/Timer4 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CCP4IP[2:0] Input Capture/Output Compare 4 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.38 Interrupt Priority Register 11 Name: IPC11 Offset: 0x856 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | CCT6IP[2:0] | | | | CCP6IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DMTIP[2:0] | | | | CCT5IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - CCT6IP[2:0] Capture/Compare/Timer6 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - CCP6IP[2:0] Input Capture/Output Compare 6 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - DMTIP[2:0] Deadman Timer Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | value | | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CCT5IP[2:0] Capture/Compare/Timer5 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | 70005452B-page 206 ## 7.7.39 Interrupt Priority Register 12 Name: IPC12 Offset: 0x858 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|------------|-----|----|-----|-------------|-----| | | | | CRCIP[2:0] | | | | U2EIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | U1EIP[2:0] | | | | QEI1IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - CRCIP[2:0] Cyclic Redundancy Check Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - U2EIP[2:0] UART2 Error Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - U1EIP[2:0] UART1 Error Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - QEI1IP[2:0] QEI1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.40 Interrupt Priority Register 13 Name: IPC13 Offset: 0x85A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | | | | | QEI2IP[2:0] | | | Access | | , | | | | R/W | R/W | R/W | | Reset | | | | | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | C2TXIP[2:0] | | | | C1TXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 10:8 - QEI2IP[2:0] QEI2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - C2TXIP[2:0] CAN2 TX Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## Bits 2:0 - C1TXIP[2:0] CAN1 TX Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.41 Interrupt Priority Register 14 Name: IPC14 Offset: 0x85C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|-------------|-----| | | | | SPI3RXIP[2:0] | | | | U3TXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | U3RXIP[2:0] | | | | U3EIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - SPI3RXIP[2:0] SPI3 Receiver Interrupt Priority bits | | er letter [=10] or to reconver interrupt i honey blee | |-------|-------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | 400 | | #### Bits 10:8 - U3TXIP[2:0] UART3 Transmitter Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - U3RXIP[2:01 UART3 Receiver Priority bits | Bits 0.4 - OSICAIF [2.0] OAICTS Received 1 Hority bits | | | | | | |--------------------------------------------------------|--------------------------------------|--|--|--|--| | Value | Description | | | | | | 7 | Interrupt Priority Level 7 (highest) | | | | | | 6 | Interrupt Priority Level 6 | | | | | | 5 | Interrupt Priority Level 5 | | | | | | 4 | Interrupt Priority Level 4 (default) | | | | | | 3 | Interrupt Priority Level 3 | | | | | | 2 | Interrupt Priority Level 2 | | | | | | 1 | Interrupt Priority Level 1 | | | | | | 0 | Interrupt Priority Level 0 (lowest) | | | | | #### Bits 2:0 - U3EIP[2:0] UART3 External Interrupt Priority bits | | The Later and the External interrupt in the state of | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.42 Interrupt Priority Register 15 Name: IPC15 Offset: 0x85E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|----------------|-----|----|-----|---------------|-----| | | | | PTGSTEPIP[2:0] | l | | | | | | Access | | R/W | R/W | R/W | | | | | | Reset | | 1 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ICDIP[2:0] | | | | SPI3TXIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - PTGSTEPIP[2:0] PTG Step Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - ICDIP[2:0] ICD Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - SPI3TXIP[2:0] SPI3 Transfer Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.43 Interrupt Priority Register 16 Name: IPC16 Offset: 0x860 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|---------------|-----| | | | | PWM1IP[2:0] | | | | QEI3IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | I2C2BCIP[2:0] | | | | I2C1BCIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - PWM1IP[2:0] Pulse-Width Modulation 1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 10:8 - QEI3IP[2:0] QEI3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## Bits 6:4 - I2C2BCIP[2:0] I2C2 Bus Collision Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 2:0 - I2C1BCIP[2:0] I2C1 Bus Collision Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.44 Interrupt Priority Register 17 Name: IPC17 Offset: 0x862 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | PWM5IP[2:0] | | | | PWM4IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PWM3IP[2:0] | | | | PWM2IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - PWM5IP[2:0] Pulse-Width Modulation 5 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 10:8 - PWM4IP[2:0] Pulse-Width Modulation 4 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - PWM3IP[2:0] Pulse-Width Modulation 3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 2:0 - PWM2IP[2:0] Pulse-Width Modulation 2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.45 Interrupt Priority Register 18 Name: IPC18 Offset: 0x864 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | CNDIP[2:0] | | | | PWM8IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PWM7IP[2:0] | | | | PWM6IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - CNDIP[2:0] Change Notice D Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 10:8 - PWM8IP[2:0] Pulse-Width Modulation 8 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - PWM7IPI2:01 Pulse-Width Modulation 7 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - PWM6IP[2:0] Pulse-Width Modulation 6 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.46 Interrupt Priority Register 19 Name: IPC19 Offset: 0x866 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----------|-----|-------------|-----| | | | | CMP3IP[2:0] | | | | CMP2IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 0 | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CMP1IP[2:0] | | | | CNEIP[2:0] | | | Access | | R/W | R/W | R/W | <u> </u> | R/W | R/W | R/W | | Reset | | 0 | 0 | 0 | | 0 | 0 | 0 | Bits 14:12 - CMP3IP[2:0] Comparator 3 Interrupt Priority bits | emi en [210] comparator o interrupt i nortaj sito | |---------------------------------------------------| | Description | | Interrupt Priority Level 7 (highest) | | Interrupt Priority Level 6 | | Interrupt Priority Level 5 | | Interrupt Priority Level 4 (default) | | Interrupt Priority Level 3 | | Interrupt Priority Level 2 | | Interrupt Priority Level 1 | | Interrupt Priority Level 0 (lowest) | | | Bits 10:8 - CMP2IP[2:0] Comparator 2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - CMP1IP[2:0] Comparator 1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CNEIP[2:0] Change Notice E Interrupt Priority bits | DILS E.U | Cital [2:0] Change Notice & Interrupt I Hority bits | |----------|-----------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.47 Interrupt Priority Register 20 Name: IPC20 Offset: 0x868 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|-------------|-----| | | | | PTG1IP[2:0] | | | | PTG0IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PTGWDTIP[2:0] | ] | | | CMP4IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 0 | 0 | 0 | Bits 14:12 - PTG1IP[2:0] Peripheral Trigger Generator 1 Interrupt Priority bits | Term [210] Tempheral Higger Contractor Time Hapt Them, Site | |-------------------------------------------------------------| | Description | | Interrupt Priority Level 7 (highest) | | Interrupt Priority Level 6 | | Interrupt Priority Level 5 | | Interrupt Priority Level 4 (default) | | Interrupt Priority Level 3 | | Interrupt Priority Level 2 | | Interrupt Priority Level 1 | | Interrupt Priority Level 0 (lowest) | | | #### Bits 10:8 - PTG0IP[2:0] Peripheral Trigger Generator 0 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - PTGWDTIP[2:0] Watchdog Timer Time-out Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - CMP4IP[2:0] Comparator 4 Interrupt Priority bits | | om in [210] comparator i interrupt i field, site | |-------|--------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.48 Interrupt Priority Register 21 Name: IPC21 Offset: 0x86A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----|-----|---------------|-----|------|-----|--------------|-----|--| | | | | SENT1EIP[2:0] | | | | SENT1IP[2:0] | | | | Access | | R/W | R/W | R/W | **** | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PTG3IP[2:0] | | | | PTG2IP[2:0] | | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | Bits 14:12 - SENT1EIP[2:0] SENT1 External Interrupt Priority bits | | - Little | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | | Bits 10:8 - SENT1IP[2:0] SENT1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - PTG3IP[2:0] Peripheral Trigger Generator 3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 – PTG2IP[2:0] Peripheral Trigger Generator 2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.49 Interrupt Priority Register 22 Name: IPC22 Offset: 0x86C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|--------------|-----| | | | | ADCAN0IP[2:0] | | | | ADCIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SENT2EIP[2:0] | | | | SENT2IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | ### Bits 14:12 - ADCAN0IP[2:0] ADC AN0 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 10:8 - ADCIP[2:0] ADC Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 6:4 - SENT2EIP[2:0] SENT2 Error Interrupt Priority bits | | CENTILE [210] CENTE END INCOMPLY HOMY DIC | |-------|-------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - SENT2IP[2:0] SENT2 TX/RX Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### 7.7.50 **Interrupt Priority Register 23** Name: IPC23 Offset: 0x86E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|---------------|-----| | | | | ADCAN4IP[2:0] | | | | ADCAN3IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN2IP[2:0] | | | | ADCAN1IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | ### Bits 14:12 - ADCAN4IP[2:0] ADC AN4 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 10:8 - ADCAN3IP[2:0] ADC AN3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - ADCAN2IPI2:01 ADC AN2 Interrupt Priority bits | Dito C.T | TECTIVE INCOMES INCOME | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | | ### Bits 2:0 - ADCAN1IP[2:0] ADC AN1 Interrupt Priority bits | Dito L. | TID OTHER [210] TIDO THE INCOMPLET HORRY BILD | |---------|-----------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.51 Interrupt Priority Register 24 Name: IPC24 Offset: 0x870 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-----------------------------|-----|----|-----|---------------|-----| | | | | ADCAN8IP[2:0] | | | | ADCAN7IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN6IP[2:0] ADCAN5IP[2:0] | | | | | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | ### Bits 14:12 - ADCAN8IP[2:0] ADC AN8 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 10:8 - ADCAN7IP[2:0] ADC AN7 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - ADCAN6IP[2:0] ADC AN6 Interrupt Priority bits | DIG U.T | ABOARTON [2:0] ABOARTO Interrupt Friends Site | |---------|-----------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | | ### Bits 2:0 - ADCAN5IP[2:0] ADC AN5 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.52 Interrupt Priority Register 25 Name: IPC25 Offset: 0x872 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|----------------|-----|----|-----|----------------|-----| | | | | ADCAN12IP[2:0 | ] | | | ADCAN11IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN10IP[2:0] | ] | | | ADCAN9IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | ### Bits 14:12 - ADCAN12IP[2:0] ADC AN12 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 10:8 - ADCAN11IP[2:0] ADC AN11 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - ADCAN10IP[2:01 ADC AN10 Interrupt Priority bits | Dito U.T | ABOTATOR [2.0] ABOTATO Interrupt Priority Site | |----------|------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | | ### Bits 2:0 - ADCAN9IP[2:0] ADC AN9 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.53 Interrupt Priority Register 26 Name: IPC26 Offset: 0x874 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----------|-----|---------------|-----| | | | | ADCAN16IP[2:0 | ] | | | ADCAN15IP[2:0 | ] | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN14IP[2:0 | ] | | | ADCAN13IP[2:0 | ] | | Access | | R/W | R/W | R/W | <u> </u> | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - ADCAN16IP[2:0] ADC AN16 Interrupt Priority bits | | The state of s | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | 1 | #### Bits 10:8 - ADCAN15IP[2:0] ADC AN15 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 6:4 - ADCAN14IP[2:0] ADC AN14 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - ADCAN13IP[2:0] ADC AN13 Interrupt Priority bits | | The station [210] The office more april more, sale | |-------|----------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.54 Interrupt Priority Register 27 Name: IPC27 Offset: 0x876 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|----------------|-----|----|-----|----------------|-----| | | | | ADCAN20IP[2:0 | ] | | | ADCAN19IP[2:0] | ] | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN18IP[2:0] | ] | | | ADCAN17IP[2:0] | ] | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | ### Bits 14:12 - ADCAN20IP[2:0] ADC AN20 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 10:8 - ADCAN19IP[2:0] ADC AN19 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 6:4 - ADCAN18IP[2:0] ADC AN18 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - ADCAN17IP[2:0] ADC AN17 Interrupt Priority bits | Dito L. | TID GET THE LEGIT TO CONTROL THOMAS BILD | |---------|------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.55 Interrupt Priority Register 28 Name: IPC28 Offset: 0x878 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|------|-----|---------------|-----| | | | | ADFLTIP[2:0] | | | | ADCAN23IP[2:0 | ] | | Access | | R/W | R/W | R/W | **** | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN22IP[2:0 | ] | | | ADCAN21IP[2:0 | ] | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - ADFLTIP[2:0] ADC Fault Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - ADCAN23IP[2:0] ADC AN23 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - ADCAN22IP[2:0] ADC AN22 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - ADCAN21IP[2:0] ADC AN21 Interrupt Priority bits | DILO L.U | ABOART [2:0] ABO ARE I Interrupt I northy bits | |----------|------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.56 Interrupt Priority Register 29 Name: IPC29 Offset: 0x87A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|---------------|-----| | | | | ADCMP3IP[2:0] | | | | ADCMP2IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCMP1IP[2:0] | | | | ADCMP0IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - ADCMP3IP[2:0] ADC Digital Comparator 3 Interrupt Priority bits | Description | |--------------------------------------| | Interrupt Priority Level 7 (highest) | | Interrupt Priority Level 6 | | Interrupt Priority Level 5 | | Interrupt Priority Level 4 (default) | | Interrupt Priority Level 3 | | Interrupt Priority Level 2 | | Interrupt Priority Level 1 | | Interrupt Priority Level 0 (lowest) | | | #### Bits 10:8 - ADCMP2IP[2:0] ADC Digital Comparator 2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - ADCMP1IP[2:0] ADC Digital Comparator 1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - ADCMP0IP[2:0] ADC Digital Comparator 0 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.57 Interrupt Priority Register 30 Name: IPC30 Offset: 0x87C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|-----------------------------------------|-----|----------------|-----| | | | A | DCFLTR3IP[2:0 | 0] | | , | ADCFLTR2IP[2:0 | )] | | Access | | R/W | R/W | R/W | *************************************** | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | A | DCFLTR1IP[2:0 | 0] | | , | ADCFLTR0IP[2:0 | )] | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - ADCFLTR3IP[2:0] ADC Oversample Filter 3 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 10:8 - ADCFLTR2IP[2:0] ADC Oversample Filter 2 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - ADCFLTR1IPI2:01 ADC Oversample Filter 1 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 2:0 - ADCFLTR0IP[2:0] ADC Oversample Filter 0 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.58 Interrupt Priority Register 31 Name: IPC31 Offset: 0x87E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----|-----|--------------|-----|----|-------------|--------------|-----|--| | | | | SPI2IP[2:0] | | | SPI1IP[2:0] | | | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | CLC2PIP[2:0] | | | | CLC1PIP[2:0] | | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | Bits 14:12 - SPI2IP[2:0] SPI2 Error Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - SPI1IP[2:0] SPI1 Error Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - CLC2PIP[2:0] CLC2 Positive Edge Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CLC1PIP[2:0] CLC1 Positive Edge Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### **Interrupt Controller** ### 7.7.59 Interrupt Priority Register 32 Name: IPC32 Offset: 0x880 Bits 2:0 - SPI3IP[2:0] SPI3 Error Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### **Interrupt Controller** ### 7.7.60 Interrupt Priority Register 35 Name: IPC35 Offset: 0x886 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|--------------|-----|----|-----|--------------|-----| | | | | MI2C3IP[2:0] | | | | SI2C3IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset Bits 14:12 - MI2C3IP[2:0] I2C3 Host Event Interrupt Priority bits | | miles [2.6] iles instantination printing | |-------|------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | | Bits 10:8 - SI2C3IP[2:0] I2C3 Client Event Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### **Interrupt Controller** ### 7.7.61 Interrupt Priority Register 36 Name: IPC36 Offset: 0x888 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|----|-----|----------------|-----|----|-----|---------------|-----| | Access<br>Reset | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN27IP[2:0] | | | | I2C3BCIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Poset | | 1 | n | 0 | | 1 | n | 0 | Bits 6:4 - ADCAN27IP[2:0] ADC AN27 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - I2C3BCIP[2:0] I2C3 Bus Collision Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.62 Interrupt Priority Register 37 Name: IPC37 Offset: 0x88A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|----------------|-----|----|-----|-------------|-----| | | | | ADCAN26IP[2:0] | ] | | | CCT7IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CCP7IP[2:0] | | | | | | | Access | | R/W | R/W | R/W | | | | | | Reset | | 1 | 0 | 0 | | | | | ### Bits 14:12 - ADCAN26IP[2:0] ADC AN26 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### Bits 10:8 - CCT7IP[2:0] Capture/Compare/Timer7 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - CCP7IP[2:0] Input Capture/Output Compare 7 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.63 Interrupt Priority Register 38 Name: IPC38 Offset: 0x88C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-------------|-----|----|-----|-------------|-----| | | | | DMA7IP[2:0] | | | | DMA6IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CCT8IP[2:0] | | | | CCP8IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - DMA7IP[2:0] Direct Memory Access 7 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - DMA6IP[2:0] Direct Memory Access 6 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - CCT8IP[2:0] Capture/Compare/Timer8 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CCP8IP[2:0] Input Capture/Output Compare 8 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.64 Interrupt Priority Register 42 Name: IPC42 Offset: 0x894 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|--------------|-----|----|-----|--------------|-----| | | | | PEVTCIP[2:0] | | | | PEVTBIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PEVTAIP[2:0] | | | | | | | Access | | R/W | R/W | R/W | | | | | | Reset | | 1 | 0 | 0 | | | | | Bits 14:12 - PEVTCIP[2:0] PWM Event C Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 10:8 - PEVTBIP[2:0] PWM Event B Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - PEVTAIP[2:0] PWM Event A Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ### 7.7.65 Interrupt Priority Register 43 Name: IPC43 Offset: 0x896 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|--------------|-----| | | | | CLC3PEIP[2:0] | | | | PEVTFIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PEVTEIP[2:0] | | | | PEVTDIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | #### Bits 14:12 - CLC3PEIP[2:0] CLC3 Positive Edge Interrupt Priority bits | | The control and an | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | | ### Bits 10:8 - PEVTFIP[2:0] PWM Event F Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - PEVTEIPI2:01 PWM Event E Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 2:0 - PEVTDIP[2:0] PWM Event D Interrupt Priority bits | | 1 = 1 = 1 [ 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | |-------|-----------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.66 Interrupt Priority Register 44 Name: IPC44 Offset: 0x898 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----|---------------|---------------|-----|-----------------------------------------|---------------|---------------|-----|--| | | | CLC3NEIP[2:0] | | | | CLC2NEIP[2:0] | | | | | Access | | R/W | R/W | R/W | *************************************** | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | CLC1NEIP[2:0] | | | | CLC4PEIP[2:0] | | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | #### Bits 14:12 - CLC3NEIP[2:0] CLC3 Negative Edge Interrupt Priority bits #### Bits 10:8 - CLC2NEIP[2:0] CLC2 Negative Edge Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 6:4 - CLC1NEIPI2:01 CLC1 Negative Edge Interrupt Priority bits | DIG U.T | Zernen [2:0] Geor Negativo Eago interrupt i nonty site | |---------|--------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | | | | #### Bits 2:0 - CLC4PEIP[2:0] CLC4 Positive Edge Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | # Interrupt Controller | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | # 7.7.67 Interrupt Priority Register 45 Name: IPC45 Offset: 0x89A Bits 10:8 - CCT9IP[2:0] Capture/Compare/Timer9 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 6:4 - CCP9IP[2:0] Input Capture/Output Compare 9 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | Bits 2:0 - CLC4NEIP[2:0] CLC4 Negative Edge Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | # Interrupt Controller # 7.7.68 Interrupt Priority Register 46 Name: IPC46 Offset: 0x89C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|----|-----|-------------|-----|----|----|---|---| | | | | CMP5IP[2:0] | | | | | | | Access<br>Reset | | R/W | R/W | R/W | | | | | | Reset | | 1 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset Bits 14:12 - CMP5IP[2:0] Comparator 5 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | ## 7.7.69 Interrupt Priority Register 47 Name: IPC47 Offset: 0x89E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----|--------------|--------------|-----|------|--------------|-------------|-----|--| | | | U3EVTIP[2:0] | | | | U2EVTIP[2:0] | | | | | Access | | R/W | R/W | R/W | **** | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | U1EVTIP[2:0] | | | | CMP6IP[2:0] | | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | Bits 14:12 - U3EVTIP[2:0] UART3 Event Interrupt Priority bits Bits 10:8 - U2EVTIP[2:0] UART2 Event Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | # Bits 6:4 - U1EVTIP[2:0] UART1 Event Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | # Bits 2:0 - CMP6IP[2:0] Comparator 6 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | # Interrupt Controller | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | # 7.7.70 Interrupt Priority Register 48 Name: IPC48 Offset: 0x89E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|---------------|-----|----|-----|----------------|-----| | | | | PMPEIP[2:0] | | | | PMPIP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADCAN25IP[2:0 | ] | | | ADCAN24IP[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 1 | 0 | 0 | | 1 | 0 | 0 | Bits 14:12 - PMPEIP[2:0] Parallel Main Port External Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 10:8 - PMPIP[2:0] Parallel Main Port Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | # Bits 6:4 - ADCAN25IP[2:0] ADC AN25 Interrupt Priority bits | Value | Description | |-------|--------------------------------------| | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | #### Bits 2:0 - ADCAN24IP[2:0] ADC AN24 Interrupt Priority bits | Dito L. | The Three Th | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 7 | Interrupt Priority Level 7 (highest) | | 6 | Interrupt Priority Level 6 | | 5 | Interrupt Priority Level 5 | | 4 | Interrupt Priority Level 4 (default) | | 3 | Interrupt Priority Level 3 | # **Interrupt Controller** | Value | Description | |-------|-------------------------------------| | 2 | Interrupt Priority Level 2 | | 1 | Interrupt Priority Level 1 | | 0 | Interrupt Priority Level 0 (lowest) | # **Interrupt Controller** # 7.7.71 CPU STATUS Register Name: SR Offset: 0x42 #### Notes: 1. The IPL[2:0] bits are concatenated with the IPL[3] bit (CORCON[3]) to form the CPU Interrupt Priority Level. The value in parentheses indicates the IPL, if IPL[3] = 1. User interrupts are disabled when IPL[3] = 1. 2. The IPL[2:0] Status bits are read-only when the NSTDIS bit (INTCON1[15]) = 1. #### Legend: C = Clearable bit Bits 7:5 - IPL[2:0] CPU Interrupt Priority Level Status bits(1,2) | Value | Description | |-------|----------------------------------------------------------------------| | 111 | CPU Interrupt Priority Level is 7 (15); user interrupts are disabled | | 110 | CPU Interrupt Priority Level is 6 (14) | | 101 | CPU Interrupt Priority Level is 5 (13) | | 100 | CPU Interrupt Priority Level is 4 (12) | | 011 | CPU Interrupt Priority Level is 3 (11) | | 010 | CPU Interrupt Priority Level is 2 (10) | | 001 | CPU Interrupt Priority Level is 1 (9) | | 000 | CPU Interrupt Priority Level is 0 (8) | # **Interrupt Controller** # 7.7.72 Core Control Register Name: CORCON Offset: 0x44 #### Note: 1. The IPL3 bit is concatenated with the IPL[2:0] bits (SR[7:5]) to form the CPU Interrupt Priority Level. Legend: C = Clearable bit Bit 15 - VAR Variable Exception Processing Latency Control bit | Value | Description | |-------|------------------------------------------| | 1 | Variable exception processing is enabled | | 0 | Fixed exception processing is enabled | #### Bit 3 - IPL3 CPU Interrupt Priority Level Status bit 3(1) | Value | Description | |-------|------------------------------------------------| | 1 | CPU Interrupt Priority Level is greater than 7 | | 0 | CPU Interrupt Priority Level is 7 or less | ## 7.7.73 Interrupt Control Register 1 Name: INTCON1 Offset: 0x8C0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|---------|--------|---------|---------|--------|---------|-------| | | NSTDIS | OVAERR | OVBERR | COVAERR | COVBERR | OVATE | OVBTE | COVTE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SFTACERR | DIV0ERR | | MATHERR | ADDRERR | STKERR | OSCFAIL | | | Access | R/W | R/W | | R/W | R/W | R/W | R/W | | | Reset | 0 | 0 | | 0 | 0 | 0 | 0 | | #### Bit 15 - NSTDIS Interrupt Nesting Disable bit | Value | Description | |-------|-------------------------------| | 1 | Interrupt nesting is disabled | | 0 | Interrupt nesting is enabled | #### Bit 14 - OVAERR Accumulator A Overflow Trap Flag bit | Value | Description | |-------|--------------------------------------------------| | 1 | Trap was caused by overflow of Accumulator A | | 0 | Trap was not caused by overflow of Accumulator A | #### Bit 13 - OVBERR Accumulator B Overflow Trap Flag bit | Value | Description | |-------|--------------------------------------------------| | 1 | Trap was caused by overflow of Accumulator B | | 0 | Trap was not caused by overflow of Accumulator B | ## Bit 12 - COVAERR Accumulator A Catastrophic Overflow Trap Flag bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Trap was caused by catastrophic overflow of Accumulator A | | 0 | Trap was not caused by catastrophic overflow of Accumulator A | #### Bit 11 - COVBERR Accumulator B Catastrophic Overflow Trap Flag bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Trap was caused by catastrophic overflow of Accumulator B | | 0 | Trap was not caused by catastrophic overflow of Accumulator B | #### Bit 10 - OVATE Accumulator A Overflow Trap Enable bit | Value | Description | |-------|--------------------------------| | 1 | Trap overflow of Accumulator A | | 0 | Trap is disabled | #### Bit 9 - OVBTE Accumulator B Overflow Trap Enable bit | Dit 5 - C | Bit 3 - CVBTE Accumulator B Overnow Trap Enable bit | | | | | |-----------|-----------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | Trap overflow of Accumulator B | | | | | | 0 | Trap is disabled | | | | | #### Bit 8 - COVTE Catastrophic Overflow Trap Enable bit | Value | Description | |-------|----------------------------------------------------------------| | 1 | Trap on catastrophic overflow of Accumulator A or B is enabled | | 0 | Trap is disabled | © 2021 Microchip Technology Inc. Datasheet and its subsidiaries # **Interrupt Controller** #### Bit 7 - SFTACERR Shift Accumulator Error Status bit | Value | Description | |-------|----------------------------------------------------------------| | 1 | Math error trap was caused by an invalid accumulator shift | | 0 | Math error trap was not caused by an invalid accumulator shift | ## Bit 6 - DIV0ERR Divide-by-Zero Error Status bit | Value | Description | | | | |-------|----------------------------------------------------|--|--|--| | 1 | Math error trap was caused by a divide-by-zero | | | | | 0 | Math error trap was not caused by a divide-by-zero | | | | #### Bit 4 - MATHERR Math Error Status bit | Value | Description | |-------|----------------------------------| | 1 | Math error trap has occurred | | 0 | Math error trap has not occurred | #### Bit 3 - ADDRERR Address Error Trap Status bit | Value | Description | |-------|-------------------------------------| | 1 | Address error trap has occurred | | 0 | Address error trap has not occurred | #### Bit 2 - STKERR Stack Error Trap Status bit | Value | Description | |-------|-----------------------------------| | 1 | Stack error trap has occurred | | 0 | Stack error trap has not occurred | #### Bit 1 - OSCFAIL Oscillator Failure Trap Status bit | Value | Description | |-------|------------------------------------------| | 1 | Oscillator failure trap has occurred | | 0 | Oscillator failure trap has not occurred | # **Interrupt Controller** ## 7.7.74 Interrupt Control Register 2 Name: INTCON2 Offset: 0x8C2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|------|--------|----|--------|--------|--------|--------| | | GIE | DISI | SWTRAP | | | | | | | Access | R/W | R/W | R/W | | | >- | , | | | Reset | 1 | 0 | 0 | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | INT3EP | INT2EP | INT1EP | INT0EP | | Access | | | | | R/W | R/W | R/W | R/W | | Reset | | | | | 0 | 0 | 0 | 0 | #### Bit 15 - GIE Global Interrupt Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Interrupts and associated IE bits are enabled | | 0 | Interrupts are disabled, but traps are still enabled | #### Bit 14 - DISI DISI Instruction Status bit | Value | Description | |-------|--------------------------------| | 1 | DISI instruction is active | | 0 | DISI instruction is not active | #### Bit 13 - SWTRAP Software Trap Status bit | Value | Description | |-------|---------------------------| | 1 | Software trap is enabled | | 0 | Software trap is disabled | #### Bit 3 - INT3EP External Interrupt 3 Edge Detect Polarity Select bit | Value | Description | |-------|----------------------------| | 1 | Interrupt on negative edge | | 0 | Interrupt on positive edge | #### Bit 2 - INT2EP External Interrupt 2 Edge Detect Polarity Select bit | Value | Description | |-------|----------------------------| | 1 | Interrupt on negative edge | | 0 | Interrupt on positive edge | #### Bit 1 - INT1EP External Interrupt 1 Edge Detect Polarity Select bit | Value | Description | |-------|----------------------------| | 1 | Interrupt on negative edge | | 0 | Interrupt on positive edge | #### Bit 0 - INT0EP External Interrupt 0 Edge Detect Polarity Select bit | | | • | | |-------|----------------------------|---|--| | Value | Description | | | | 1 | Interrupt on negative edge | | | | 0 | Interrupt on positive edge | | | # **Interrupt Controller** # 7.7.75 Interrupt Control Register 3 Name: INTCON3 Offset: 0x8C4 #### Bit 8 - NAE NVM Address Error Soft Trap Status bit | Value | Description | |-------|----------------------------------------------| | 1 | NVM address error soft trap has occurred | | 0 | NVM address error soft trap has not occurred | #### Bit 4 - DOOVR DO Stack Overflow Soft Trap Status bit | Value | Description | |-------|----------------------------------------------| | 1 | DO stack overflow soft trap has occurred | | 0 | DO stack overflow soft trap has not occurred | ## Bit 0 - APLL Auxiliary PLL Loss of Lock Soft Trap Status bit | Value | Description | |-------|--------------------------------------| | 1 | APLL lock soft trap has occurred | | 0 | APLL lock soft trap has not occurred | # **Interrupt Controller** # 7.7.76 Interrupt Control Register 4 Name: INTCON4 Offset: 0x8C6 #### Bit 1 - ECCDBE ECC Double-Bit Error Trap bit | Value | Description | |-------|--------------------------------------------| | 1 | ECC double-bit error trap has occurred | | 0 | ECC double-bit error trap has not occurred | #### Bit 0 - SGHT Software Generated Hard Trap Status bit | Value | Description | |-------|-----------------------------------------------| | 1 | Software generated hard trap has occurred | | 0 | Software generated hard trap has not occurred | # 7.7.77 Interrupt Control and Status Register Name: INTTREG Offset: 0x8C8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-------|-------|---------|------|------|---| | | | | VHOLD | | | ILR[ | 3:0] | | | Access | | | R | | R | R | R | R | | Reset | | | 0 | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | VECNU | JM[7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 13 - VHOLD Vector Number Capture Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | VECNUM[7:0] bits read current value of vector number encoding tree (i.e., highest priority pending | | | interrupt) | | 0 | Vector number latched into VECNUM[7:0] at Interrupt Acknowledge and retained until next IACK | Bits 11:8 - ILR[3:0] New CPU Interrupt Priority Level bits | Value | Description | |-------|------------------------------------| | 1111 | CPU Interrupt Priority Level is 15 | | | | | 0001 | CPU Interrupt Priority Level is 1 | | 0000 | CPU Interrupt Priority Level is 0 | Bits 7:0 – VECNUM[7:0] Vector Number of Pending Interrupt bits | Value | Description | |----------|--------------------------------| | 11111111 | 255, Reserved; do not use | | | | | 00001001 | 9, IC1 – Input Capture 1 | | 00001000 | 8, INT0 – External Interrupt 0 | | 00000111 | 7, Reserved; do not use | | 00000110 | 6, Generic soft error trap | | 00000101 | 5, Reserved; do not use | | 00000100 | 4, Math error trap | | 00000011 | 3, Stack error trap | | 00000010 | 2, Generic hard trap | | 00000001 | 1, Address error trap | | 0000000 | 0, Oscillator fail trap | ## 8. I/O Ports **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive source. To complement the information in this data sheet, refer to "I/O Ports with Edge Detect" (www.microchip.com/DS70005322) in the "dsPIC33/PIC24 Family Reference Manual". Many of the device pins are shared among the peripherals and the Parallel I/O ports. All I/O input ports feature Schmitt Trigger inputs for improved noise immunity. Some of the key features of the I/O ports are: - · 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 ## 8.1 Parallel I/O (PIO) Ports All port pins have 12 registers directly associated with their operation as digital I/Os. 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. Any bit and its associated data and control registers that are not valid for a particular device are disabled. This means the corresponding LATx and TRISx registers, and the port pin are read as zeros. When a pin is shared with another peripheral or function that is defined as an input only, it is nevertheless regarded as a dedicated port because there is no other competing source of outputs. Table 8-1 shows the pin availability. Figure 8-1 shows the 5V input tolerant pins across this device. Table 8-1. Pin and ANSELx Availability | Device | Rx15 | Rx14 | Rx13 | Rx12 | Rx11 | Rx10 | Rx9 | Rx8 | Rx7 | Rx6 | Rx5 | Rx4 | Rx3 | Rx2 | Rx1 | Rx0 | |-----------------------|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | PORTA | | | | | | | | | | | | | | | | | | dsPIC33CKXXXMP608/308 | - | - | _ | _ | - | _ | - | 1-1 | _ | - | _ | X | X | х | × | X | | dsPIC33CKXXXMP606/306 | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | X | X | Х | X | X | | dsPIC33CKXXXMP605/305 | _ | _ | _ | _ | _ | _ | _ | - | - | _ | _ | Х | X | Х | X | Х | | ANSELA | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | Х | X | Х | X | Х | | | | | | | Р | ORTB | | | | | | | | | | | | dsPIC33CKXXXMP608/308 | X | Х | Х | X | х | Х | X | X | X | X | X | Х | X | X | X | X | | dsPIC33CKXXXMP606/306 | X | Х | Х | Х | X | Х | Х | X | Х | X | X | X | X | Х | Х | X | | dsPIC33CKXXXMP605/305 | X | Х | Х | X | Х | Х | X | X | X | X | X | X | X | х | X | X | | ANSELB | - | _ | - | _ | - | _ | Х | Х | Х | _ | - | X | X | Х | Х | Х | | | | | | | Р | ORTC | | | | | | | | | | | | dsPIC33CKXXXMP608/308 | X | Х | Х | X | X | Х | Х | X | X | X | X | X | X | Х | X | X | | dsPIC33CKXXXMP606/306 | X | Х | Х | Х | х | Х | Х | Х | Х | X | X | X | X | X | Х | X | | dsPIC33CKXXXMP605/305 | _ | _ | X | X | Х | Х | Х | Х | X | X | X | X | X | Х | Х | Х | | ANSELC | - | _ | - | _ | _ | _ | _ | _ | X | X | _ | _ | Х | Х | Х | X | | | | | | | Р | ORTD | | | | | | | | | | | | dsPIC33CKXXXMP608/308 | X | X | Х | X | х | Х | Х | Х | X | X | Х | Х | X | Х | Х | X | | dsPIC33CKXXXMP606/306 | X | Х | Х | Х | X | Х | Х | Х | Х | Х | Х | Х | X | X | Х | X | Figure 8-1. Block Diagram of a Typical Shared Port Structure #### 8.1.1 Open-Drain Configuration In addition to the PORTx, LATx and TRISx registers for data control, port pins can also be individually configured for either digital or open-drain output. This is controlled by the Open-Drain Enable for PORTx 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, other than $V_{DD}$ , by using external pull-up resistors. The maximum open-drain voltage allowed on any pin is the same as the maximum $V_{IH}$ specification for that particular pin. ## 8.2 Configuring Analog and Digital Port Pins The ANSELx registers control the operation of the analog port pins. The port pins that are to function as analog inputs or outputs must have their corresponding ANSELx and TRISx 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 registers have a default value of 0xFFFF; therefore, all pins that share analog functions are analog (not digital) by default. Pins with analog functions affected by the ANSELx registers are listed with a buffer type of analog in the Pinout I/O Descriptions (see 1. Device Overview). If the TRISx bit is cleared (output) while the ANSELx bit is set, the digital output level ( $V_{OH}$ or $V_{OL}$ ) is converted by an analog peripheral, such as the ADC module or comparator module. When the PORTx 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. #### 8.2.1 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 a NOP. # 8.2.2 Port Controls/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |---------|-------------------------------------------|-------------|------------|-------------|---|-----|------------------------|---|---|---|--|--|--| | 0,0500 | ANCELA | 15:8 | | | | ANS | ELx[15:8] | | | | | | | | 0x0E00 | ANSELA | 7:0 | | | | ANS | SELx[7:0] | | | | | | | | 0x0E02 | TRISA | 15:8 | | | | TR | ISA[15:8] | | | | | | | | UXULUZ | TRIOA | 7:0 | TRISA[7:0] | | | | | | | | | | | | 0x0E04 | PORTA | 15:8 | | PORTA[15:8] | | | | | | | | | | | UNULUT | TORTA | 7:0 | | | | | RTA[7:0] | | | | | | | | 0x0E06 | LATA | 15:8 | | LATx[15:8] | | | | | | | | | | | 0,0200 | | 7:0 | | LATx[7:0] | | | | | | | | | | | 0x0E08 | ODCA | 15:8 | | | | | CA[15:8] | | | | | | | | 2100-20 | (Allender) | 7:0 | | ODCA[7:0] | | | | | | | | | | | 0x0E0A | CNPUA | 15:8 | | | | | PUA[15:8] | | | | | | | | | | 7:0 | | | | | PUA[7:0] | | | | | | | | 0x0E0C | CNPDA | 15:8 | | | | | PDA[15:8] | | | | | | | | 10.000 | 1.00 St. 10000 (\$1,1250 No. | 7:0 | 1-100 | | | CN | PDA[7:0] | | | | | | | | 0x0E0E | CNCONA | 15:8 | ON | | | | CNSTYLE | | | | | | | | | | 7:0 | | | | | | | | | | | | | 0x0E10 | CNEN0A | 15:8 | | | | | N0A[15:8] | | | | | | | | | Contract of the | 7:0 | | | | | ENOA[7:0] | | | | | | | | 0x0E12 | CNSTATA | 15:8<br>7:0 | | | | | TATx[15:8] | | | | | | | | | | 15:8 | | | | | STATx[7:0] | | | | | | | | 0x0E14 | CNEN1A | 7:0 | | | | | N1A[15:8] | | | | | | | | | | 15:8 | | | | | EN1A[7:0]<br>IFA[15:8] | | | | | | | | 0x0E16 | CNFA | 7:0 | | | | CN | NFA[7:0] | | | | | | | | 0x0E18 | | 7.0 | | | | Ci | NFA[7.0] | | T | | | | | | | Reserved | | | | | | | | | | | | | | 0x0E1B | Neserveu | | | | | | | | | | | | | | 0x0E1C | ANSELB | 15:8 | | | | | ELB[15:8] | | | | | | | | UNULIU | , (3222 | 7:0 | | | | | SELB[7:0] | | | | | | | | 0x0E1E | TRISB | 15:8 | | | | | ISB[15:8] | | | | | | | | | | 7:0 | | | | | ISB[7:0] | | | | | | | | 0x0E20 | PORTB | 15:8 | | | | | RTB[15:8] | | | | | | | | | 1. T. | 7:0 | | | | | RTB[7:0] | | | | | | | | 0x0E22 | LATB | 15:8 | | | | | TB[15:8] | | | | | | | | | 3 3000 5 300 300 | 7:0 | | | | | ATB[7:0] | | | | | | | | 0x0E24 | ODCB | 15:8 | | | | | CB[15:8] | | | | | | | | | | 7:0 | | | | | OCB[7:0] | | | | | | | | 0x0E26 | CNPUB | 15:8 | | | | | PUB[15:8] | | | | | | | | | Mary Come | 7:0 | | | | | PUB[7:0] | | | | | | | | 0x0E28 | CNPDB | 15:8 | | | | | PDB[15:8] | | | | | | | | | | 7:0 | O.1. | | | CN | PDB[7:0] | | | | | | | | 0x0E2A | CNCONB | 15:8 | ON | | | | CNSTYLE | | | | | | | | | | 7:0 | | | | | | | | | | | | | 0x0E2C | CNEN0B | 15:8 | | | | | N0B[15:8] | | | | | | | | | | 7:0 | | | | | EN0B[7:0] | | | | | | | | 0x0E2E | CNSTATB | 15:8 | | | | | TATD[15:8] | | | | | | | | | | 7:0 | | | | | TATB[7:0] | | | | | | | | 0x0E30 | CNEN1B | 15:8 | | | | | N1B[15:8] | | | | | | | | | | 7:0 | | | | | EN1B[7:0] | | | | | | | | 0x0E32 | CNFB | 15:8 | | | | | FB[15:8] | | | | | | | | | | 7:0 | | | | | NFB[7:0] | | | | | | | | 0x0E34 | TRISC | 15:8 | | | | | ISC[15:8] | | | | | | | | 00500 | | 7:0 | | | | TR | ISC[7:0] | | | | | | | | 0x0E36 | Reserved | | | | | | | | | | | | | | 0x0E37 | | | | | | | | | | | | | | | contir | nued | | | | | | | | | | | |--------|-----------------------------------------|-------------|----|---------------------------|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Offset | Name | | | • | 5 | | | | 1 | | | | 0x0E38 | ANSELC | 15:8<br>7:0 | | ANSELC[15:8] ANSELC[7:0] | | | | | | | | | 0x0E3A | | | | | | | | | | | | | 0x0E3B | Reserved | | | | | | | | | | | | 0x0E3C | PORTC | 15:8 | | | | POF | TC[15:8] | | | | | | OXOLOG | TORTO | 7:0 | | PORTC[7:0] | | | | | | | | | 0x0E3E | LATC | 15:8 | | | | | C[15:8] | | | | | | | | 7:0 | | | | | TC[7:0] | | | | | | 0x0E40 | ODCC | 15:8 | | ODCx[15:8] | | | | | | | | | | | 7:0<br>15:8 | | | | | PUx[15:8] | | | | | | 0x0E42 | CNPUC | 7:0 | | | | | PUx[7:0] | | | | | | | | 15:8 | | | | | PDx[15:8] | | | | | | 0x0E44 | CNPDC | 7:0 | | | | | Dx[7:0] | | | | | | | 15:8 ON CNSTYLE | | | | | | | | | | | | 0x0E46 | CNCONC | 7:0 | | | | | The state of s | | | | | | 0.0540 | ONENGO | 15:8 | | | | CNE | N0x[15:8] | | | , | | | 0x0E48 | CNEN0C | 7:0 | | | | CNE | N0x[7:0] | | | | | | 0x0E4A | CNSTATC | 15:8 | | | | CNS | TATx[15:8] | | | | | | UXUE4A | CNSTATE | 7:0 | | | | CNS | TATx[7:0] | | | | | | 0x0E4C | CNEN1C | 15:8 | | | | | N1x[15:8] | | | | | | UNULTO | ONLIVIO | 7:0 | | | | | N1x[7:0] | | | | | | 0x0E4E | CNFC | 15:8 | | | | | Fx[15:8] | | | | | | | | 7:0 | | | | CN | IFx[7:0] | | | | | | 0x0E50 | | | | | | | | | | | | | 0x0E53 | Reserved | | | | | | | | | | | | | | 15:8 | | | | ANS | <br>ELD[15:8] | | | | | | 0x0E54 | ANSELD | 7.0 | | | | | ELD[7.0] | | | | | | 0.0550 | TDIOD | 15:8 | | | | | SD[15:8] | | | | | | 0x0E56 | TRISD | 7:0 | | | | | ISD[7:0] | | | | | | 0x0E58 | PORTD | 15:8 | | | | POF | RTD[15:8] | | | | | | UXUESO | PORTD | 7:0 | | | | | RTD[7:0] | | | | | | 0x0E5A | LATD | 15:8 | | | | | TD[15:8] | | | | | | | (E 1) | 7:0 | | | | | TD[7:0] | | | | | | 0x0E5C | ODCD | 15:8 | | | | | Cx[15:8] | | | | | | | | 7:0 | | | | | Cx[7:0] | | | | | | 0x0E5E | CNPUD | 15:8<br>7:0 | | | | | UD[15:8]<br>PUD[7:0] | | | | | | | SALE SALE | 15:8 | | | | | PDx[15:8] | | | | | | 0x0E60 | CNPDD | 7:0 | | | | | PDx[7:0] | | | | | | 0.0500 | ONGOVE | 15:8 | ON | | | | CNSTYLE | | | | | | 0x0E62 | CNCOND | 7:0 | | | | | | | | | | | 0v0E64 | CNENOD | 15:8 | | | | CNE | N0D[15:8] | | | | | | 0x0E64 | CNEN0D | 7:0 | | | | | N0D[7:0] | | | | | | 0x0E66 | CNSTATD | 15:8 | | | | | ATD[15:8] | | | | | | OXOLOG | ONOTATIO | 7:0 | | | | | TATD[7:0] | | | | | | 0x0E68 | CNEN1D | 15:8 | | | | | N1D[15:8] | | | | | | | | 7:0 | | | | | N1D[7:0] | | | | | | 0x0E6A | CNFD | 15:8<br>7:0 | | | | | FD[15:8] | | | | | | 0x0E6C | | 7.0 | | | | CN | FD[7:0] | | | | | | | Reserved | | | | | | | | | | | | 0x0E6F | , , , , , , , , , , , , , , , , , , , , | | | | | | | | | | | | | (4)(4)(4)(4) | 15:8 | | | | ANS | ELx[15:8] | | | | | | 0x0E70 | ANSELE | 7:0 | | | | | ELx[7:0] | | | | | | 0v0E72 | TDICE | 15:8 | | | | TRI | SE[15:8] | | | | | | 0x0E72 | TRISE | 7:0 | | | | | ISE[7:0] | | | | | # dsPIC33CK512MP608 Family I/O Ports | contir | nued | | | | | | | | | | | | | |-------------|----------|----------|-------------|-------------|---|-------|----------|---|---|---|--|--|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 0x0E74 | PORTE | 15:8 | | PORTE[15:8] | | | | | | | | | | | UXUE/4 | PORTE | 7:0 | | PORTE[7:0] | | | | | | | | | | | 0x0E76 | LATE | 15:8 | | | | LATE | [15:8] | | | | | | | | UXUE70 | LATE | 7:0 | | LATE[7:0] | | | | | | | | | | | 0x0E78 ODCE | ODCE | 15:8 | | | | ODC | E[15:8] | | | | | | | | | ODCE | 7:0 | | ODCE[7:0] | | | | | | | | | | | 0x0E7A CNPU | CNDUE | 15:8 | | CNPUE[15:8] | | | | | | | | | | | | OIVI OL | 7:0 | | CNPUE[7:0] | | | | | | | | | | | 0x0E7C | CNPDE | 15:8 | CNPDE[15:8] | | | | | | | | | | | | UXUETC | CNFDE | 7:0 | CNPDE[7:0] | | | | | | | | | | | | 0x0E7E | CNCONE | 15:8 | ON | | | | CNSTYLE | | | | | | | | UXUETE | CNCONE | 7:0 | | | | | | | | | | | | | 0x0E80 | CNEN0E | 15:8 | | | | CNEN | 0x[15:8] | | | | | | | | UXUEOU | CINEINUE | 7:0 | | | | CNEN | l0x[7:0] | | | | | | | | 0x0E82 | CNSTATE | 15.8 | | | | CNSTA | TE[15.8] | | | | | | | | UXULUZ | CNSTATE | 7:0 | | | | CNSTA | ATE[7:0] | | | | | | | | 0x0E84 | CNEN1E | 15:8 | | | | CNEN | 1x[15:8] | | | | | | | | UNUE04 | CINEINTE | 7:0 | | | | CNEN | l1x[7:0] | | | | | | | | 0x0E86 | CNFE | 15:8 | | | | CNFE | [15:8] | | | | | | | | UXUEOU | CNFE | 7:0 | | | | CNF | E[7:0] | | | | | | | # dsPIC33CK512MP608 Family I/O Ports # 8.2.2.1 Analog Select for PORTx Register Name: ANSELx **Offset:** 0xE00, 0xE1C, 0xE38, 0xE54, 0xE70 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|--------------|-----|-----|-----|-----|-----|-----| | | | ANSELx[15:8] | | | | | | | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ANSELx[7:0] | | | | | | | | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Bits 15:0 - ANSELx[15:0] Analog Select for PORTx bits | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | Analog input is enabled and digital input is disabled on the PORTx[n] pin | | 0 | Analog input is disabled and digital input is enabled on the PORTx[n] pin | # dsPIC33CK512MP608 Family I/O Ports # 8.2.2.2 Output Enable for PORTx Register Name: TRISx **Offset:** 0xE02, 0xE1E, 0xE34, 0xE56, 0xE72 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|-------------|-----|-----|-----|-----|-----|-----| | | | TRISx[15:8] | | | | | | | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TRISx[7:0] | | | | | | | | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Bits 15:0 - TRISx[15:0] Output Enable for PORTx bits | Value | Description | |-------|-------------------------------------------| | 1 | LATx[n] is not driven on the PORTx[n] pin | | 0 | LATx[n] is driven on the PORTx[n] pin | # dsPIC33CK512MP608 Family I/O Ports # 8.2.2.3 Input Data for PORTx Register Name: PORTx **Offset:** 0xE04, 0xE20, 0xE3C, 0xE58, 0xE74 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|-------------|-----|-----|-----|-----|-----|-----| | | | PORTx[15:8] | | | | | | | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Γ | PORTx[7:0] | | | | | | | | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Bits 15:0 - PORTx[15:0] PORTx Data Input Value bits # 8.2.2.4 Output Data for PORTx Register Name: LATx **Offset:** 0xE06, 0xE22, 0xE3E, 0xE5A, 0xE76 Legend: x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|-----|-----|------|--------|-----|-----|-----| | | | | | LATx | [15:8] | | | | | Access | R/W | Reset | X | X | X | X | X | X | X | X | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | LATx[7:0] | | | | | | | | | Access | R/W | Reset | X | X | X | X | X | X | X | X | Bits 15:0 - LATx[15:0] PORTx Data Output Value bits # dsPIC33CK512MP608 Family I/O Ports # 8.2.2.5 Open-Drain Enable for PORTx Register Name: ODCx **Offset:** 0xE08, 0xE24, 0xE40, 0xE5C, 0xE78 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-----------|------------|-----|-----|-----|-----|-----|-----|--| | | | ODCx[15:8] | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | ODCx[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - ODCx[15:0] PORTx Open-Drain Enable bits | Value | Description | |-------|-----------------------------------------| | 1 | Open-drain is enabled on the PORTx pin | | 0 | Open-drain is disabled on the PORTx pin | # dsPIC33CK512MP608 Family I/O Ports # 8.2.2.6 Change Notification Pull-up Enable for PORTx Register Name: CNPUx **Offset:** 0xE0A, 0xE26, 0xE42, 0xE5E, 0xE7A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|-------------|-----|-----|-----|-----|-----|-----| | | | CNPUx[15:8] | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CNPUx[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - CNPUx[15:0] Change Notification Pull-up Enable for PORTx bits | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | The pull-up for PORTx[n] is enabled – takes precedence over the pull-down selection | | 0 | The pull-up for PORTx[n] is disabled | ## I/O Ports # 8.2.2.7 Change Notification Pull-Down Enable for PORTx Register Name: CNPDx **Offset:** 0xE0C, 0xE28, 0xE44, 0xE60, 0xE7C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|-----|-----|------|---------|-----|-----|-----| | | | | | CNPD | x[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CNPDx[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 – CNPDx[15:0] Change Notification Pull-Down Enable for PORTx bits | Value | Description | |-------|------------------------------------------------------------------------------------| | 1 | The pull-down for PORTx[n] is enabled (if the pull-up for PORTx[n] is not enabled) | | 0 | The pull-down for PORTx[n] is disabled | # dsPIC33CK512MP608 Family I/O Ports # 8.2.2.8 Change Notification Control for PORTx Register Name: CNCONx **Offset:** 0xE0E, 0xE2A, 0xE46, 0xE62, 0xE7E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|----|----|----|---------|----|---|---| | | ON | | | | CNSTYLE | | | | | Access | R/W | , | | | R/W | , | | | | Reset | 0 | | | | 0 | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset #### Bit 15 - ON Change Notification (CN) Control for PORTx On bit | Value | Description | |-------|----------------| | 1 | CN is enabled | | 0 | CN is disabled | #### Bit 11 - CNSTYLE Change Notification Style Selection bit | Value | Description | |-------|-------------------------------------------------------------------------------------------------| | 1 | Edge style (detects edge transitions, CNFx[15:0] bits are used for a Change Notification event) | | 0 | Mismatch style (detects change from last port read, CNSTATx[15:0] bits are used for a Change | | | Notification event) | # dsPIC33CK512MP608 Family I/O Ports # 8.2.2.9 Interrupt Change Notification Enable for PORTx Register Name: CNEN0x **Offset:** 0xE10, 0xE2C, 0xE48, 0xE64, 0xE80 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|-----|-----|-------|----------|-----|-----|-----| | | | | | CNENC | )x[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CNEN0x[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - CNEN0x[15:0] Interrupt Change Notification Enable for PORTx bits | Value | Description | |-------|------------------------------------------------------------------------| | 1 | Interrupt-on-change (from the last read value) is enabled for PORTx[n] | | 0 | Interrupt-on-change is disabled for PORTx[n] | # 8.2.2.10 Interrupt Change Notification Status for PORTx Register Name: CNSTATx **Offset:** 0xE12, 0xE2E, 0xE4A, 0xE66, 0xE82 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------------|----|----|-------|----------|----|---|---| | | | | | CNSTA | Tx[15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CNSTATx[7:0] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Bits 15:0 – CNSTATx[15:0]** Interrupt Change Notification Status for PORTx bits When CNSTYLE (CNCONx[11]) = 0: | Value | Description | |-------|--------------------------------------------------------------| | 1 | Change occurred on PORTx[n] since last read of PORTx[n] | | 0 | Change did not occur on PORTx[n] since last read of PORTx[n] | I/O Ports # 8.2.2.11 Interrupt Change Notification Edge Select for PORTx Register Name: CNEN1x **Offset:** 0xE14, 0xE30, 0xE4C, 0xE68, 0xE84 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|-----|-----|-------|---------|-----|-----|-----| | | | | | CNEN1 | x[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CNEN1x[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - CNEN1x[15:0] Interrupt Change Notification Edge Select for PORTx bits #### 8.2.2.12 Interrupt Change Notification Flag for PORTx Register Name: CNFx **Offset:** 0xE16, 0xE32, 0xE4E, 0xE6A, 0xE86 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|-----|-----|------|--------|-----|-----|-----| | | | | | CNFx | [15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CNFx[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Bits 15:0 – CNFx[15:0]** Interrupt Change Notification Flag for PORTx bits When CNSTYLE (CNCONx[11]) = 1: | Value | Description | |-------|---------------------------------------------------------| | 1 | An enabled edge event occurred on the PORTx[n] pin | | 0 | An enabled edge event did not occur on the PORTx[n] pin | # 8.3 Input Change Notification (ICN) The Input Change Notification function of the I/O ports allows the dsPIC33CK512MP608 family devices to generate interrupt requests to the processor in response to a Change-of-State (COS) 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 Change Notification (CN) functionality of each I/O port. To enable the Change Notification feature for the port, the ON bit (CNCONx[15]) must be set. The CNEN0x and CNEN1x registers contain the CN interrupt enable control bits for each of the input pins. The setting of these bits enables a CN interrupt for the corresponding pins. Also, these bits, in combination with the CNSTYLE bit (CNCONx[11]), define a type of transition when the interrupt is generated. Possible CN event options are listed in Table 8-2. Table 8-2. Change Notification Event Options | CNSTYLE Bit<br>(CNCONx[11]) | CNEN1x Bit | CNEN0x Bit | Change Notification<br>Event Description | |-----------------------------|-----------------|------------|------------------------------------------------------------------------------------------| | 0 | Does not matter | 0 | Disabled | | 0 | Does not matter | 1 | Detects a mismatch<br>between the last read state<br>and the current state of<br>the pin | | 1 | 0 | 0 | Disabled | | 1 | 0 | 1 | Detects a positive transition only (from '0' to '1') | | 1 | 1 | 0 | Detects a negative transition only (from '1' to '0') | | 1 | 1 | 1 | Detects both positive and negative transitions | The CNSTATx register indicates whether a change occurred on the corresponding pin since the last read of the PORTx bit. In addition to the CNSTATx register, the CNFx register is implemented for each port. This register contains flags for Change Notification events. These flags are set if the valid transition edge, selected in the CNEN0x and CNEN1x registers, is detected. CNFx stores the occurrence of the event. CNFx bits must be cleared in software to get the next Change Notification interrupt. The CN interrupt is generated only for the I/Os configured as inputs (corresponding TRISx bits must be set). **Note:** Pull-ups and pull-downs on Input Change Notification pins should always be disabled when the port pin is configured as a digital output. ## 8.4 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 work arounds in application code, or a complete redesign, may be the only option. Peripheral Pin Select configuration provides an alternative to these choices by enabling peripheral set selection and 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 Peripheral Pin Select 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 any one of these I/O pins. Hardware safeguards are included that prevent accidental or spurious changes to the peripheral mapping once it has been established. #### 8.4.1 Available Pins The number of available pins is dependent on the particular device and its pin count. Pins that support the Peripheral Pin Select feature include the label, "RPn", in their full pin designation, where "n" is the remappable pin number. "RP" is used to designate pins that support both remappable input and output functions. #### 8.4.2 Available Peripherals The peripherals managed by the Peripheral Pin Select are all digital only peripherals. These include general serial communications (UART and SPI), general purpose timer clock inputs, timer-related peripherals (input capture and output compare) and interrupt-on-change inputs. In comparison, some digital only peripheral modules are never included in the Peripheral Pin Select 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. One example includes I<sup>2</sup>C modules. A similar requirement excludes all modules with analog inputs, such as the A/D 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/Os 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. #### 8.4.3 Controlling Configuration Changes Because peripheral mapping can be changed during run time, some restrictions on peripheral remapping are needed to prevent accidental configuration changes. The dsPIC33CK512MP608 devices have implemented the control register lock sequence. #### 8.4.3.1 Control Register Lock Under normal operation, writes to the RPINRx and RPORx registers are not allowed. Attempted writes will appear to execute normally, but the contents of the registers will remain unchanged. To change these registers, they must be unlocked in hardware. The register lock is controlled by the IOLOCK bit (RPCON[11]). Setting IOLOCK prevents writes to the control registers; clearing IOLOCK allows writes. To set or clear IOLOCK, the NVMKEY unlock sequence must be executed: - Write 0x55 to NVMKEY. - 2. Write 0xAA to NVMKEY. - Clear (or set) IOLOCK as a single operation. IOLOCK remains in one state until changed. This allows all of the Peripheral Pin Selects to be configured with a single unlock sequence, followed by an update to all of the control registers. Then, IOLOCK can be set with a second lock sequence. **Note:** MPLAB® XC16 provides a built-in C language function for unlocking and modifying the RPCON register: builtin write RPCON (value); For more information, see the MPLAB® XC16 Help files. ### 8.5 Considerations for Peripheral Pin Selection The ability to control Peripheral Pin Selection introduces several considerations into application design that most users would never think of otherwise. This is particularly true for several common peripherals, which are only available as remappable peripherals. The main consideration is that the Peripheral Pin Selects are not available on default pins in the device's default (Reset) state. More specifically, because all RPINRx registers reset to '1's and RPORx registers reset to '0's, this means all PPS inputs are tied to V<sub>SS</sub>, while all PPS outputs are disconnected. This means that before any other application code is executed, the user must initialize the device with the proper peripheral configuration. Because the IOLOCK bit resets in the unlocked state, it is not necessary to execute the unlock sequence after the device has come out of Reset. For application safety, however, it is always better to set IOLOCK and lock the configuration after writing to the control registers. The NVMKEY unlock sequence must be executed as an Assembly language routine. If the bulk of the application is written in C, or another high-level language, the unlock sequence should be performed by writing in-line assembly or by using the builtin write RPCON(value) function provided by the compiler. Choosing the configuration requires a review of all Peripheral Pin Selects and their pin assignments, particularly those that will not be used in the application. In all cases, unused pin-selectable peripherals should be disabled completely. Unused peripherals should have their inputs assigned to an unused RPn pin function. I/O pins with unused RPn functions should be configured with the null peripheral output. #### 8.6 Input Mapping The inputs of the Peripheral Pin Select 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 RPINRx registers are used to configure peripheral input mapping. Each register contains sets of 8-bit fields, with each set associated with one of the remappable peripherals. Programming a given peripheral's bit field with an appropriate 8-bit index value maps the RPn pin with the corresponding value, or internal signal, to that peripheral. See Table 8-3 for a list of available inputs. For example, Figure 8-2 illustrates remappable pin selection for the U1RX input. Figure 8-2. Remappable Input for U1RX Example 8-1 provides a configuration for bidirectional communication with flow control using UART1. The following input and output functions are used: Input Functions: U1RX, U1CTS Output Functions: U1TX, U1RTS Table 8-3. Remappable Pin Inputs | RPINRx[15:8] or RPINRx[7:0] | Function | Available on Ports | |-----------------------------|-----------------|--------------------| | 0 | V <sub>SS</sub> | Internal | | 1 | Comparator 1 | Internal | | 2 | Comparator 2 | Internal | | 3 | Comparator 3 | Internal | | 4-5 | RP4-RP5 | Reserved | | 6 | PTG Trigger 26 | Internal | | 7 | PTG Trigger 27 | Internal | | 8-10 | RP8-RP10 | Reserved | | 11 | PWM Event Out C | Internal | | 12 | PWM Event Out D | Internal | | 13 | PWM Event Out E | Internal | | 14-31 | RP14-RP31 | Reserved | | 32 | RP32 | Port Pin RB0 | | 33 | RP33 | Port Pin RB1 | | 34 | RP34 | Port Pin RB2 | | 35 | RP35 | Port Pin RB3 | | 36 | RP36 | Port Pin RB4 | | 37 | RP37 | Port Pin RB5 | | 38 | RP38 | Port Pin RB6 | | 39 | RP39 | Port Pin RB7 | | continued | | | | | | | | |-----------------------------|----------|--------------------|--|--|--|--|--| | RPINRx[15:8] or RPINRx[7:0] | Function | Available on Ports | | | | | | | 40 | RP40 | Port Pin RB8 | | | | | | | 41 | RP41 | Port Pin RB9 | | | | | | | 42 | RP42 | Port Pin RB10 | | | | | | | 43 | RP43 | Port Pin RB11 | | | | | | | 44 | RP44 | Port Pin RB12 | | | | | | | 45 | RP45 | Port Pin RB13 | | | | | | | 46 | RP46 | Port Pin RB14 | | | | | | | 47 | RP47 | Port Pin RB15 | | | | | | | 48 | RP48 | Port Pin RC0 | | | | | | | 49 | RP49 | Port Pin RC1 | | | | | | | 50 | RP50 | Port Pin RC2 | | | | | | | 51 | RP51 | Port Pin RC3 | | | | | | | 52 | RP52 | Port Pin RC4 | | | | | | | 53 | RP53 | Port Pin RC5 | | | | | | | 54 | RP54 | Port Pin RC6 | | | | | | | 55 | RP55 | Port Pin RC7 | | | | | | | 56 | RP56 | Port Pin RC8 | | | | | | | 57 | RP57 | Port Pin RC9 | | | | | | | 58 | RP58 | Port Pin RC10 | | | | | | | 59 | RP59 | Port Pin RC11 | | | | | | | 60 | RP60 | Port Pin RC12 | | | | | | | 61 | RP61 | Port Pin RC13 | | | | | | | 62 | RP62 | Port Pin RC14 | | | | | | | 63 | RP63 | Port Pin RC15 | | | | | | | 64 | RP64 | Port Pin RD0 | | | | | | | 65 | RP65 | Port Pin RD1 | | | | | | | 66 | RP66 | Port Pin RD2 | | | | | | | 67 | RP67 | Port Pin RD3 | | | | | | | 68 | RP68 | Port Pin RD4 | | | | | | | 69 | RP69 | Port Pin RD5 | | | | | | | 70 | RP70 | Port Pin RD6 | | | | | | | 71 | RP71 | Port Pin RD7 | | | | | | | 72 | RP72 | Port Pin RD8 | | | | | | | 73 | RP73 | Port Pin RD9 | | | | | | | 74 | RP74 | Port Pin RD10 | | | | | | | continued | | | |-----------------------------|------------------|--------------------| | RPINRx[15:8] or RPINRx[7:0] | Function | Available on Ports | | 75 | RP75 | Port Pin RD11 | | 76 | RP76 | Port Pin RD12 | | 77 | RP77 | Port Pin RD13 | | 78 | RP78 | Port Pin RD14 | | 79 | RP79 | Port Pin RD15 | | 80-157 | RP80-RP175 | Reserved | | 158 | DAC6 pwm_req_on | Internal | | 159 | DAC6 pwm_req_off | Internal | | 160 | DAC5 pwm_req_on | Internal | | 161 | DAC5 pwm_req_off | Internal | | 162 | DAC4 pwm_req_on | Internal | | 163 | DAC4 pwm_req_off | Internal | | 164 | DAC3 pwm_req_on | Internal | | 165 | DAC3 pwm_req_off | Internal | | 166 | DAC2 pwm_req_on | Internal | | 167 | DAC2 pwm_req_off | Internal | | 168 | DAC1 pwm_req_on | Internal | | 169 | DAC1 pwm_req_off | Internal | | 176 | RP176 | Virtual RPV0 | | 177 | RP177 | Virtual RPV1 | | 178 | RP178 | Virtual RPV2 | | 179 | RP179 | Virtual RPV3 | | 180 | RP180 | Virtual RPV4 | | 181 | RP181 | Virtual RPV5 | #### 8.7 Virtual Connections The dsPIC33CK512MP608 devices support six virtual RPn pins (RP176-RP181), which are identical in functionality to all other RPn pins, with the exception of pinouts. These six pins are internal to the devices and are not connected to a physical device pin. These pins provide a simple way for inter-peripheral connection without utilizing a physical pin. For example, the output of the analog comparator can be connected to RP176 and the PWM Fault input can be configured for RP176 as well. This configuration allows the analog comparator to trigger PWM Faults without the use of an actual physical pin on the device. | Table 8-4 | Selectable Input | Sources (Mans | Input to Function) | |-----------|------------------|---------------|--------------------| | | | | | | Input Name <sup>(1)</sup> | Function Name | Register | Register Bits | |---------------------------|---------------|----------|---------------| | External Interrupt 1 | INT1 | RPINR0 | INT1R[7:0] | | External Interrupt 2 | INT2 | RPINR1 | INT2R[7:0] | | External Interrupt 3 | INT3 | RPINR1 | INT3R[7:0] | | Timer1 External Clock | T1CK | RPINR2 | T1CK[7:0] | | SCCP Timer1 | TCKI1 | RPINR3 | TCKI1R[7:0] | | SCCP Capture 1 | ICM1 | RPINR3 | ICM1R[7:0] | | SCCP Timer2 | TCKI2 | RPINR4 | TCKI2R[7:0] | | SCCP Capture 2 | ICM2 | RPINR4 | ICM2R[7:0] | | SCCP Timer3 | TCKI3 | RPINR5 | TCKI3R[7:0] | | SCCP Capture 3 | ICM3 | RPINR5 | ICM3R[7:0] | | SCCP Timer4 | TCKI4 | RPINR6 | TCKI4R[7:0] | | SCCP Capture 4 | ICM4 | RPINR6 | ICM4R[7:0] | | continued | | | | |---------------------------|---------------|----------|---------------| | Input Name <sup>(1)</sup> | Function Name | Register | Register Bits | | SCCP Timer5 | TCKI5 | RPINR7 | TCKI5R[7:0] | | SCCP Capture 5 | ICM5 | RPINR7 | ICM5R[7:0] | | SCCP Timer6 | TCKI6 | RPINR8 | TCKI6R[7:0] | | SCCP Capture 6 | ICM6 | RPINR8 | ICM6R[7:0] | | SCCP Timer7 | TCKI7 | RPINR9 | TCKI7R[7:0] | | SCCP Capture 7 | ICM7 | RPINR9 | ICM7R[7:0] | | SCCP Timer8 | TCKI8 | RPINR10 | TCKI8R[7:0] | | SCCP Capture 8 | ICM8 | RPINR10 | ICM8R[7:0] | | xCCP Fault A | OCFA | RPINR11 | OCFAR[7:0] | | xCCP Fault B | OCFB | RPINR11 | OCFBR[7:0] | | PWM PCI 8 | PCI8 | RPINR12 | PCI8R[7:0] | | PWM PCI 9 | PCI9 | RPINR12 | PCI9R[7:0] | | PWM PCI 10 | PCI10 | RPINR13 | PCI10R[7:0] | | PWM PCI 11 | PCI11 | RPINR13 | PCI11R[7:0] | | QEI1 Input A | QEIA1 | RPINR14 | QEIA1R[7:0] | | QEI1 Input B | QEIB1 | RPINR14 | QEIB1R[7:0] | | QEI1 Index 1 Input | QEINDX1 | RPINR15 | QEINDX1R[7:0] | | QEI1 Home 1 Input | QEIHOM1 | RPINR15 | QEIHOM1R[7:0] | | QEI2 Input A | QEIA2 | RPINR16 | QEIA2R[7:0] | | QEI2 Input B | QEIB2 | RPINR16 | QEIB2R[7:0] | | QEI2 Index 1 Input | QEINDX2 | RPINR17 | QEINDX2R[7:0] | | QEI2 Home 1 Input | QEIHOM2 | RPINR17 | QEIHOM2R[7:0] | | UART1 Receive | U1RX | RPINR18 | U1RXR[7:0] | | UART1 Data-Set-Ready | <u>U1DSR</u> | RPINR18 | U1DSRR[7:0] | | UART2 Receive | U2RX | RPINR19 | U2RXR[7:0] | | UART2 Data-Set-Ready | <u>U2DSR</u> | RPINR19 | U2DSRR[7:0] | | SPI1 Data Input | SDI1 | RPINR20 | SDI1R[7:0] | | SPI1 Clock Input | SCK1IN | RPINR20 | SCK1R[7:0] | | SPI1 Client Select | SS1 | RPINR21 | SS1R[7:0] | | Reference Clock Input | REFOI | RPINR21 | REFOIR[7:0] | | SPI2 Data Input | SDI2 | RPINR22 | SDI2R[7:0] | | SPI2 Clock Input | SCK2IN | RPINR22 | SCK2R[7:0] | | SPI2 Client Select | <u>\$\$2</u> | RPINR23 | SS2R[7:0] | | CAN1 Input | CAN1RX | RPINR26 | CAN1RXR[7:0] | | UART3 Receive | U3RX | RPINR27 | U3RXR[7:0] | | continued | | | | |------------------------------|---------------|----------|---------------| | Input Name <sup>(1)</sup> | Function Name | Register | Register Bits | | UART3 Data-Set-Ready | U3DSR | RPINR27 | U3DSRR[7:0] | | SPI3 Data Input | SDI3 | RPINR29 | SDI3R[7:0] | | SPI3 Clock Input | SCK3IN | RPINR29 | SCK3R[7:0] | | SPI3 Client Select | SS3 | RPINR30 | SS3R[7:0] | | MCCP Timer9 | TCKI9 | RPINR32 | TCKI9R[7:0] | | MCCP Capture 9 | ICM9 | RPINR33 | ICM9R[7:0] | | xCCP Fault C | OCFC | RPINR37 | OCFCR[7:0] | | PWM Input 17 | PCI17 | RPINR37 | PCI17R[7:0] | | PWM Input 18 | PCI18 | RPINR38 | PCI18R[7:0] | | PWM Input 12 | PCI12 | RPINR42 | PCI12R[7:0] | | PWM Input 13 | PCI13 | RPINR42 | PCI13R[7:0] | | PWM Input 14 | PCI14 | RPINR43 | PCI14R[7:0] | | PWM Input 15 | PCI15 | RPINR43 | PCI15R[7:0] | | PWM Input 16 | PCI16 | RPINR44 | PCI16R[7:0] | | SENT1 Input | SENT1 | RPINR44 | SENT1R[7:0] | | SENT2 Input | SENT2 | RPINR45 | SENT2R[7:0] | | CLC Input A | CLCINA | RPINR45 | CLCINAR[7:0] | | CLC Input B | CLCINB | RPINR46 | CLCINBR[7:0] | | CLC Input C | CLCINC | RPINR46 | CLCINCR[7:0] | | CLC Input D | CLCIND | RPINR47 | CLCINDR[7:0] | | ADC Trigger Input (ADTRIG31) | ADCTRG | RPINR47 | ADCTRGR[7:0] | | xCCP Fault D | OCFD | RPINR48 | OCFDR[7:0] | | UART1 Clear-to-Send | <u>U1CTS</u> | RPINR48 | U1CTSR[7:0] | | UART2 Clear-to-Send | U2CTS | RPINR49 | U2CTSR[7:0] | | UART3 Clear-to-Send | U3CTS | RPINR49 | U3CTSR[7:0] | Note: Unless otherwise noted, all inputs use the Schmitt Trigger input buffers. #### 8.8 Output Mapping In contrast to inputs, the outputs of the Peripheral Pin Select 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 RPORx registers are used to control output mapping. Each register contains sets of 6-bit fields, with each set associated with one RPn pin (see 8.12.2 RPINR0 through 8.12.70 RPOR26). The value of the bit field corresponds to one of the peripherals and that peripheral's output is mapped to the pin (see 8.9 Mapping Limitations and Figure 8-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 8-3. Multiplexing Remappable Outputs for RPn **Note:** There are six virtual output ports which are not connected to any I/O ports (RP176-RP181). These virtual ports can be accessed by RPOR20, RPOR21 and RPOR22. #### 8.9 Mapping Limitations The control schema of the peripheral select pins is not limited to a small range of fixed peripheral configurations. There are no mutual or hardware-enforced lockouts between any of the peripheral mapping SFRs. Literally, any combination of peripheral mappings, across any or all of the RPn pins, is possible. This includes both many-to-one and one-to-many mappings of peripheral inputs, and outputs to pins. While such mappings may be technically possible from a configuration point of view, they may not be supportable from an electrical point of view (see Table 8-5). Table 8-5. Remappable Output Pin Registers(1) | RP Pin | I/O Port | |--------|-----------------------------------------------------------------------| | RP32 | Port Pin RB0 | | RP33 | Port Pin RB1 | | RP34 | Port Pin RB2 | | RP35 | Port Pin RB3 | | RP36 | Port Pin RB4 | | RP37 | Port Pin RB5 | | RP38 | Port Pin RB6 | | RP39 | Port Pin RB7 | | RP40 | Port Pin RB8 | | RP41 | Port Pin RB9 | | RP42 | Port Pin RB10 | | RP43 | Port Pin RB11 | | RP44 | Port Pin RB12 | | RP45 | Port Pin RB13 | | | RP32 RP33 RP34 RP35 RP36 RP36 RP37 RP38 RP39 RP40 RP41 RP42 RP43 RP43 | #### Note: Not all RPn pins are available on all packages. Make sure the selected device variant has the feature available on the device. | _ | | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RP Pin | I/O Port | | RP46 | Port Pin RB14 | | RP47 | Port Pin RB15 | | RP48 | Port Pin RC0 | | RP49 | Port Pin RC1 | | RP50 | Port Pin RC2 | | RP51 | Port Pin RC3 | | RP52 | Port Pin RC4 | | RP53 | Port Pin RC5 | | RP54 | Port Pin RC6 | | RP55 | Port Pin RC7 | | RP56 | Port Pin RC8 | | RP57 | Port Pin RC9 | | RP58 | Port Pin RC10 | | RP59 | Port Pin RC11 | | RP60 | Port Pin RC12 | | RP61 | Port Pin RC13 | | RP62 | Port Pin RC14 | | RP63 | Port Pin RC15 | | RP64 | Port Pin RD0 | | RP65 | Port Pin RD1 | | RP66 | Port Pin RD2 | | RP67 | Port Pin RD3 | | RP68 | Port Pin RD4 | | RP69 | Port Pin RD5 | | RP70 | Port Pin RD6 | | RP71 | Port Pin RD7 | | RP176 | Virtual Pin RPV0 | | RP177 | Virtual Pin RPV1 | | RP178 | Virtual Pin RPV2 | | RP179 | Virtual Pin RPV3 | | RP180 | Virtual Pin RPV4 | | RP181 | Virtual Pin RPV5 | | | RP46 RP47 RP48 RP48 RP49 RP50 RP50 RP51 RP52 RP53 RP54 RP55 RP56 RP57 RP58 RP59 RP60 RP61 RP62 RP63 RP64 RP65 RP65 RP66 RP67 RP68 RP69 RP70 RP71 RP176 RP177 RP178 RP178 RP179 RP180 | #### Note: <sup>1.</sup> Not all RPn pins are available on all packages. Make sure the selected device variant has the feature available on the device. Table 8-6. Output Selection for Remappable Pins (RPn)<sup>(1)</sup> | Function | RPnR[5:0] | Output Name | |--------------|-----------|------------------------------------| | Default PORT | 0 | RPn tied to Default Pin | | U1TX | 1 | RPn tied to UART1 Transmit | | U1RTS | 2 | RPn tied to UART1 Request-to-Send | | U2TX | 3 | RPn tied to UART2 Transmit | | U2RTS | 4 | RPn tied to UART2 Request-to-Send | | SDO1 | 5 | RPn tied to SPI1 Data Output | | SCK1 | 6 | RPn tied to SPI1 Clock Output | | SS1 | 7 | RPn tied to SPI1 Client Select | | SDO2 | 8 | RPn tied to SPI2 Data Output | | SCK2 | 9 | RPn tied to SPI2 Clock Output | | SS2 | 10 | RPn tied to SPI2 Client Select | | SD03 | 11 | RPn tied to SPI3 Data Output | | SCK3 | 12 | RPn tied to SPI3 Clock output | | SS3 | 13 | RPn tied to SPI3 Client Select | | REFCLKO | 14 | RPn tied to Reference Clock Output | | OCM1 | 15 | RPn tied to SCCP1 Output | | OCM2 | 16 | RPn tied to SCCP2 Output | | OCM3 | 17 | RPn tied to SCCP3 Output | | OCM4 | 18 | RPn tied to SCCP4 Output | | OCM5 | 19 | RPn tied to SCCP5 Output | | OCM6 | 20 | RPn tied to SCCP6 Output | | CAN1 | 21 | RPn tied to CAN1 Output | | CAN2 | 22 | RPn tied to CAN2 Output | | CMP1 | 23 | RPn tied to Comparator 1 Output | | CMP2 | 24 | RPn tied to Comparator 2 Output | | CMP3 | 25 | RPn tied to Comparator 3 Output | | CMP4 | 26 | RPn tied to Comparator 4 Output | | U3TX | 27 | RPn tied to UART3 Transmit | | U3RTS | 28 | RPn tied to UART3 Request-to-Send | | CMP5 | 32 | RPn tied to Comparator 5 Output | | CMP6 | 33 | RPn tied to Comparator 6 Output | | PWM4H | 34 | RPn tied to PWM4H Output | #### Note: Not all RPn pins are available on all packages. Make sure the selected device variant has the feature available on the device. | continued | | | | | | | |-----------|-----------|-----------------------------------|--|--|--|--| | Function | RPnR[5:0] | Output Name | | | | | | PWM4L | 35 | RPn tied to PWM4L Output | | | | | | PWMEA | 36 | RPn tied to PWM Event A Output | | | | | | PWMEB | 37 | RPn tied to PWM Event B Output | | | | | | QEICMP | 38 | RPn tied to QEI Comparator Output | | | | | | CLC1OUT | 40 | RPn tied to CLC1 Output | | | | | | CLC2OUT | 41 | RPn tied to CLC2 Output | | | | | | OCM7 | 42 | RPn tied to SCCP7 Output | | | | | | OCM8 | 43 | RPn tied to SCCP8 Output | | | | | | PWMEC | 44 | RPn tied to PWM Event C Output | | | | | | PWMED | 45 | RPn tied to PWM Event D Output | | | | | | PTGTRG24 | 46 | PTG Trigger Output 24 | | | | | | PTGTRG25 | 47 | PTG Trigger Output 25 | | | | | | SENT1OUT | 48 | RPn tied to SENT1 Output | | | | | | SENT2OUT | 49 | RPn tied to SENT2 Output | | | | | | CLC3OUT | 50 | RPn tied to CLC3 Output | | | | | | CLC4OUT | 51 | RPn tied to CLC4 Output | | | | | | U1DTR | 52 | Data Terminal Ready Output 1 | | | | | | U2DTR | 53 | Data Terminal Ready Output 2 | | | | | #### Note: Not all RPn pins are available on all packages. Make sure the selected device variant has the feature available on the device. #### 8.10 I/O Helpful Tips - 1. In some cases, certain pins, as defined in 33.1 DC Characteristics under "Injection Current", have internal protection diodes to V<sub>DD</sub> and V<sub>SS</sub>. The term, "Injection Current", is also referred to as "Clamp Current". On designated pins, with sufficient external current-limiting precautions by the user, I/O pin input voltages are allowed to be greater or lesser than the data sheet absolute maximum ratings, with respect to the V<sub>SS</sub> and V<sub>DD</sub> supplies. Note that when the user application forward biases either of the high or low-side internal input clamp diodes, that the resulting current being injected into the device that is clamped internally by the V<sub>DD</sub> and V<sub>SS</sub> power rails, may affect the ADC accuracy by four to six counts. - 2. I/O pins that are shared with any analog input pin (i.e., ANx) are always analog pins, by default, after any Reset. Consequently, configuring a pin as an analog input pin automatically disables the digital input pin buffer and any attempt to read the digital input level by reading PORTx or LATx will always return a '0', regardless of the digital logic level on the pin. To use a pin as a digital I/O pin on a shared ANx pin, the user application needs to configure the Analog Select for PORTx registers in the I/O ports module (i.e., ANSELx) by setting the appropriate bit that corresponds to that I/O port pin to a '0'. - **Note:** Although it is not possible to use a digital input pin when its analog function is enabled, it is possible to use the digital I/O output function, TRISx = 0x0, while the analog function is also enabled. However, this is not recommended, particularly if the analog input is connected to an external analog voltage source, which would create signal contention between the analog signal and the output pin driver. - Most I/O pins have multiple functions. Referring to the device pin diagrams in this data sheet, the priorities of the functions allocated to any pins are indicated by reading the pin name, from left-to-right. The left most - function name takes precedence over any function to its right in the naming convention. For example: AN16/T2CK/T7CK/RC1; this indicates that AN16 is the highest priority in this example and will supersede all other functions to its right in the list. Those other functions to its right, even if enabled, would not work as long as any other function to its left was enabled. This rule applies to all of the functions listed for a given pin. - 4. Each pin has an internal weak pull-up resistor and pull-down resistor that can be configured using the CNPUx and CNPDx registers, respectively. These resistors eliminate the need for external resistors in certain applications. The internal pull-up is up to ∼(V<sub>DD</sub> − 0.8), not V<sub>DD</sub>. This value is still above the minimum V<sub>IH</sub> of CMOS and TTL devices. - 5. When driving LEDs directly, the I/O pin can source or sink more current than what is specified in the $V_{OH}/I_{OH}$ and $V_{OL}/I_{OL}$ DC characteristics specification. The respective $I_{OH}$ and $I_{OL}$ current rating only applies to maintaining the corresponding output at or above the $V_{OH}$ , and at or below the $V_{OL}$ levels. However, for LEDs, unlike digital inputs of an externally connected device, they are not governed by the same minimum $V_{IH}/V_{IL}$ levels. An I/O pin output can safely sink or source any current less than that listed in the Absolute Maximum Ratings in 33. Electrical Characteristics of this data sheet. For example: $V_{OH} = 2.4v @ I_{OH} = -8 \text{ mA}$ and $V_{DD} = 3.3V$ The maximum output current sourced by any 8 mA I/O pin = 12 mA. LED source current < 12 mA is technically permitted. - 6. The Peripheral Pin Select (PPS) pin mapping rules are as follows: - 6.1. Only one "output" function can be active on a given pin at any time, regardless if it is a dedicated or remappable function (one pin, one output). - 6.2. It is possible to assign a "remappable output" function to multiple pins and externally short or tie them together for increased current drive. - 6.3. If any "dedicated output" function is enabled on a pin, it will take precedence over any remappable "output" function. - 6.4. If any "dedicated digital" (input or output) function is enabled on a pin, any number of "input" remappable functions can be mapped to the same pin. - 6.5. If any "dedicated analog" function(s) are enabled on a given pin, "digital input(s)" of any kind will all be disabled, although a single "digital output", at the user's cautionary discretion, can be enabled and active as long as there is no signal contention with an external analog input signal. For example, it is possible for the ADC to convert the digital output logic level, or to toggle a digital output on a comparator or ADC input, provided there is no external analog input, such as for a Built-In Self-Test. - 6.6. Any number of "input" remappable functions can be mapped to the same pin(s) at the same time, including to any pin with a single output from either a dedicated or remappable "output". - 6.7. The TRISx registers control only the digital I/O output buffer. Any other dedicated or remappable active "output" will automatically override the TRISx setting. The TRISx register does not control the digital logic "input" buffer. Remappable digital "inputs" do not automatically override TRISx settings, which means that the TRISx bit must be set to input for pins with only remappable input function(s) assigned. - 6.8. All analog pins are enabled by default after any Reset and the corresponding digital input buffer on the pin has been disabled. Only the Analog Select for PORTx (ANSELx) registers control the digital input buffer, not the TRISx register. The user must disable the analog function on a pin using the Analog Select for PORTx registers in order to use any "digital input(s)" on a corresponding pin, no exceptions. #### 8.11 I/O Ports Resources Many useful resources are provided on the main product page of the Microchip website for the devices listed in this data sheet. This product page contains the latest updates and additional information. ### 8.11.1 Key Resources - "I/O Ports with Edge Detect" (www.microchip.com/DS70005322) in the "dsPIC33/PIC24 Family Reference Manual" - Code Samples - Application Notes - Software Libraries - Webinars - All Related "dsPIC33/PIC24 Family Reference Manual" sections - · Development Tools ### 8.12 Peripheral Pin Select Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----------------------|-------------|------------|------------|---|-------|-------------------|---|---|---| | 0x0D00 | RPCON(1) | 15:8 | | | | | IOLOCK | | | | | UXUDUU | KFCON(1) | 7:0 | | | | | | | | | | 0x0D02 | | | | | | | | | | | | 0x0D03 | Reserved | | | | | | | | | | | 000003 | | 15:8 | | INT1R[7:0] | | | | | | | | 0x0D04 | RPINR0 | 7:0 | | | | INT | K[7.0] | | | | | | | 15:8 | | INT3R[7:0] | | | | | | | | 0x0D06 | RPINR1 | 7:0 | | INT2R[7:0] | | | | | | | | | | 15:8 | | T1CKR[7:0] | | | | | | | | 0x0D08 | RPINR2 | 7:0 | TOTALIT.OJ | | | | | | | | | | | 15:8 | | | 1 | ICM1 | R[7:0] | | 1 | | | 0x0D0A | RPINR3 | 7:0 | | | | | 1R[7:0] | | | | | | | 15:8 | | | | | R[7:0] | | | | | 0x0D0C | RPINR4 | 7:0 | | | | | 2R[7:0] | | | | | A 11777 ACCUSA | Demonstructure and a | 15:8 | | | | | R[7:0] | | | | | 0x0D0E | RPINR5 | 7:0 | | | | | 3R[7:0] | | | | | | Lance Control | 15:8 | | | | | R[7:0] | | | | | 0x0D10 | RPINR6 | 7:0 | | | | | 4R[7:0] | | | | | 2 25 12 | Tarania a | 15:8 | | | | | R[7:0] | | | | | 0x0D12 | RPINR7 | 7:0 | | | | | 5R[7:0] | | | | | 0.0044 | DDINIDO | 15.8 | | | | | R[7·0] | | | | | 0x0D14 | RPINR8 | 7:0 | | | | | 6R[7:0] | | | | | 0.0040 | DDINIDO | 15:8 | | | | | R[7:0] | | | | | 0x0D16 | RPINR9 | 7:0 | | | | | 7R[7:0] | | | | | 0.0040 | | 15:8 | | | | | R[7:0] | | | | | 0x0D18 | RPINR10 | 7:0 | | | | | 3R[7:0] | | | | | 0,00044 | DDIND44 | 15:8 | | | | OCFE | BR[7:0] | | | | | 0x0D1A | RPINR11 | 7:0 | | | | OCFA | AR[7:0] | | | | | 0v0D1C | DDINID42 | 15:8 | | | | PCI9 | R[7:0] | | | | | 0x0D1C | RPINR12 | 7:0 | | | | | R[7:0] | | | | | 0x0D1E | RPINR13 | 15:8 | | | | PCI11 | IR[7:0] | | | | | OXODIL | TO INICIO | 7:0 | | | | | DR[7:0] | | | | | 0x0D20 | RPINR14 | 15:8 | | | | QEIB* | 1R[7:0] | | | | | OXOBEO | | 7:0 | | | | QEIA? | 1R[7:0] | | | | | 0x0D22 | RPINR15 | 15:8 | | | | | M1R[7:0] | | | | | OXOBEE | 74 114(10 | 7:0 | | | | | X1R[7:0] | | | | | 0x0D24 | RPINR16 | 15:8 | | | | | 2R[7:0] | | | | | | | 7:0 | | | | | 2R[7:0] | | | | | 0x0D26 | RPINR17 | 15:8 | | | | | M2R[7:0] | | | | | | WAS THE STATE OF | 7:0 | | | | | X2R[7:0] | | | | | 0x0D28 | RPINR18 | 15:8 | | | | | RR[7:0] | | | | | | | 7:0 | | | | | (R[7:0] | | | | | 0x0D2A | RPINR19 | 15:8 | | | | | RR[7:0] | | | | | | | 7:0 | | | | | (R[7:0] | | | | | 0x0D2C | RPINR20 | 15:8 | SCK1R[7:0] | | | | | | | | | | | 7:0 | | | | | R[7:0] | | | | | 0x0D2E | RPINR21 | 15:8 | | | | | IR[7:0] | | | | | | | 7:0 | | | | | R[7:0] | | | | | 0x0D30 | RPINR22 | 15:8<br>7:0 | | | | | 2R[7:0] | | | | | | | 15:8 | | | | SD12 | R[7:0] | | | | | 0x0D32 | RPINR23 | 7:0 | | | | 9001 | R[7:0] | | | | | | | 15:8 | | | | | R[7.0]<br>3R[7:0] | | | | | 0x0D34 | RPINR24 | 7:0 | | | | | 3R[7:0] | | | | | | | 1.0 | | | | QLIA | ر ۱۰۰۰ ۱۰۰۰ | | | | | contin | ued | | | | | | | | | | |--------|------------------------------------|-------------|---|-------------|---|-------|--------------------|---------|---|---| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0D36 | RPINR25 | 15:8 | _ | | | | | | | | | UXUDSU | KFINK25 | 7:0 | | | | | X3R[7:0] | | | | | 0x0D38 | RPINR26 | 15:8 | | | | | RXR[7:0] | | | | | ONOBOO | 10 111120 | 7:0 | | | | | RXR[7:0] | | | | | 0x0D3A | RPINR27 | 15:8 | | | | | RR[7:0] | | | | | | 1.0 40.000 | 7:0 | | | | U3R) | XR[7:0] | | _ | | | 0x0D3C | December | | | | | | | | | | | 0x0D3D | Reserved | | | | | | | | | | | UXUDOD | | 15:8 | | | | SCK. | 3R[7:0] | | | | | 0x0D3E | RPINR29 | 7:0 | | | | | 3R[7:0] | | | | | | | 15:8 | | | | OBIG | 7 (7 .0] | | | | | 0x0D40 | RPINR30 | 7:0 | | | | SS3 | R[7:0] | | 1 | | | 0x0D42 | | 7.0 | | | | | 14(1.0) | | | | | | Reserved | | | | | | | | | | | 0x0D43 | | | | | | | | | | | | 0x0D44 | RPINR32 | 15:8 | | TCKI9R[7:0] | | | | | | | | UXUD44 | THINK32 | 7:0 | | | | | | | | | | 0x0D46 | RPINR33 | 15:8 | | | | | | | | | | | TT IIVIXOO | 7:0 | | | | ICM | PR[7:0] | | | | | 0x0D48 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0D4D | | 45.0 | | | | DOI1 | 7017.01 | | | | | 0x0D4E | RPINR37 | 15:8<br>7:0 | | | | | 7R[7:0] | | | | | | | 15:8 | | | | OCFI | DR[7:0] | | | | | 0x0D50 | RPINR38 | 7:0 | | | | DCI4 | 8R[7:0] | | | | | 0x0D52 | | 7.0 | | | | FCIT | or(7.0] | | | | | | Reserved | | | | | | | | | | | 0x0D57 | Veseiven | | | | | | | | | | | | | 15:8 | | | | PCI1 | 3R[7:0] | | | | | 0x0D58 | RPINR42 | 7:0 | | | | | 2R[7:0] | | | | | 0.0054 | DDIVID 46 | 15:8 | | | | | 5R[7:0] | | | | | 0x0D5A | RPINR43 | 7:0 | | | | | 4R[7:0] | | | | | 0x0D5C | RPINR44 | 15:8 | | | | SENT | 1R[7:0] | | | | | OXODSC | IXF IIVIX44 | 7:0 | | | | PCI1 | 6R[7:0] | | | | | 0x0D5E | RPINR45 | 15:8 | | | | | IAR[7:0] | | | | | OXOBOL | THE INTERIOR | 7:0 | | | | | 2R[7:0] | | | | | 0x0D60 | RPINR46 | 15:8 | | | | | ICR[7:0] | | | | | | 1 10 0/21/24/20 | 7:0 | | | | | IBR[7:0] | | | | | 0x0D62 | RPINR47 | 15:8 | | | | | RGR[7:0] | | | | | | No. post a recur \$600 \$100 \$1.0 | 7:0 | | | | CLCIN | IDR[7:0] | | | | | 0x0D64 | RPINR48 | 15:8 | | | | | SR[7:0] | | | | | | | 7:0 | | | | | DR[7:0] | | | | | 0x0D66 | RPINR49 | 15:8<br>7:0 | | | | | SR[7:0]<br>SR[7:0] | | | | | 0x0D68 | | 7.0 | | | | 0201 | SR[1.0] | | | | | | Reserved | | | | | | | | | | | 0x0D7F | reconved | | | | | | | | | | | | DDC TO | 15:8 | | | | | RP3 | 3R[5:0] | | 1 | | 0x0D80 | RPOR0 | 7:0 | | | | | | 2R[5:0] | | | | 0,0000 | DDCD4 | 15:8 | | | | | | 5R[5:0] | | | | 0x0D82 | RPOR1 | 7:0 | | | | | | 4R[5:0] | | | | 0,0004 | PDOPO | 15:8 | | | | | | 7R[5:0] | | | | 0x0D84 | RPOR2 | 7:0 | | | | | | 6R[5:0] | | | | 0,0000 | DDOD2 | 15:8 | | | | | | 9R[5:0] | | | | 0x0D86 | RPOR3 | 7:0 | | | | | | BR[5:0] | | | | 0x0D88 | RPOR4 | 15:8 | | | | | RP4 | 1R[5:0] | | | | | NFUR4 | 7:0 | | | | | DD4 | DR[5:0] | | | | contin | ued | | | | | | | | | | | | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----|------------|--------------------------|-----|------|---------|---|--|---|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | | | Oliset | Name | | - 1 | • | 9 | - 4 | | | | | · | | | 0x0D8A | RPOR5 | 15:8 | | | | | | 3R[5:0] | | | | | | | | 7:0 | | | | | | 2R[5:0] | | | | | | 0x0D8C | RPOR6 | 15:8 | | | | | | 5R[5:0] | | | | | | | | 7:0 | | | | | | 4R[5:0] | | | | | | 0x0D8E | RPOR7 | 15:8 | | | | | | 7R[5:0] | | | | | | | - Control Control | 7:0 | | | RP46R[5:0] | | | | | | | | | 0x0D90 | RPOR8 | 15:8 | | RP49R[5:0] | | | | | | | | | | | | 7:0 | | | RP48R[5:0]<br>RP51R[5:0] | | | | | | | | | 0x0D92 | RPOR9 | 15:8 | | | | | | | | | | | | | | 7:0 | | | | | | DR[5:0] | | | | | | 0x0D94 | RPOR10 | 15:8 | | | | | | 3[5:0] | | | | | | | | 7:0 | | | | | | 2R[5:0] | | | | | | 0x0D96 | RPOR11 | 15:8 | | | | | | 5R[5:0] | | | | | | | 1.00201.20002000000 | 7:0 | | | | | | 4R[5:0] | | | | | | 0x0D98 | RPOR12 | 15.8 | | | | | | 7R[5:0] | | | | | | | Committee of the Commit | 7:0 | | | | | | 6R[5:0] | | | | | | 0x0D9A | RPOR13 | 15:8 | | | | | | PR[5:0] | | | | | | | 220 (530).52 | 7:0 | | | | | | BR[5:0] | | | | | | 0x0D9C | RPOR14 | 15:8 | | | | | | 1R[5:0] | | | | | | | | 7:0 | | | | | | DR[5:0] | | | | | | 0x0D9E | RPOR15 | 15:8 | | | | | | 3R[5:0] | | | | | | | | 7:0 | | | | | | 2R[5:0] | | | | | | 0x0DA0 | RPOR16 | 15:8 | | | | | | 5R[5:0] | | | | | | 0,100,10 | 111 271113 | 7:0 | | | | | | 4R[5:0] | | | | | | 0x0DA2 | RPOR17 | 15:8 | | | | | | /R[5:0] | | | | | | 0,100,12 | | 7:0 | | | | | | 6R[5:0] | | | | | | 0x0DA4 | RPOR18 | 15:8 | | | | | | PR[5:0] | | | | | | UNUDATI | | 7:0 | | | | | | BR[5:0] | | | | | | 0x0DA6 | RPOR19 | 15:8 | | | | | | 1R[5:0] | | | | | | | | 7:0 | | | | | | DR[5:0] | | | | | | 0x0DA8 | RPOR20 | 15:8 | | | | | | 3R[5:0] | | | | | | UNUDI TO | 111 01120 | 7:0 | | | | | | 2R[5:0] | | | | | | 0x0DAA | RPOR21 | 15:8 | | | | | RP7 | 5R[5:0] | | | | | | OXOD/ U | THI OTTE | 7:0 | | | | | | 4R[5:0] | | | | | | 0x0DAC | RPOR22 | 15:8 | | | | | | 7R[5:0] | | | | | | OXOD/ (C | THI OTTE | 7:0 | | | | | | 6R[5:0] | | | | | | 0x0DAE | RPOR23 | 15:8 | | | | | | 9R[5:0] | | | | | | JAUDAL | TAI OINZU | 7:0 | | | | | RP78 | 3R[5:0] | | | | | | 0x0DB0 | RPOR24 | 15:8 | | | | | | 7R[5:0] | | | | | | 0,00000 | IN ONZ4 | 7:0 | | | | | RP17 | 6R[5:0] | | | | | | 0x0DB2 | RPOR25 | 15:8 | | | | | | 9R[5:0] | | | | | | UNUDBZ | NF ORZU | 7:0 | | | | | RP17 | 8R[5:0] | | | | | | 0x0DB4 | RPOR26 | 15:8 | | | | | | 1R[5:0] | | | | | | 000004 | NI ONZU | 7:0 | | | | | RP18 | 0R[5:0] | | | | | I/O Ports ### 8.12.1 Peripheral Remapping Configuration Register Name: RPCON<sup>(1)</sup> Offset: 0xD00 Note: Access Reset 1. Writing to this register needs an unlock sequence. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|----|----|----|----|--------|----|---|---| | | | | | | IOLOCK | | | | | Access<br>Reset | | | | | R/W | | | | | Reset | | | | | 0 | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Bit 11 - IOLOCK Peripheral Remapping Register Lock bit | | 220 Ort 1 Oriphoral Comapping Cognition 2000 ort | |-------|---------------------------------------------------------------------| | Value | Description | | 1 | All Peripheral Remapping registers are locked and cannot be written | | 0 | All Peripheral Remapping registers are unlocked and can be written | ### 8.12.2 Peripheral Pin Select Input Register 0 Name: RPINR0 Offset: 0xD04 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | | | | | INT1 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset Bits 15:8 - INT1R[7:0] Assign External Interrupt 1 (INT1) to the Corresponding RPn Pin bits #### I/O Ports ### 8.12.3 Peripheral Pin Select Input Register 1 Name: RPINR1 Offset: 0xD06 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----|------------|-----|-----|-----|-----|-----|-----|--|--|--| | | | INT3R[7:0] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | INT2R[7:0] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 - INT3R[7:0] Assign External Interrupt 3 (INT3) to the Corresponding RPn Pin bits Bits 7:0 - INT2R[7:0] Assign External Interrupt 2 (INT2) to the Corresponding RPn Pin bits ### 8.12.4 Peripheral Pin Select Input Register 2 Name: RPINR2 Offset: 0xD08 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | | | | | T1CK | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset Bits 15:8 - T1CKR[7:0] Assign Timer1 External Clock (T1CK) to the Corresponding RPn Pin bits I/O Ports ### 8.12.5 Peripheral Pin Select Input Register 3 Name: RPINR3 Offset: 0xD0A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----|------------|-----|-------|--------|-----|-----|-----|--|--| | | | ICM1R[7:0] | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TCKI1 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - ICM1R[7:0] Assign SCCP Capture 1 (ICM1) Input to the Corresponding RPn Pin bits Bits 7:0 - TCKI1R[7:0] Assign SCCP Timer1 (TCKI1) Input to the Corresponding RPn Pin bits I/O Ports ### 8.12.6 Peripheral Pin Select Input Register 4 Name: RPINR4 Offset: 0xD0C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|--------|-----|-----|-----| | | | | | ICM2 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TCKI2 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - ICM2R[7:0] Assign SCCP Capture 2 (ICM2) Input to the Corresponding RPn Pin bits Bits 7:0 - TCKI2R[7:0] Assign SCCP Timer2 (TCKI2) Input to the Corresponding RPn Pin bits I/O Ports ### 8.12.7 Peripheral Pin Select Input Register 5 Name: RPINR5 Offset: 0xD0E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|--------|-----|-----|-----| | | | | | ICM3 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TCKI3 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - ICM3R[7:0] Assign SCCP Capture 3 (ICM3) Input to the Corresponding RPn Pin bits Bits 7:0 – TCKI3R[7:0] Assign SCCP Timer3 (TCKI3) Input to the Corresponding RPn Pin bits #### I/O Ports ### 8.12.8 Peripheral Pin Select Input Register 6 Name: RPINR6 Offset: 0xD10 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|--------|-----|-----|-----| | | | | | ICM4 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TCKI4 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - ICM4R[7:0] Assign SCCP Capture 4 (ICM4) Input to the Corresponding RPn Pin bits Bits 7:0 – TCKI4R[7:0] Assign SCCP Timer4 (TCKI4) Input to the Corresponding RPn Pin bits ### 8.12.9 Peripheral Pin Select Input Register 7 Name: RPINR7 Offset: 0xD12 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | ICM5 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TCKIS | SR[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - ICM5R[7:0] Assign SCCP Capture 5 (ICM5) Input to the Corresponding RPn Pin bits Bits 7:0 – TCKI5R[7:0] Assign SCCP Timer5 (TCKI5) Input to the Corresponding RPn Pin bits #### 8.12.10 Peripheral Pin Select Input Register 8 Name: RPINR8 Offset: 0xD14 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | ICM6R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TCKI6 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - ICM6R[7:0] Assign SCCP Capture 6 (ICM6) Input to the Corresponding RPn Pin bits Bits 7:0 – TCKI6R[7:0] Assign SCCP Timer6 (TCKI6) Input to the Corresponding RPn Pin bits ### 8.12.11 Peripheral Pin Select Input Register 9 Name: RPINR9 Offset: 0xD16 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--| | | | | | ICM7 | R[7:0] | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TCKI7R[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:8 - ICM7R[7:0] Assign SCCP Capture 7 (ICM7) Input to the Corresponding RPn Pin bits Bits 7:0 – TCKI7R[7:0] Assign SCCP Timer7 (TCKI7) Input to the Corresponding RPn Pin bits #### 8.12.12 Peripheral Pin Select Input Register 10 Name: RPINR10 Offset: 0xD18 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | ICM8R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TCKI8 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - ICM8R[7:0] Assign SCCP Capture 8 (ICM8) Input to the Corresponding RPn Pin bits Bits 7:0 – TCKI8R[7:0] Assign SCCP Timer8 (TCKI8) Input to the Corresponding RPn Pin bits #### 8.12.13 Peripheral Pin Select Input Register 11 Name: RPINR11 Offset: 0xD1A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | OCFBR[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | OCFAR[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - OCFBR[7:0] Assign SCCP Fault B (OCFB) Input to the Corresponding RPn Pin bits Bits 7:0 - OCFAR[7:0] Assign SCCP Fault A (OCFA) Input to the Corresponding RPn Pin bits #### 8.12.14 Peripheral Pin Select Input Register 12 Name: RPINR12 Offset: 0xD1C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PCI9R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PC 8R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - PCI9R[7:0] Assign PWM Input 9 (PCI9) to the Corresponding RPn Pin bits Bits 7:0 - PCI8R[7:0] Assign PWM Input 8 (PCI8) to the Corresponding RPn Pin bits #### 8.12.15 Peripheral Pin Select Input Register 13 Name: RPINR13 Offset: 0xD1E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | PCI11R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PCI10 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - PCI11R[7:0] Assign PWM Input 11 (PCI11) to the Corresponding RPn Pin bits Bits 7:0 - PCI10R[7:0] Assign PWM Input 10 (PCI10) to the Corresponding RPn Pin bits #### 8.12.16 Peripheral Pin Select Input Register 14 Name: RPINR14 Offset: 0xD20 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | QEIB1R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | QEIA1 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - QEIB1R[7:0] Assign QEI Input B (QEIB1) to the Corresponding RPn Pin bits Bits 7:0 - QEIA1R[7:0] Assign QEI Input A (QEIA1) to the Corresponding RPn Pin bits I/O Ports #### 8.12.17 Peripheral Pin Select Input Register 15 Name: RPINR15 Offset: 0xD22 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|---------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | QEIHOM1R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | QEINDX1R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - QEIHOM1R[7:0] Assign QEI Home 1 Input (QEIHOM1) to the Corresponding RPn Pin bits Bits 7:0 - QEINDX1R[7:0] Assign QEI Index 1 Input (QEINDX1) to the Corresponding RPn Pin bits #### 8.12.18 Peripheral Pin Select Input Register 16 Name: RPINR16 Offset: 0xD24 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | QEIB2R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | QEIA2 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - QEIB2R[7:0] Assign QEI2 Input B (QEIB2) to the Corresponding RPn Pin bits Bits 7:0 - QEIA2R[7:0] Assign QEI2 Input A (QEIA2) to the Corresponding RPn Pin bits #### 8.12.19 Peripheral Pin Select Input Register 17 Name: RPINR17 Offset: 0xD26 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|-----------|-----|-----|-----| | | | | | QEIHON | //2R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | QEIND | (2R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - QEIHOM2R[7:0] Assign QEI Home 2 Input (QEIHOM2) to the Corresponding RPn Pin bits Bits 7:0 - QEINDX2R[7:0] Assign QEI Index 2 Input (QEINDX2) to the Corresponding RPn Pin bits I/O Ports #### 8.12.20 Peripheral Pin Select Input Register 18 Name: RPINR18 Offset: 0xD28 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | U1DSRR[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | U1RX | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 – U1DSRR[7:0] Assign UART1 Data-Set-Ready (U1DSR) to the Corresponding RPn Pin bits Bits 7:0 - U1RXR[7:0] Assign UART1 Receive (U1RX) to the Corresponding RPn Pin bits #### 8.12.21 Peripheral Pin Select Input Register 19 Name: RPINR19 Offset: 0xD2A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | U2DSRR[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | U2RX | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 – U2DSRR[7:0] Assign UART2 Data-Set-Ready (U2DSR) to the Corresponding RPn Pin bits Bits 7:0 - U2RXR[7:0] Assign UART2 Receive (U2RX) to the Corresponding RPn Pin bits #### 8.12.22 Peripheral Pin Select Input Register 20 Name: RPINR20 Offset: 0xD2C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|------------|-----|-----|------|--------|-----|-----|-----|--|--| | | SCK1R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | SDI1 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - SCK1R[7:0] Assign SPI1 Clock Input (SCK1IN) to the Corresponding RPn Pin bits Bits 7:0 - SDI1R[7:0] Assign SPI1 Data Input (SDI1) to the Corresponding RPn Pin bits #### 8.12.23 Peripheral Pin Select Input Register 21 Name: RPINR21 Offset: 0xD2E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | REFOIR[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | SS1F | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - REFOIR[7:0] Assign Reference Clock Input (REFOI) to the Corresponding RPn Pin bits Bits 7:0 – SS1R[7:0] Assign SPI1 Client Select $(\overline{SS1})$ to the Corresponding RPn Pin bits #### 8.12.24 Peripheral Pin Select Input Register 22 Name: RPINR22 Offset: 0xD30 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | SCK2R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | SDI2I | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - SCK2R[7:0] Assign SPI2 Clock Input (SCK2IN) to the Corresponding RPn Pin bits Bits 7:0 - SDI2R[7:0] Assign SPI2 Data Input (SDI2) to the Corresponding RPn Pin bits ## I/O Ports ### 8.12.25 Peripheral Pin Select Input Register 23 Name: RPINR23 Offset: 0xD32 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-----------|-----|-----|-----|-----|-----|-----|-----|--| | | | | | | | | | | | | Access | | , | | | | , | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | SS2R[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 7:0 – SS2R[7:0] Assign SPI2 Client Select $(\overline{SS2})$ to the Corresponding RPn Pin bits #### I/O Ports #### 8.12.26 Peripheral Pin Select Input Register 24 Name: RPINR24 Offset: 0xD34 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-------|---------|-----|-----|-----|--|--| | | QEIB3R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | QEIA3 | BR[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - QEIB3R[7:0] Assign QEI Input B3 (QEIB3) to the Corresponding RPn Pin bits Bits 7:0 - QEIA3R[7:0] Assign QEI Input A3 (QEIA3) to the Corresponding RPn Pin bits #### 8.12.27 Peripheral Pin Select Input Register 25 Name: RPINR25 Offset: 0xD36 Bits 7:0 - QEINDX3R[7:0] Assign QEI Index 3 Input (QEINDX3) to the Corresponding RPn Pin bits #### 8.12.28 Peripheral Pin Select Input Register 26 Name: RPINR26 Offset: 0xD38 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|--------------|-----|-----|-------|---------|-----|-----|-----|--|--| | | CAN2RXR[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | CAN1R | XR[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - CAN2RXR[7:0] Assign CAN2 Input (CAN2RX) to the Corresponding RPn Pin bits Bits 7:0 - CAN1RXR[7:0] Assign CAN1 Input (CAN1RX) to the Corresponding RPn Pin bits #### 8.12.29 Peripheral Pin Select Input Register 27 Name: RPINR27 Offset: 0xD3A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | U3DSRR[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | U3RX | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 – U3DSRR[7:0] Assign UART3 Data-Set-Ready (U3DSR) to the Corresponding RPn Pin bits Bits 7:0 - U3RXR[7:0] Assign UART3 Receive (U3RX) to the Corresponding RPn Pin bits #### 8.12.30 Peripheral Pin Select Input Register 29 Name: RPINR29 Offset: 0xD3E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|------------|-----|-----|------|--------|-----|-----|-----|--|--| | | SCK3R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | SDI3 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - SCK3R[7:0] Assign SPI3 Clock Input (SCK3IN) to the Corresponding RPn Pin bits Bits 7:0 - SDI3R[7:0] Assign SPI3 Data Input (SDI3) to the Corresponding RPn Pin bits ## I/O Ports ### 8.12.31 Peripheral Pin Select Input Register 30 Name: RPINR30 Offset: 0xD40 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|-----|-----|-----|------|--------|-----|-----|-----| | Access<br>Reset | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | SS3F | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 – SS3R[7:0] Assign SPI3 Client Select (SS3) to the Corresponding RPn Pin bits ## 8.12.32 Peripheral Pin Select Input Register 32 Name: RPINR32 Offset: 0xD44 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|--------|-----|-----|-----| | | | | | TCKI9 | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset Bits 15:8 - TCKI9R[7:0] Assign MCCP Timer9 Input (TCKI9) to the Corresponding RPn Pin bits # dsPIC33CK512MP608 Family I/O Ports ### 8.12.33 Peripheral Pin Select Input Register 33 Name: RPINR33 Offset: 0xD46 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|--------|-----|-----|-----| | ^ | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | ICM9I | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - ICM9R[7:0] Assign MCCP Capture 9 Input (ICM9) to the Corresponding RPn Pin bits #### I/O Ports #### 8.12.34 Peripheral Pin Select Input Register 37 Name: RPINR37 Offset: 0xD4E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|------|--------|-----|-----|-----|--|--| | | PCI17R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | OCFD | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - PCI17R[7:0] Assign PWM Input 17 (PCI17) to the Corresponding RPn Pin bits Bits 7:0 – OCFDR[7:0] Assign xCCP Fault D (OCFD) to the Corresponding RPn Pin bits **I/O Ports** ## 8.12.35 Peripheral Pin Select Input Register 38 Name: RPINR38 Offset: 0xD50 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|-----|-----|-----|-------|---------|-----|-----|-----| | Access<br>Reset | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PCI18 | BR[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - PCI18R[7:0] Assign PWM Input 18 (PCI18) to the Corresponding RPn Pin bits I/O Ports #### 8.12.36 Peripheral Pin Select Input Register 42 Name: RPINR42 Offset: 0xD58 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | PCI13R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PCI12 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - PCI13R[7:0] Assign PWM Input 13 (PCI13) to the Corresponding RPn Pin bits Bits 7:0 - PCI12R[7:0] Assign PWM Input 12 (PCI12) to the Corresponding RPn Pin bits #### 8.12.37 Peripheral Pin Select Input Register 43 Name: RPINR43 Offset: 0xD5A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-------|--------|-----|-----|-----|--|--| | | PCI15R[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PCI14 | R[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:8 - PCI15R[7:0] Assign PWM Input 15 (PCI15) to the Corresponding RPn Pin bits Bits 7:0 - PCI14R[7:0] Assign PWM Input 14 (PCI14) to the Corresponding RPn Pin bits #### 8.12.38 Peripheral Pin Select Input Register 44 Name: RPINR44 Offset: 0xD5C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-------------|-----|-----|-------|--------|-----|-----|-----|--| | | SENT1R[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | PCI16 | R[7:0] | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:8 - SENT1R[7:0] Assign SENT1 Input (SENT1) to the Corresponding RPn Pin bits Bits 7:0 - PCI16R[7:0] Assign PWM Input 16 (PCI16) to the Corresponding RPn Pin bits #### 8.12.39 Peripheral Pin Select Input Register 45 Name: RPINR45 Offset: 0xD5E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----|--------------|-----|-------|---------|-----|-----|-----|--|--|--| | | | CLCINAR[7:0] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | SENT2 | 2R[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 - CLCINAR[7:0] Assign CLC Input A (CLCINA) to the Corresponding RPn Pin bits Bits 7:0 - SENT2R[7:0] Assign SENT2 Input (SENT2) to the Corresponding RPn Pin bits # dsPIC33CK512MP608 Family I/O Ports #### 8.12.40 Peripheral Pin Select Input Register 46 Name: RPINR46 Offset: 0xD60 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | CLCIN | CR[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | CLCIN | BR[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - CLCINCR[7:0] Assign CLC Input C (CLCINC) to the Corresponding RPn Pin bits Bits 7:0 - CLCINBR[7:0] Assign CLC Input B (CLCINB) to the Corresponding RPn Pin bits **Datasheet** #### 8.12.41 Peripheral Pin Select Input Register 47 Name: RPINR47 Offset: 0xD62 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 0 | 0 | |--------|-----|----------|-------|-------|---------|-------|-----|-----| | DIL | 13 | 14 | 13 | | | 10 | 9 | | | | | | | ADCTR | GR[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Official | - VAP | CLCIN | DR[7:0] | 23.00 | | Ī | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - ADCTRGR[7:0] Assign ADC Trigger Input (ADCTRG) to the Corresponding RPn Pin bits Bits 7:0 - CLCINDR[7:0] Assign CLC Input D (CLCIND) to the Corresponding RPn Pin bits #### 8.12.42 Peripheral Pin Select Input Register 48 Name: RPINR48 Offset: 0xD64 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | U1CTS | SR[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | OCFD | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 – U1CTSR[7:0] Assign UART1 Clear-to-Send (U1CTS) to the Corresponding RPn Pin bits Bits 7:0 - OCFDR[7:0] Assign xCCP Fault D (OCFD) to the Corresponding RPn Pin bits #### 8.12.43 Peripheral Pin Select Input Register 49 Name: RPINR49 Offset: 0xD66 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----|-------------|-----|-------|---------|-----|-----|-----|--|--|--| | | | U3CTSR[7:0] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | U2CTS | SR[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 - U3CTSR[7:0] Assign UART3 Clear-to-Send (U3CTS) to the Corresponding RPn Pin bits Bits 7:0 – U2CTSR[7:0] Assign UART2 Clear-to-Send ( $\overline{\text{U2CTS}}$ ) to the Corresponding RPn Pin bits #### 8.12.44 Peripheral Pin Select Output Register 0 Name: RPOR0 Offset: 0xD80 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--| | | | | | RP33R[5:0] | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RP32 | R[5:0] | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 13:8 - RP33R[5:0] Peripheral Output Function is Assigned to RP33 Output Pin bits Bits 5:0 – RP32R[5:0] Peripheral Output Function is Assigned to RP32 Output Pin bits #### 8.12.45 Peripheral Pin Select Output Register 1 Name: RPOR1 Offset: 0xD82 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--| | | | | | RP35R[5:0] | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RP34 | R[5:0] | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 13:8 - RP35R[5:0] Peripheral Output Function is Assigned to RP35 Output Pin bits Bits 5:0 – RP34R[5:0] Peripheral Output Function is Assigned to RP34 Output Pin bits #### 8.12.46 Peripheral Pin Select Output Register 2 Name: RPOR2 Offset: 0xD84 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--| | | | | | RP37R[5:0] | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RP36 | R[5:0] | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 13:8 - RP37R[5:0] Peripheral Output Function is Assigned to RP37 Output Pin bits Bits 5:0 – RP36R[5:0] Peripheral Output Function is Assigned to RP36 Output Pin bits #### 8.12.47 Peripheral Pin Select Output Register 3 Name: RPOR3 Offset: 0xD86 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP39 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP38 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP39R[5:0] Peripheral Output Function is Assigned to RP39 Output Pin bits Bits 5:0 – RP38R[5:0] Peripheral Output Function is Assigned to RP38 Output Pin bits #### 8.12.48 Peripheral Pin Select Output Register 4 Name: RPOR4 Offset: 0xD88 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP41 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP40 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP41R[5:0] Peripheral Output Function is Assigned to RP41 Output Pin bits Bits 5:0 – RP40R[5:0] Peripheral Output Function is Assigned to RP40 Output Pin bits #### 8.12.49 Peripheral Pin Select Output Register 5 Name: RPOR5 Offset: 0xD8A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP43 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP42 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP43R[5:0] Peripheral Output Function is Assigned to RP43 Output Pin bits Bits 5:0 – RP42R[5:0] Peripheral Output Function is Assigned to RP42 Output Pin bits #### 8.12.50 Peripheral Pin Select Output Register 6 Name: RPOR6 Offset: 0xD8C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP45 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP44 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP45R[5:0] Peripheral Output Function is Assigned to RP45 Output Pin bits Bits 5:0 – RP44R[5:0] Peripheral Output Function is Assigned to RP44 Output Pin bits #### 8.12.51 Peripheral Pin Select Output Register 7 Name: RPOR7 Offset: 0xD8E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP47 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP46 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP47R[5:0] Peripheral Output Function is Assigned to RP47 Output Pin bits Bits 5:0 – RP46R[5:0] Peripheral Output Function is Assigned to RP46 Output Pin bits #### 8.12.52 Peripheral Pin Select Output Register 8 Name: RPOR8 Offset: 0xD90 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP49 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP48 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP49R[5:0] Peripheral Output Function is Assigned to RP49 Output Pin bits Bits 5:0 – RP48R[5:0] Peripheral Output Function is Assigned to RP48 Output Pin bits #### 8.12.53 Peripheral Pin Select Output Register 9 Name: RPOR9 Offset: 0xD92 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP51 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP50 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 – RP51R[5:0] Peripheral Output Function is Assigned to RP51 Output Pin bits Bits 5:0 – RP50R[5:0] Peripheral Output Function is Assigned to RP50 Output Pin bits ### 8.12.54 Peripheral Pin Select Output Register 10 Name: RPOR10 Offset: 0xD94 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP53 | 3[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP52 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP53[5:0] Peripheral Output Function is Assigned to RP53 Output Pin bits Bits 5:0 – RP52R[5:0] Peripheral Output Function is Assigned to RP52 Output Pin bits #### 8.12.55 Peripheral Pin Select Output Register 11 Name: RPOR11 Offset: 0xD96 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP55 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP54 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 – RP55R[5:0] Peripheral Output Function is Assigned to RP55 Output Pin bits Bits 5:0 – RP54R[5:0] Peripheral Output Function is Assigned to RP54 Output Pin bits #### 8.12.56 Peripheral Pin Select Output Register 12 Name: RPOR12 Offset: 0xD98 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP57 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP56 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 – RP57R[5:0] Peripheral Output Function is Assigned to RP57 Output Pin bits Bits 5:0 – RP56R[5:0] Peripheral Output Function is Assigned to RP56 Output Pin bits #### 8.12.57 Peripheral Pin Select Output Register 13 Name: RPOR13 Offset: 0xD9A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|------|--------|-----|-----| | | | | | | RP59 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP58 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 - RP59R[5:0] Peripheral Output Function is Assigned to RP59 Output Pin bits Bits 5:0 – RP58R[5:0] Peripheral Output Function is Assigned to RP58 Output Pin bits # 8.12.58 Peripheral Pin Select Output Register 14 Name: RPOR14 Offset: 0xD9C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--|--| | | | | | RP61R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP60 | R[5:0] | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 - RP61R[5:0] Peripheral Output Function is Assigned to RP61 Output Pin bits Bits 5:0 – RP60R[5:0] Peripheral Output Function is Assigned to RP60 Output Pin bits # 8.12.59 Peripheral Pin Select Output Register 15 Name: RPOR15 Offset: 0xD9E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--|--| | | | | | RP63R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP62 | R[5:0] | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 - RP63R[5:0] Peripheral Output Function is Assigned to RP63 Output Pin bits Bits 5:0 – RP62R[5:0] Peripheral Output Function is Assigned to RP62 Output Pin bits # 8.12.60 Peripheral Pin Select Output Register 16 Name: RPOR16 Offset: 0xDA0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|-----|-----|-----|-----|--|--|--| | | | | | RP65R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RP64R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 – RP65R[5:0] Peripheral Output Function is Assigned to RP65 Output Pin bits Bits 5:0 – RP64R[5:0] Peripheral Output Function is Assigned to RP64 Output Pin bits # 8.12.61 Peripheral Pin Select Output Register 17 Name: RPOR17 Offset: 0xDA2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|----|------------|------|--------|----|----|--|--|--| | | | | | RP67R[5:0] | | | | | | | | | Access | | | RW | RW | RW | RW | RW | RW | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP66 | R[5:0] | | | | | | | Access | | | RW | RW | RW | RW | RW | RW | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 - RP67R[5:0] Peripheral Output Function is Assigned to RP67 Output Pin bits Bits 5:0 – RP66R[5:0] Peripheral Output Function is Assigned to RP66 Output Pin bits # 8.12.62 Peripheral Pin Select Output Register 18 Name: RPOR18 Offset: 0xDA4 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|-----|-----|-----|-----|--|--|--| | | | | | RP69R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RP68R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 - RP69R[5:0] Peripheral Output Function is Assigned to RP69 Output Pin bits Bits 5:0 – RP68R[5:0] Peripheral Output Function is Assigned to RP68 Output Pin bits # 8.12.63 Peripheral Pin Select Output Register 19 Name: RPOR19 Offset: 0xDA6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--|--| | | | | | RP71R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP70 | R[5:0] | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 - RP71R[5:0] Peripheral Output Function is Assigned to RP71 Output Pin bits Bits 5:0 – RP70R[5:0] Peripheral Output Function is Assigned to RP70 Output Pin bits # 8.12.64 Peripheral Pin Select Output Register 20 Name: RPOR20 Offset: 0xDA8 #### Note: 1. These are virtual output ports. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|-----|-----|-----|-----|--|--|--| | | | | | RP73R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RP72R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 - RP73R[5:0] Peripheral Output Function is Assigned to RP73 Output Pin bits<sup>(1)</sup> Bits 5:0 – RP72R[5:0] Peripheral Output Function is Assigned to RP72 Output Pin bits<sup>(1)</sup> # 8.12.65 Peripheral Pin Select Output Register 21 Name: RPOR21 Offset: 0xDAA #### Note: 1. These are virtual output ports. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----|----|-----|------------|-----|-----|-----|-----|--|--| | | | | | RP75R[5:0] | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | RP74R[5:0] | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 13:8 – RP75R[5:0] Peripheral Output Function is Assigned to RP75 Output Pin bits<sup>(1)</sup> Bits 5:0 – RP74R[5:0] Peripheral Output Function is Assigned to RP74 Output Pin bits<sup>(1)</sup> # 8.12.66 Peripheral Pin Select Output Register 22 Name: RPOR22 Offset: 0xDAC #### Note: 1. These are virtual output ports. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--|--| | | | | | RP77R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP76 | R[5:0] | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 – RP77R[5:0] Peripheral Output Function is Assigned to RP77 Output Pin bits<sup>(1)</sup> Bits 5:0 – RP76R[5:0] Peripheral Output Function is Assigned to RP76 Output Pin bits<sup>(1)</sup> # 8.12.67 Peripheral Pin Select Output Register 23 Name: RPOR23 Offset: 0xDAE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|------------|------|--------|-----|-----|--|--|--| | | | | | RP79R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP78 | R[5:0] | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 - RP79R[5:0] Peripheral Output Function is Assigned to RP79 Output Pin bits Bits 5:0 – RP78R[5:0] Peripheral Output Function is Assigned to RP78 Output Pin bits # 8.12.68 Peripheral Pin Select Output Register 24 Name: RPOR24 Offset: 0xDB0 #### Note: 1. These are virtual output ports. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|-------------|-------|---------|-----|-----|--|--|--| | | | | | RP177R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP176 | SR[5:0] | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 – RP177R[5:0] Peripheral Output Function is Assigned to RP177 Output Pin bits<sup>(1)</sup> Bits 5:0 - RP176R[5:0] Peripheral Output Function is Assigned to RP176 Output Pin bits<sup>(1)</sup> # 8.12.69 Peripheral Pin Select Output Register 25 Name: RPOR25 Offset: 0xDB2 #### Note: 1. These are virtual output ports. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----|----|-----|-------------|-------|---------|-----|-----|--|--|--| | | | | | RP179R[5:0] | | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | RP178 | BR[5:0] | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 13:8 – RP179R[5:0] Peripheral Output Function is Assigned to RP179 Output Pin bits<sup>(1)</sup> Bits 5:0 - RP178R[5:0] Peripheral Output Function is Assigned to RP178 Output Pin bits<sup>(1)</sup> # 8.12.70 Peripheral Pin Select Output Register 26 Name: RPOR26 Offset: 0xDB4 #### Note: 1. These are virtual output ports. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----|-----|-------|--------|-----|-----| | | | | | | RP181 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RP180 | R[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:8 – RP181R[5:0] Peripheral Output Function is Assigned to RP181 Output Pin bits<sup>(1)</sup> Bits 5:0 - RP180R[5:0] Peripheral Output Function is Assigned to RP180 Output Pin bits<sup>(1)</sup> # 9. Oscillator with High-Frequency PLL **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Oscillator Module with High-Speed PLL" (www.microchip.com/DS70005255) in the "dsPIC33/PIC24 Family Reference Manual". The dsPIC33CK512MP608 family oscillator with high-frequency PLL includes these characteristics: - On-Chip Phase-Locked Loop (PLL) to Boost Internal Operating Frequency on Select Internal and External Oscillator Sources - · Auxiliary PLL (APLL) Clock Generator to Boost Operating Frequency for Peripherals - Doze mode for System Power Savings - Scalable Reference Clock Output (REFCLKO) - On-the-Fly Clock Switching between Various Clock Sources - Fail-Safe Clock Monitoring (FSCM) that Detects Clock Failure and Permits Safe Application Recovery or Shutdown A block diagram of the dsPIC33CK512MP608 oscillator system is shown in Figure 9-1. Figure 9-1. dsPIC33CK512MP608 Core Clock Sources Block Diagram Figure 9-2. dsPIC33CK512MP608 Oscillator Subsystem # 9.1 Primary PLL The Primary Oscillator and internal FRC Oscillator sources can optionally use an on-chip PLL to obtain higher operating speeds. Figure 9-3 illustrates a block diagram of the Primary PLL module. For PLL operation, the following requirements must be met at all times without exception: - The PLL Input Frequency (FPLLI) must be in the range of 8 MHz to 64 MHz - The PFD Input Frequency (F<sub>PFD</sub>) must be in the range of 8 MHz to (F<sub>VCO</sub>/16) MHz The VCO Output Frequency (F<sub>VCO</sub>) must be in the range of 400 MHz to 1600 MHz Figure 9-3. Primary Core PLL And VCO Detail Note 1: Clock option for PWM. 2: Clock option for ADC. 3: Clock option for DAC. 4: PLL source is always FRC unless FNOSC is the Primary Oscillator with PLL. Equation 9-1 provides the relationship between the PLL Input Frequency (F<sub>PLLI</sub>) and VCO Output Frequency (F<sub>VCO</sub>). Equation 9-1. Primary Core F<sub>VCO</sub> Calculation $$FVCO = FPLLI \times \left(\frac{M}{N1}\right) = FPLLI \times \left(\frac{PLLFBDIV[7:0]}{PLLPRE[3:0]}\right)$$ # Oscillator with High-Frequency PLL Equation 9-2 provides the relationship between the PLL Input Frequency (F<sub>PLLI</sub>) and PLL Output Frequency (F<sub>PLLO</sub>). #### Equation 9-2. Primary Core F<sub>PLLO</sub> Calculation $$FPLLO = FPLLI \times \left(\frac{M}{N1 \times N2 \times N3}\right) = FPLLI \times \left(\frac{PLLFBDIV[7:0]}{PLLPRE[3:0] \times POST1DIV[2:0] \times POST2DIV[2:0]}\right)$$ #### Where: M = PLLFBDIV[7:0] N1 = PLLPRE[3:0] N2 = POST1DIV[2:0]N3 = POST2DIV[2:0] **Note:** The PLL Phase Detector Input Divider Select (PLLPREx) bits and the PLL Feedback Divider (PLLFBDIVx) bits should not be changed when operating in PLL mode. Therefore, the user must start on either a non-PLL source or clock switch to a non-PLL source (e.g., internal FRC Oscillator) to make any necessary changes and then clock switch to the desired PLL source. Using Two-Speed Start-up (IESO (FOSCSEL[7])) with a PLL source will start the device on the FRC while preparing the PLL. Once the PLL is ready, the device will switch automatically to the new source. This mode should not be used if changes are needed to the PLLPREx and PLLFBDIVx bits because the PLL may be running before user code execution begins. It is not permitted to directly clock switch from one PLL clock source to a different PLL clock source. The user would need to transition between PLL clock sources with a clock switch to a non-PLL clock source. **Note:** $F_{PLLO} = F_{PLLI} * M/(N1 * N2 * N3); F_{PLLI} = 8; M = 125; N1 = 1; N2 = 5; N3 = 1; so <math>F_{PLLO} = 8 * 125/(1 * 5 * 1) = 200 \text{ MHz} \text{ or } 50 \text{ MIPS}.$ # 9.2 Auxiliary PLL The dsPIC33CK512MP608 device family implements an Auxiliary PLL (APLL) module for each core present. The APLL is used to generate various peripheral clock sources independent of the system clock. Figure 9-4 shows a block diagram of the Auxiliary core APLL module. For APLL operation, the following requirements must be met at all times without exception: - The APLL Input Frequency (AF<sub>PLLI</sub>) must be in the range of 8 MHz to 64 MHz - The APFD Input Frequency (AF<sub>PFD</sub>) must be in the range of 8 MHz to (AF<sub>VCO</sub>/16) MHz - The AVCO Output Frequency (AF $_{ m VCO}$ ) must be in the range of 400 MHz to 1600 MHz Figure 9-4. Auxiliary Core APLL and VCO Detail Equation 9-3 provides the relationship between the APLL Input Frequency (AF<sub>PLLI</sub>) and the AVCO Output Frequency (AF<sub>VCO</sub>). ## Equation 9-3. Auxiliary Core AF<sub>VCO</sub> Calculation $$FVCO = FPLLI \times \left(\frac{M}{N!}\right) = FPLLI \times \left(\frac{PLLFBDIV}{PLLPRE} [3:0]\right)$$ Equation 9-4 provides the relationship between the APLL Input Frequency (AF<sub>PLLI</sub>) and APLL Output Frequency (AF<sub>PLLO</sub>). #### Equation 9-4. Auxiliary Core AF<sub>PLLO</sub> Calculation $$AFPLLO = AFPLLI \times \left(\frac{M}{N1 \times N2 \times N3}\right) = AFPLLI \times \left(\frac{APLLFBDIV [7:0]}{APLLPRE [3:0] \times APOSTIDIV [2:0] \times APOST2DIV [2:0]}\right)$$ Where: M = APLLFBDIV[7:0] N1 = APLLPRE[3:0] N2 = APOST1DIV[2:0] N3 = APOST2DIV[2:0] # Example 9-2. Code for Using Auxiliary PLL with the Internal FRC Oscillator **Note:** Even with the APLLEN bit set, another peripheral must generate a clock request before the APLL will start. # 9.3 CPU Clocking The dsPIC33CK512MP608 devices can be configured to use any of the following clock configurations: - · Primary Oscillator (POSC) on the OSCI and OSCO pins - · Internal Fast RC (FRC) Oscillator with optional clock divider - · Internal Low-Power RC Oscillator - Primary Oscillator with PLL (ECPLL, HSPLL, XTPLL) - Internal Fast RC Oscillator with PLL (FRCPLL) - Backup Internal Fast RC Oscillator (BFRC) The system clock source is divided by two to produce the internal instruction cycle clock. In this document, the instruction cycle clock is denoted by $F_{CY}$ . The timing diagram in Figure 9-5 illustrates the relationship between the system clock ( $F_{OSC}$ ), the instruction cycle clock ( $F_{CY}$ ) and the Program Counter (PC). The internal instruction cycle clock (F<sub>CY</sub>) can be output on the OSCO I/O pin if the Primary Oscillator mode (POSCMD[1:0]) is not configured as HS/XT. For more information, see 9. Oscillator with High-Frequency PLL. Figure 9-5. Clock and Instruction Cycle Timing # 9.4 Primary Oscillator (POSC) The dsPIC33CK512MP608 family devices contain one instance of the Primary Oscillator (POSC). The Primary Oscillator is available on the OSCI and OSCO pins of the dsPIC33CK devices. This connection enables an external crystal (or ceramic resonator) to provide the clock to the device. The Primary Oscillator provides three modes of operation: - Medium Speed Oscillator (XT Mode): The XT mode is a Medium Gain, Medium Frequency mode used to work with crystal frequencies of 3.5 MHz to 10 MHz. - High-Speed Oscillator (HS Mode): The HS mode is a High-Gain, High-Frequency mode used to work with crystal frequencies of 10 MHz to 32 MHz. - External Clock Source Operation (EC Mode): If the on-chip oscillator is not used, the EC mode allows the internal oscillator to be bypassed. The device clocks are generated from an external source (0 MHz to up to 64 MHz) and input on the OSCI pin. Example 9-3 illustrates code for using the PLL (50 MIPS) with the Primary Oscillator. ``` Example 9-3. Code for Using PLL (50 MIPS) with Primary Oscillator (POSC) //code example for 50 MIPS system clock using POSC with 10 MHz external crystal // Select FRC on POR config FNOSC = FRC // Oscillator Source Selection #pragma (Internal Fast RC (FRC)) config #pragma /// Enable Clock Switching and Configure POSC in XT mode POSCMD = XT #pragma config #pragma config FCKSM = CSECMD main() // Configure PLL prescaler, both PLL postscalers, and PLL feedback divider CLKDIVbits.PLLPRE = 1; // N1=1 PLLFBDbits.PLLFBDIV = 100; // M = 100 PLLDIVbits.POST1DIV = 5; // N2=5 // N3=1 PLLDIVbits.POST2DIV = 1; // Initiate Clock Switch to Primary Oscillator with PLL (NOSC=0b011) _builtin_write_OSCCONH(0x03); builtin write OSCCONL(OSCCON | 0x01); // Wait for Clock switch to occur while (OSCCONbits.OSWEN!= 0); // Wait for PLL to lock while (OSCCONbits.LOCK!= 1); ``` # 9.5 Internal Fast RC (FRC) Oscillator The dsPIC33CK512MP608 family devices contain one instance of the internal Fast RC (FRC) Oscillator. The FRC Oscillator provides a nominal 8 MHz clock without requiring an external crystal or ceramic resonator, which results in system cost savings for applications that do not require a precise clock reference. The application software can tune the frequency of the oscillator using the FRC Oscillator Tuning bits (TUN[5:0]) in the FRC Oscillator Tuning register (OSCTUN[5:0]). # 9.6 Low-Power RC Oscillator The dsPIC33CK512MP608 family devices contain one instance of the Low-Power RC (LPRC) Oscillator, which provides a nominal clock frequency of 32.768 kHz. The dsPIC33CK512MP608 family devices implement the LPRC function with the BFRC and post-divider to yield a 50% duty cycle output. # Oscillator with High-Frequency PLL The LPRC is the clock source for the Watchdog Timer (WDT) and Fail-Safe Clock Monitor (FSCM) circuits in the clock subsystem. The LPRC Oscillator is shut off in Sleep mode. The LPRC Oscillator remains enabled under these conditions: - · The FSCM is enabled - · The WDT is enabled - · The LPRC Oscillator is selected as the system clock # 9.7 Backup Internal Fast RC (BFRC) Oscillator The oscillator block provides a stable reference clock source for the Fail-Safe Clock Monitor (FSCM). When FSCM is enabled in the FCKSM[1:0] Configuration bits (FOSC[7:6]), it constantly monitors the main clock source against a reference signal from the 8 MHz Backup Internal Fast RC (BFRC) Oscillator. In case of a clock failure, the Fail-Safe Clock Monitor switches the clock to the BFRC Oscillator, allowing for continued low-speed operation or a safe application shutdown. # 9.8 Reference Clock Output In addition to the CLKO output (F<sub>OSC</sub>/2), the dsPIC33CK512MP608 family devices can be configured to provide a reference clock output signal to a port pin. This feature is available in all oscillator configurations and allows the user to select a greater range of clock submultiples to drive external devices in the application. CLKO is enabled by Configuration bit, OSCIOFNC, and is independent of the REFCLKO reference clock. REFCLKO is mappable to any I/O pin that has mapped output capability. The reference clock output module block diagram is shown in Figure 9-6. Figure 9-6. Reference Clock Generator This reference clock output is controlled by the REFOCONL and REFOCONH registers. Setting the ROEN bit (REFOCONL[15]) makes the clock signal available on the REFCLKO pin. The RODIV[14:0] bits (REFOCONH[14:0]) and ROTRIM[8:0] bits (REFOTRIM[15:7]) enable the selection of different clock divider options. The formula for determining the final frequency output is shown in Equation 9-5. The ROSWEN bit (REFOCONL[9]) indicates that the clock divider has been successfully switched. In order to switch the REFCLKO divider, the user should ensure that this bit reads as '0'. Write the updated values to the RODIV[14:0] or ROTRIM[8:0] bits, set the ROSWEN bit and then wait until it is cleared before assuming that the REFCLKO clock is valid. #### **Equation 9-5. Calculating Frequency Output** $$F_{REFOUT} = \frac{F_{REFIN}}{2 \cdot (RODIV[14:0] + ROTRIM[8:0]/512)}$$ Where: FREFOUT = Output Frequency FREFIN = Input Frequency When RODIV[14:0] = 0, the output clock is the same as the input clock. The ROSEL[3:0] bits (REFOCONL[3:0]) determine which clock source is used for the reference clock output. The ROSLP bit (REFOCONL[11]) determines if the reference source is available on REFCLKO when the device is in Sleep mode. To use the reference clock output in Sleep mode, both the ROSLP bit must be set and the clock selected by the ROSEL[3:0] bits must be enabled for operation during Sleep mode, if possible. Clearing the ROSEL[3:0] bits allows the reference output frequency to change, as the system clock changes during any clock switches. The ROOUT bit enables/disables the reference clock output on the REFCLKO pin. The ROACTIV bit (REFOCONL[8]) indicates that the module is active; it can be cleared by disabling the module (setting ROEN to '0'). The user must not change the reference clock source, or adjust the divider when the ROACTIV bit indicates that the module is active. To avoid glitches, the user should not disable the module until the ROACTIV bit is '1'. # 9.9 Oscillator Configuration The oscillator system has both Configuration registers and SFRs to configure, control and monitor the system. The FOSCSEL and FOSC Configuration registers (FOSCSEL and FOSC, respectively) are used for initial setup. Table 9-1 lists the configuration settings that select the device's oscillator source and operating mode at a Power-on Reset (POR). Table 9-1. Configuration Bit Values for Clock Selection | Oscillator<br>Source | Oscillator Mode | FNOSC[2:0]<br>Value | POSCMD[1:0]<br>Value | Notes | |----------------------|--------------------------------------|---------------------|----------------------|--------| | S0 | Fast RC Oscillator (FRC) | 000 | XX | Note 1 | | S1 | Fast RC Oscillator with PLL (FRCPLL) | 001 | xx | Note 1 | | S2 | Primary Oscillator (EC) | 010 | 00 | Note 1 | | S2 | Primary Oscillator (XT) | 010 | 01 | | | S2 | Primary Oscillator (HS) | 010 | 10 | | | S3 | Primary Oscillator with PLL (ECPLL) | 011 | 00 | Note 1 | | S3 | Primary Oscillator with PLL (XTPLL) | 011 | 01 | | | S3 | Primary Oscillator with PLL (HSPLL) | 011 | 10 | | | S4 | Reserved | 100 | XX | | | S5 | Low-Power RC Oscillator (LPRC) | 101 | xx | Note 1 | #### Notes: - 1. The OSCO pin function is determined by the OSCIOFNC Configuration bit. - 2. This is the default oscillator mode for an unprogrammed (erased) device. # Oscillator with High-Frequency PLL | continued | | | | | | | |----------------------|-----------------------------------------------|---------------------|----------------------|-------------------|--|--| | Oscillator<br>Source | Oscillator Mode | FNOSC[2:0]<br>Value | POSCMD[1:0]<br>Value | Notes | | | | S6 | Backup FRC (BFRC) | 110 | XX | Note 1 | | | | S7 | Fast RC Oscillator with ÷ N Divider (FRCDIVN) | 111 | xx | Note 1,<br>Note 2 | | | #### Notes: - 1. The OSCO pin function is determined by the OSCIOFNC Configuration bit. - 2. This is the default oscillator mode for an unprogrammed (erased) device. # 9.10 OSCCON Unlock Sequence The OSCCON register is protected against unintended writes through a lock mechanism. The upper and lower bytes of OSCCON have their own unlock sequence, and both must be used when writing to both bytes of the register. Before OSCCON can be written to, the following unlock sequence must be used: - 1. Execute the unlock sequence for the OSCCON high byte. In two back-to-back instructions: - Write 0x78 to OSCCON[15:8] - Write 0x9A to OSCCON[15:8] - 2. In the instruction immediately following the unlock sequence, the OSCCON[15:8] bits can be modified. - 3. Execute the unlock sequence for the OSCCON low byte. In two back-to-back instructions: - Write 0x46 to OSCCON[7:0] - Write 0x57 to OSCCON[7:0] - 4. In the instruction immediately following the unlock sequence, the OSCCON[7:0] bits can be modified. **Note:** MPLAB® XC16 provides a built-in C language function, including the unlocking sequence to modify high and low bytes in the OSCCON register: \_\_builtin\_write\_OSCCONH(value) builtin\_write\_OSCCONL(value) # 9.11 Oscillator Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------|-----------|----------|----------|---------------|---------------|----------------|----------------|-------|---------------|----------| | 0x0F84 | 00000N(4) | 15:8 | | | COSC[2:0] | | | | NOSC[2:0] | | | UXUF84 | OSCCON(1) | 7:0 | CLKLOCK | | LOCK | | CF | | | OSWEN | | 0x0F86 | CLKDIV | 15:8 | ROI | | DOZE[2:0] | | DOZEN | | FRCDIV[2:0] | | | UXUFOU | CLKDIV | 7:0 | | | Reserv | ed[1:0] | | PLLP | RE[3:0] | | | 0x0F88 | | | | | | | | | | | | <br>0x0F89 | Reserved | | | | | | | | | | | 0.0504 | DUEDD | 15:8 | | | | | | Reser | ved[3:0] | | | 0x0F8A | PLLFBD | 7:0 | | | | PLLFB | DIV[7:0] | | | | | 00504 | DI I DIV | 15:8 | | | | | | | VCOD | IV[1:0] | | 0x0F8A | PLLDIV | 7:0 | | | POST1DIV[2:0] | | | | POST2DIV[2:0] | | | 0x0F8C | OSCTUN | 15:8 | | | | | | | | | | UXUF8C | | 7:0 | | | | | TUN[ | 5:0] | | | | 0x0F8E | ACLKCON1 | 15:8 | APLLEN | APLLCK | | | | | | FRCSEL | | UXUFOE | ACERCONT | 7:0 | | Reserved[1:0] | | | APLLPRE[3:0] | | | | | 0x0F90 | ADLI EDD1 | 15:8 | | | | | | Reser | ved[3:0] | | | UXUF9U | APLLFBD1 | 7:0 | | | | APLLFE | BDIV[7:0] | | | | | 0x0F92 | APLLDIV1 | 15:8 | | | | | | | AVCO | 0IV[1:0] | | UXUF92 | AFLLDIVI | 7:0 | | ) | APOST1DIV[2:0 | )] | APOST2DIV[2:0] | | | | | 0x0F94<br><br>0x0F99 | Reserved | | | | | | | | | | | 00504 | OWNORKOON | 15:8 | CANCLKEN | | | | | CANCL | KSEL[3:0] | | | 0x0F9A | CANCLKCON | 7:0 | | | | CANCLKDIV[6:0] | | | | | | 0x0F9C<br><br>0x0FB7 | Reserved | | | | | | | | | | | OVOEDS | REFOCONL | 15:8 | ROEN | | ROSIDL | ROOUT | ROSLP | | ROSWEN | ROACTIV | | 0x0FB8 | | 7:0 | | | | | | ROS | EL[3:0] | | | 00504 | DEFOCALL | 15:8 | | | | | RODIV[14:8] | | | | | 0x0FBA | REFOCONH | 7:0 | | | | ROD | IV[7:0] | | | | # 9.11.1 Oscillator Control Register Name: OSCCON<sup>(1)</sup> Offset: 0xF84 #### Notes: - 1. Writes to this register require an unlock sequence. - 2. Direct clock switches between any Primary Oscillator mode with PLL and FRCPLL mode are not permitted. This applies to clock switches in either direction. In these instances, the application must switch to FRC mode as a transitional clock source between the two PLL modes. - 3. This bit should only be cleared in software. Setting the bit in software (= 1) will have the same effect as an actual oscillator failure and will trigger an oscillator failure trap. #### **Legend:** y = Value set from Configuration bits on POR | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|----|-----------|----|-----|-----|-----------|-------| | | | | COSC[2:0] | | | | NOSC[2:0] | | | Access | | R | R | R | | R/W | R/W | R/W | | Reset | | 0 | 0 | 0 | | У | У | У | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CLKLOCK | | LOCK | | CF | | | OSWEN | | Access | R/W | | R | | R/W | | | R/W | | Reset | 0 | | 0 | | 0 | | | 0 | #### Bits 14:12 - COSC[2:0] Current Oscillator Selection bits (read-only) | CCCC[2:0] Carrent Commuter Colocient bite (road city) | |----------------------------------------------------------------| | Description | | Fast RC Oscillator (FRC) with Divide-by-n (FRCDIVN) | | Backup FRC (BFRC) | | Low-Power RC Oscillator (LPRC) | | Reserved – default to FRC | | Primary Oscillator (XT, HS, EC) with PLL (XTPLL, HSPLL, ECPLL) | | Primary Oscillator (XT, HS, EC) | | Fast RC Oscillator (FRC) with PLL (FRCPLL) | | Fast RC Oscillator (FRC) | | | # Bits 10:8 - NOSC[2:0] New Oscillator Selection bits(2) | Value | Description | |-------|----------------------------------------------------------------| | 111 | Fast RC Oscillator (FRC) with Divide-by-n (FRCDIVN) | | 110 | Backup FRC (BFRC) | | 101 | Low-Power RC Oscillator (LPRC) | | 100 | Reserved – default to FRC | | 011 | Primary Oscillator (XT, HS, EC) with PLL (XTPLL, HSPLL, ECPLL) | | 010 | Primary Oscillator (XT, HS, EC) | | 001 | Fast RC Oscillator (FRC) with PLL (FRCPLL) | | 000 | Fast RC Oscillator (FRC) | # Bit 7 - CLKLOCK Clock Lock Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | If (FCKSM0 = 1), then clock and PLL configurations are locked; if (FCKSM0 = 0), then clock and PLL | | | configurations may be modified | | 0 | Clock and PLL selections are not locked, configurations may be modified | #### Bit 5 - LOCK PLL Lock Status bit (read-only) | Value | Description | |-------|------------------------------------------------------------------| | 1 | Indicates that PLL is in lock or PLL start-up timer is satisfied | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 385 # Oscillator with High-Frequency PLL | Value | Description | |-------|-------------------------------------------------------------------------------------| | 0 | Indicates that PLL is out of lock, start-up timer is in progress or PLL is disabled | # Bit 3 - CF Clock Fail Detect bit (3) | Value | Description | |-------|---------------------------------------| | 1 | FSCM has detected a clock failure | | 0 | FSCM has not detected a clock failure | #### Bit 0 - OSWEN Oscillator Switch Enable bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Requests oscillator switch to the selection specified by the NOSC[2:0] bits | | 0 | Oscillator switch is complete | # 9.11.2 Clock Divider Register Name: CLKDIV Offset: 0xF86 #### Notes: - 1. The DOZE[2:0] bits can only be written to when the DOZEN bit is clear. If DOZEN = 1, any writes to DOZE[2:0] are ignored. - 2. This bit is cleared when the ROI bit is set and an interrupt occurs. - The DOZEN bit cannot be set if DOZE[2:0] = 000. If DOZE[2:0] = 000, any attempt by user software to set the DOZEN bit is ignored. - 4. PLLPRE[3:0] may be updated while the PLL is operating, but the VCO may overshoot. #### Legend: r = Reserved bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----------|---------|-------|-------|-------------|-----| | | ROI | | DOZE[2:0] | | DOZEN | | FRCDIV[2:0] | | | Access | R/W | Reset | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Reserv | ed[1:0] | | PLLPF | RE[3:0] | | | Access | | | r | r | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 1 | #### Bit 15 - ROI Recover on Interrupt bit | V | alue | Description | |---|------|-----------------------------------------------------------------------------------------------------------| | 1 | | Interrupts will clear the DOZEN bit and the processor clock, and the peripheral clock ratio is set to 1:1 | | 0 | | Interrupts have no effect on the DOZEN bit | #### Bits 14:12 - DOZE[2:0] Processor Clock Reduction Select bits(1) | Value | Description | |-------|---------------------------------------| | 111 | F <sub>P</sub> divided by 128 | | 110 | F <sub>P</sub> divided by 64 | | 101 | F <sub>P</sub> divided by 32 | | 100 | F <sub>P</sub> divided by 16 | | 011 | F <sub>P</sub> divided by 8 (default) | | 010 | F <sub>P</sub> divided by 4 | | 001 | F <sub>P</sub> divided by 2 | | 000 | F <sub>P</sub> divided by 1 | #### Bit 11 - DOZEN Doze Mode Enable bit(2,3) | Value | Description | |-------|--------------------------------------------------------------------------------------------| | 1 | DOZE[2:0] field specifies the ratio between the peripheral clocks and the processor clocks | | 0 | Processor clock and peripheral clock ratio is forced to 1:1 | #### Bits 10:8 - FRCDIV[2:0] Internal Fast RC Oscillator Postscaler bits | Value | Description | |-------|----------------------------| | 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) | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 387 Oscillator with High-Frequency PLL Bits 5:4 - Reserved[1:0] Read as '0' # Bits 3:0 – PLLPRE[3:0] PLL Phase Detector Input Divider Select bits<sup>(4)</sup> (also denoted as 'N1', PLL prescaler) | Value | Description | |-------|-------------------------------------------------| | 1111 | Reserved | | | | | 1001 | Reserved | | 1000 | Input divided by 8 | | 0111 | Input divided by 7 | | 0110 | Input divided by 6 | | 0101 | Input divided by 5 | | 0100 | Input divided by 4 | | 0011 | Input divided by 3 | | 0010 | Input divided by 2 | | 0001 | Input divided by 1 (power-on default selection) | | 0000 | Reserved | # 9.11.3 PLL Feedback Divider Register Name: PLLFBD Offset: 0xF8A #### Note: The allowed range is 16-200 (decimal). The rest of the values are reserved and should be avoided. The power on the default feedback divider is 150 (decimal) with an 8 MHz FRC input clock. The VCO frequency is 1.2 GHz. Legend: r = Reserved bit Bits 11:8 - Reserved[3:0] Maintain as '0' Bits 7:0 - PLLFBDIV[7:0] PLL Feedback Divider bits (also denoted as 'M', PLL multiplier) | Value | Description | |----------|----------------------------| | 11111111 | Reserved | | | | | 11001000 | 200 Maximum <sup>(1)</sup> | | | | | 10010110 | 150 (default) | | 00000001 | Reserved | | 00000000 | Reserved | Oscillator with High-Frequency PLL # 9.11.4 FRC Oscillator Tuning Register Name: OSCTUN Offset: 0xF8C Bits 5:0 - TUN[5:0] FRC Oscillator Tuning bits | Value | Description | |--------|---------------------------------------------| | 011111 | Maximum frequency deviation of 1.74% (MHz) | | 011110 | Center frequency + 1.693% (MHz) | | | | | 000001 | Center frequency + 0.047% (MHz) | | 000000 | Center frequency (8.00 MHz nominal) | | 111111 | Center frequency – 0.047% (MHz) | | | | | 100001 | Center frequency – 1.693% (MHz) | | 100000 | Minimum frequency deviation of -1.74% (MHz) | # Oscillator with High-Frequency PLL ### 9.11.5 PLL Output Divider Register Name: PLLDIV Offset: 0xF8A #### Notes: - 1. The POST1DIVx and POST2DIVx divider values must not be changed while the PLL is operating. - 2. The default values for POST1DIVx and POST2DIVx are 4 and 1, respectively, yielding a 150 MHz system source clock. Bits 9:8 - VCODIV[1:0] PLL VCO Output Divider Select bits | Value | Description | |-------|---------------------| | 11 | F <sub>VCO</sub> | | 10 | F <sub>VCO</sub> /2 | | 01 | F <sub>VCO</sub> /3 | | 00 | F <sub>VCO</sub> /4 | #### Bits 6:4 - POST1DIV[2:0] PLL Output Divider #1 Ratio bits(1,2) POST1DIV[2:0] can have a valid value, from 1 to 7 (POST1DIVx value should be greater than or equal to the POST2DIVx value). The POST1DIVx divider is designed to operate at higher clock rates than the POST2DIVx divider. #### Bits 2:0 - POST2DIV[2:0] PLL Output Divider #2 Ratio bits(1,2) POST2DIV[2:0] can have a valid value, from 1 to 7 (POST1DIVx value should be greater than or equal to the POST2DIVx value). The POST1DIVx divider is designed to operate at higher clock rates than the POST2DIVx divider. # 9.11.6 Auxiliary Clock Control Register Name: ACLKCON1 Offset: 0xF8E #### Note: 1. Even with the APLLEN bit set, another peripheral must generate a clock request before the APLL will start. #### Legend: r = Reserved bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|---------|-----|-------|---------|--------| | | APLLEN | APLLCK | | | | | | FRCSEL | | Access | R/W | R/W | | | | | | R/W | | Reset | 0 | 0 | | | | | | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Reserv | ed[1:0] | | APLLP | RE[3:0] | | | Access | | | r | r | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - APLLEN Auxiliary PLL Enable/Bypass Select bit (1) | Value | Description | |-------|----------------------------------------------------------------------------------| | 1 | AF <sub>PLLO</sub> is connected to APLL post-divider output (bypass is disabled) | | 0 | AF <sub>PLLO</sub> is connected to APLL input clock (bypass is enabled) | #### Bit 14 - APLLCK APLL Phase-Locked State Status bit | Value | Description | |-------|------------------------------| | 1 | Auxiliary PLL is in lock | | 0 | Auxiliary PLL is not in lock | # Bit 8 - FRCSEL FRC Clock Source Select bit # Bits 5:4 - Reserved[1:0] Read as '0' # Bits 3:0 – APLLPRE[3:0] Auxiliary PLL Phase Detector Input Divider bits | Value | Description | |-------|-------------------------------------------------| | 1111 | Reserved | | | | | 1001 | Reserved | | 1000 | Input divided by 8 | | 0111 | Input divided by 7 | | 0110 | Input divided by 6 | | 0101 | Input divided by 5 | | 0100 | Input divided by 4 | | 0011 | Input divided by 3 | | 0010 | Input divided by 2 | | 0001 | Input divided by 1 (power-on default selection) | | 0000 | Reserved | # 9.11.7 APLL Feedback Divider Register Name: APLLFBD1 Offset: 0xF90 #### Note: The allowed range is 16-200 (decimal). The rest of the values are reserved and should be avoided. The power-on default feedback divider is 150 (decimal) with an 8 MHz FRC input clock; the VCO frequency is 1.2 GHz. Legend: r = Reserved bit Bits 11:8 - Reserved[3:0] Maintain as '0' Bits 7:0 - APLLFBDIV[7:0] APLL Feedback Divider bits | DIG 1.0 ALLEDDIV[1.0] ALL | EE I COODON DIVIGOI DIC | |---------------------------|----------------------------| | Value | Description | | 11111111 | Reserved | | | | | 11001000 | 200 maximum <sup>(1)</sup> | | | | | 10010110 | 150 (default) | | | | | 00010000 | 16 minimum <sup>(1)</sup> | | | | | 00000010 | Reserved | | 00000001 | Reserved | | 0000000 | Reserved | | | | # Oscillator with High-Frequency PLL #### 9.11.8 APLL Output Divider Register Name: APLLDIV1 Offset: 0xF92 #### Notes: - 1. The APOST1DIVx and APOST2DIVx values must not be changed while the PLL is operating. - 2. The default values for APOST1DIVx and APOST2DIVx are 4 and 1, respectively, yielding a 150 MHz system source clock. Bits 9:8 - AVCODIV[1:0] APLL VCO Output Divider Select bits | Value | Description | |-------|----------------------| | 11 | AF <sub>VCO</sub> | | 10 | AF <sub>VCO</sub> /2 | | 01 | AF <sub>VCO</sub> /3 | | 00 | AF <sub>VCO</sub> /4 | #### Bits 6:4 - APOST1DIV[2:0] APLL Output Divider #1 Ratio bits(1,2) APOST1DIV[2:0] can have a valid value, from 1 to 7 (the APOST1DIVx value should be greater than or equal to the APOST2DIVx value). The APOST1DIVx divider is designed to operate at higher clock rates than the APOST2DIVx divider. #### Bits 2:0 - APOST2DIV[2:0] APLL Output Divider #2 Ratio bits(1,2) APOST2DIV[2:0] can have a valid value, from 1 to 7 (the APOST2DIVx value should be less than or equal to the APOST1DIVx value). The APOST1DIVx divider is designed to operate at higher clock rates than the APOST2DIVx divider. # 9.11.9 CAN Clock Control Register Name: CANCLKCON Offset: 0xF9A #### Notes: - 1. The user must ensure the input clock source is 640 MHz or less. Operation with input reference frequency above 640 MHz will result in unpredictable behavior. - 2. The CANCLKDIVx divider value must not be changed during CAN module operation. - 3. The user must ensure the maximum clock output frequency of the divider is 80 MHz or less. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------------------|-----|-----------|-----|----------------|-----|-----|-----| | | CANCLKEN CANCLKSEL[3:0] | | (SEL[3:0] | | | | | | | Access | R/W | | | | R/W | R/W | R/W | R/W | | Reset | 0 | | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | CANCLKDIV[6:0] | | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - CANCLKEN Enables the CAN Clock Generator bit | Value | Description | |-------|--------------------------------------------| | 1 | CAN clock generation circuitry is enabled | | 0 | CAN clock generation circuitry is disabled | # Bits 11:8 - CANCLKSEL[3:0] CAN Clock Source Select bits(1) | Value | Description | |-----------|------------------------------| | 1011-1111 | Reserved (no clock selected) | | 1010 | AF <sub>VCO</sub> /4 | | 1001 | AF <sub>VCO</sub> /3 | | 1000 | AF <sub>VCO</sub> /2 | | 0111 | AF <sub>VCO</sub> | | 0110 | AF <sub>PLLO</sub> | | 0101 | F <sub>VCO</sub> /4 | | 0100 | F <sub>VCO</sub> /3 | | 0011 | F <sub>VCO</sub> /2 | | 0010 | F <sub>PLLO</sub> | | 0001 | F <sub>VCO</sub> | | 0000 | 0 (no clock selected) | # Bits 6:0 - CANCLKDIV[6:0] CAN Clock Divider Select bits(2,3) | Value | Description | |---------|---------------| | 1111111 | Divide-by-128 | | | | | 0000010 | Divide-by-3 | | 0000001 | Divide-by-2 | | 000000 | Divide-by-1 | #### 9.11.10 Reference Clock Control Low Register Name: REFOCONL Offset: 0xFB8 Legend: HC = Hardware Clearable bit; HSC = Hardware Settable/Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|----|--------|-------|-------|------------|--------|---------| | | ROEN | | ROSIDL | ROOUT | ROSLP | | ROSWEN | ROACTIV | | Access | R/W | | R/W | R/W | R/W | | R/W/HC | R/HSC | | Reset | 0 | | 0 | 0 | 0 | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | ROSEL[3:0] | | | | Access | | | | | R/W | R/W | R/W | R/W | | Reset | | | | | 0 | 0 | 0 | 0 | #### Bit 15 - ROEN Reference Clock Enable bit | Value | Description | |-------|----------------------------------------------------| | 1 | Reference Oscillator is enabled on the REFCLKO pin | | 0 | Reference Oscillator is disabled | #### Bit 13 - ROSIDL Reference Clock Stop in Idle bit | Value | Description | |-------|----------------------------------------------------| | 1 | Reference Oscillator is disabled in Idle mode | | 0 | Reference Oscillator continues to run in Idle mode | # Bit 12 - ROOUT Reference Clock Output Enable bit | Val | ue | Description | |-----|----|-----------------------------------------------------------------------------| | 1 | | Reference clock external output is enabled and available on the REFCLKO pin | | 0 | | Reference clock external output is disabled | # Bit 11 - ROSLP Reference Clock Stop in Sleep bit | Value | Description | |-------|------------------------------------------------------| | 1 | Reference Oscillator continues to run in Sleep modes | | 0 | Reference Oscillator is disabled in Sleep modes | ### Bit 9 - ROSWEN Reference Clock Output Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Clock divider change (requested by changes to RODIVx) is requested or is in progress (set in software, cleared by hardware upon completion) | | 0 | Clock divider change has completed or is not pending | # Bit 8 - ROACTIV Reference Clock Status bit | Value | Description | |-------|----------------------------------------------------------------------------------| | 1 | Reference clock is active; do not change clock source | | 0 | Reference clock is stopped; clock source and configuration may be safely changed | #### Bits 3:0 - ROSEL[3:0] Reference Clock Source Select bits | Value | Description | |-------|---------------------| | 1111 | Reserved | | | Reserved | | 1000 | Reserved | | 0111 | REFI pin | | 0110 | F <sub>VCO</sub> /4 | | 0101 | BFRC | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 396 Oscillator with High-Frequency PLL | Value | Description | |-------|------------------------------------| | 0100 | LPRC | | 0011 | FRC | | 0010 | Primary Oscillator | | 0001 | Peripheral clock (F <sub>P</sub> ) | | 0000 | System clock (F <sub>OSC</sub> ) | Oscillator with High-Frequency PLL ## 9.11.11 Reference Clock Control High Register Name: REFOCONH Offset: 0xFBA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----|-----|-------------|------|--------|-----|-----|-----|--|--| | | | | RODIV[14:8] | | | | | | | | | Access | | R/W | | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | RODI | V[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | **Bits 14:0 – RODIV[14:0]** Reference Clock Integer Divider Select bits Divider for the selected input clock source is two times the selected value. | Value | Description | |--------------------|------------------------------------------------| | 111 1111 1111 1111 | Base clock value divided by 65,534 (2 * 7FFFh) | | 111 1111 1111 1110 | Base clock value divided by 65,532 (2 * 7FFEh) | | 111 1111 1111 1101 | Base clock value divided by 65,530 (2 * 7FFDh) | | | | | 000 0000 0000 0010 | Base clock value divided by 4 (2 * 2) | | 000 0000 0000 0001 | Base clock value divided by 2 (2 * 1) | | 000 0000 0000 0000 | Base clock value | ## 10. Direct Memory Access (DMA) Controller **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. For more information, refer to "Direct Memory Access Controller (DMA)" (www.microchip.com/DS30009742) in the "dsPIC33/PIC24 Family Reference Manual". The Direct Memory Access (DMA) Controller is designed to service high data throughput peripherals operating on the SFR bus, allowing them to access data memory directly and alleviating the need for CPU-intensive management. By allowing these data-intensive peripherals to share their own data path, the main data bus is also deloaded, resulting in additional power savings. The DMA Controller functions both as a peripheral and a direct extension of the CPU. It is located on the microcontroller data bus, between the CPU and DMA-enabled peripherals, with direct access to SRAM. This partitions the SFR bus into two buses, allowing the DMA Controller access to the DMA-capable peripherals located on the new DMA SFR bus. The controller serves as an Initiator device on the DMA SFR bus, controlling data flow from DMA-capable peripherals. The controller also monitors CPU instruction processing directly, allowing it to be aware of when the CPU requires access to peripherals on the DMA bus and automatically relinquishing control to the CPU as needed. This increases the effective bandwidth for handling data without DMA operations, causing a processor Stall. This makes the controller essentially transparent to the user. The DMA Controller has these features: - A Total of Eight Independently Programmable Channels - Concurrent Operation with the CPU (no DMA caused Wait states) - · DMA Bus Arbitration - · Five Programmable Address modes - · Four Programmable Transfer modes - · Four Flexible Internal Data Transfer modes - · Byte or Word Support for Data Transfer - 16-Bit Source and Destination Address Register for each Channel, Dynamically Updated and Reloadable - · 16-Bit Transaction Count Register, Dynamically Updated and Reloadable - · Upper and Lower Address Limit Registers - Counter Half-Full Level Interrupt - Software Triggered Transfer - Null Write mode for Symmetric Buffer Operations A simplified block diagram of the DMA Controller is shown if Figure 10-1. Figure 10-1. DMA Functional Block Diagram ## 10.1 Summary of DMA Operations The DMA Controller is capable of moving data between addresses according to a number of different parameters. Each of these parameters can be independently configured for any transaction. In addition, any or all of the DMA channels can independently perform a different transaction at the same time. Transactions are classified by these parameters: - Source and destination (SFRs and data RAM) - Data size (byte or word) - Trigger source - Transfer mode (One-Shot, Repeated or Continuous) - Addressing modes (Fixed Address or Address Blocks with or without Address Increment/Decrement) In addition, the DMA Controller provides channel priority arbitration for all channels. ## 10.1.1 Source and Destination Using the DMA Controller, data may be moved between any two addresses in the Data Space. The SFR space (0000h to 0FFFh), or the data RAM space (1000h to 4FFFh), can serve as either the source or the destination. Data can be moved between these areas in either direction or between addresses in either area. The four different combinations are shown in 10.1.5 Addressing Modes. If it is necessary to protect areas of data RAM, the DMA Controller allows the user to set upper and lower address boundaries for operations in the Data Space above the SFR space. The boundaries are set by the DMAH and DMAL Limit registers. If a DMA channel attempts an operation outside of the address boundaries, the transaction is terminated and an interrupt is generated. ## **Direct Memory Access (DMA) Controller** #### 10.1.2 Data Size The DMA Controller can handle both 8-bit and 16-bit transactions. Size is user-selectable using the SIZE bit (DMACHn[1]). By default, each channel is configured for word-size transactions. When byte-size transactions are chosen, the LSB of the source and/or destination address determines if the data represent the upper or lower byte of the data RAM location. ## 10.1.3 Trigger Source The DMA Controller can use 82 of the device's interrupt sources to initiate a transaction. The DMA trigger sources occur in reverse order from their natural interrupt priority and are shown in 10.1.5 Addressing Modes. Since the source and destination addresses for any transaction can be programmed independently of the trigger source, the DMA Controller can use any trigger to perform an operation on any peripheral. This also allows DMA channels to be cascaded to perform more complex transfer operations. #### 10.1.4 Transfer Mode The DMA Controller supports four types of data transfers, based on the volume of data to be moved for each trigger. - One-Shot: A single transaction occurs for each trigger. - Continuous: A series of back-to-back transactions occur for each trigger; the number of transactions is determined by the DMACNTn transaction counter. - Repeated One-Shot: A single transaction is performed repeatedly, once per trigger, until the DMA channel is disabled. - Repeated Continuous: A series of transactions are performed repeatedly, one cycle per trigger, until the DMA channel is disabled All transfer modes allow the option to have the source and destination addresses, and counter value, automatically reloaded after the completion of a transaction. #### 10.1.5 Addressing Modes The DMA Controller also supports transfers between single addresses or address ranges. The four basic options are: - · Fixed-to-Fixed: Between two constant addresses - · Fixed-to-Block: From a constant source address to a range of destination addresses - · Block-to-Fixed: From a range of source addresses to a single, constant destination address - · Block-to-Block: From a range of source addresses to a range of destination addresses The option to select auto-increment or auto-decrement of source and/or destination addresses is available for Block Addressing modes. In addition to the four basic modes, the DMA Controller also supports Peripheral Indirect Addressing (PIA) mode, where the source or destination address is generated jointly by the DMA Controller and a PIA-capable peripheral. When enabled, the DMA channel provides a base source and/or destination address, while the peripheral provides a fixed range offset address. Figure 10-2. Types of DMA Data Transfers **Note:** Relative sizes of memory areas are not shown to scale. #### 10.1.6 Channel Priority Each DMA channel functions independently of the others, but also competes with the others for access to the data and DMA buses. When access collisions occur, the DMA Controller arbitrates between the channels using a user-selectable priority scheme. Two schemes are available: - Round Robin: When two or more channels collide, the lower numbered channel receives priority on the first collision. On subsequent collisions, the higher numbered channels each receive priority based on their channel number. - Fixed: When two or more channels collide, the lowest numbered channel always receives priority, regardless of past history; however, any channel being actively processed is not available for an immediate retrigger. If a higher priority channel is continually requesting service, it will be scheduled for service after the next lower priority channel with a pending request. ## 10.2 Typical Setup To set up a DMA channel for a basic data transfer: - Enable the DMA Controller (DMAEN = 1) and select an appropriate channel priority scheme by setting or clearing PRSSEL. - 2. Program DMAH and DMAL with appropriate upper and lower address boundaries for data RAM operations. - 3. Select the DMA channel to be used and disable its operation (CHEN = 0). - 4. Program the appropriate source and destination addresses for the transaction into the channel's DMASRCn and DMADSTn registers. For PIA mode addressing, use the base address value. - 5. Program the DMACNTn register for the number of triggers per transfer (One-Shot or Continuous modes) or the number of words (bytes) to be transferred (Repeated modes). - 6. Set or clear the SIZE bit to select the data size. - 7. Program the TRMODE[1:0] bits to select the Data Transfer mode. - 8. Program the SAMODE[1:0] and DAMODE[1:0] bits to select the addressing mode. - 9. Enable the DMA channel by setting CHEN. - 10. Enable the trigger source interrupt. #### 10.2.1 Peripheral Module Disable The channels of the DMA Controller can be individually powered down using the Peripheral Module Disable (PMD) registers. #### 10.2.2 DMA Registers The DMA Controller uses a number of registers to control its operation. The number of registers depends on the number of channels implemented for a particular device. There are always four module-level registers (one control and three buffer/address): - DMACON: DMA Engine Control Register (10.2.3.1 DMACON) - · DMAH and DMAL: DMA High and Low Address Limit Registers - DMABUF: DMA Transfer Data Buffer Each of the DMA channels implements five registers (two control and three buffer/address): - DMACHn: DMA Channel n Control Register (10.2.3.2 DMACHn) - DMAINTn: DMA Channel n Interrupt Register (10.2.3.3 DMAINTn) - · DMASRCn: DMA Data Source Address Pointer for Channel n Register - DMADSTn: DMA Data Destination Source for Channel n Register - DMACNTn: DMA Transaction Counter for Channel n Register For devices, there are a total of 34 registers. **Direct Memory Access (DMA) Controller** ## 10.2.3 DMA Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------------|----------|--------|---------|---------|----------|------------|---------|--------|--------| | 0x0AA8 | DMACON | 15:8 | DMAEN | | DMASIDL | | | | | | | UXUAAO | DIVIACON | 7:0 | | | | | | | | PRSSEL | | 0x0AAA | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0AAF | | | | | | | | | | | | 0x0AB0 | DMACHn | 15:8 | | | | Reserved | | NULLW | RELOAD | CHREQ | | UXUADU | DIVIACITII | 7:0 | SAMO | DE[1:0] | DAMO | DE[1:0] | TRMO | DE[1:0] | SIZE | CHEN | | 0x0AB2 | DMAINTn | 15:8 | DBUFWF | | | | CHSEL[6:0] | | | | | UXUADZ | DXUAB2 DMAINTH | | HIGHIF | LOWIF | DONEIF | HALFIF | OVRUNIF | | | HALFEN | ## 10.2.3.1 DMA Engine Control Register Name: DMACON Offset: 0xAA8 ## Bit 15 - DMAEN DMA Module Enable bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Enables module | | 0 | Disables module and terminates all active DMA operation(s) | #### Bit 13 - DMASIDL DMA Stop in Idle bit | Value | Description | | |-------|-----------------------------------|--| | 1 | DMA continues to run in Idle mode | | | 0 | DMA is disabled in Idle mode | | #### Bit 0 - PRSSEL Channel Priority Scheme Selection bit | Value | Description | |-------|-----------------------| | 1 | Round robin scheme | | 0 | Fixed priority scheme | ### 10.2.3.2 DMA Channel n Control Register Name: DMACHn Offset: 0xAB0 #### Notes: - 1. Only the original DMACNTn is required to be stored to recover the original DMASRCn and DMADSTn values. - 2. DMACNTn will always be reloaded in Repeated mode transfers, regardless of the state of the RELOAD bit. - 3. The number of transfers executed while CHREQ is set depends on the configuration of TRMODE[1:0]. #### Legend: r = Reserved bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|---------|------|----------|-------|---------|--------|-------| | | | | | Reserved | | NULLW | RELOAD | CHREQ | | Access | | | | r | | R/W | R/W | R/W | | Reset | | | | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SAMO | DE[1:0] | DAMO | DE[1:0] | TRMOI | DE[1:0] | SIZE | CHEN | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 12 - Reserved Maintain as '0' ### Bit 10 - NULLW Null Write Mode bit | Value | Description | |-------|------------------------------------------------------------------| | 1 | A dummy write is initiated to DMASRCn for every write to DMADSTn | | 0 | No dummy write is initiated | ### Bit 9 - RELOAD Address and Count Reload bit(1) | Value | Description | |-------|-------------------------------------------------------------------------------------------------| | 1 | DMASRCn, DMADSTn and DMACNTn registers are reloaded to their previous values upon the start of | | | the next operation | | 0 | DMASRCn, DMADSTn and DMACNTn are not reloaded on the start of the next operation <sup>(2)</sup> | ## Bit 8 - CHREQ DMA Channel Software Request bit (3) | Value | Description | |-------|-------------------------------------------------------------------------------------------------| | 1 | A DMA request is initiated by software; automatically cleared upon completion of a DMA transfer | | 0 | No DMA request is pending | #### Bits 7:6 - SAMODE[1:0] Source Address Mode Selection bits | Value | Description | |-------|--------------------------------------------------------------------------| | 11 | DMASRCn is used in Peripheral Indirect Addressing and remains unchanged | | 10 | DMASRCn is decremented based on the SIZE bit after a transfer completion | | 01 | DMASRCn is incremented based on the SIZE bit after a transfer completion | | 00 | DMASRCn remains unchanged after a transfer completion | ## Bits 5:4 - DAMODE[1:0] Destination Address Mode Selection bits | Value | Description | |-------|--------------------------------------------------------------------------| | 11 | DMADSTn is used in Peripheral Indirect Addressing and remains unchanged | | 10 | DMADSTn is decremented based on the SIZE bit after a transfer completion | | 01 | DMADSTn is incremented based on the SIZE bit after a transfer completion | | 00 | DMADSTn remains unchanged after a transfer completion | #### Bits 3:2 - TRMODEI1:01 Transfer Mode Selection bits | Value | Description | |-------|---------------------| | 11 | Repeated Continuous | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 406 ## **Direct Memory Access (DMA) Controller** | Value | Description | |-------|-------------------| | 10 | Continuous | | 01 | Repeated One-Shot | | 00 | One-Shot | ## Bit 1 - SIZE Data Size Selection bit | Value | Description | |-------|---------------| | 1 | Byte (8-bit) | | 0 | Word (16-bit) | ## Bit 0 - CHEN DMA Channel Enable bit | Value | Description | |-------|---------------------------------------| | 1 | The corresponding channel is enabled | | 0 | The corresponding channel is disabled | ## 10.2.3.3 DMA Channel n Interrupt Register Name: DMAINTn Offset: 0xAB2 #### Notes: 1. Setting these flags in software does not generate an interrupt. 2. Testing for address limit violations (DMASRCn or DMADSTn is either greater than DMAH or less than DMAL) is NOT done before the actual access. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------------|-------|--------|--------|---------|-----|-----|--------| | | DBUFWF CHSEL[6:0] | | | | | | | | | Access | R/W | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | HIGHIF | LOWIF | DONEIF | HALFIF | OVRUNIF | | | HALFEN | | Access | R/W | R/W | R/W | R/W | R/W | | | R/W | | Reset | | | | | | | | 0 | ### Bit 15 - DBUFWF DMA Buffered Data Write Flag bit(1) | Value | Description | |-------|---------------------------------------------------------------------------------------------------| | 1 | The content of the DMA buffer has not been written to the location specified in DMADSTn or | | | DMASRCn in Null Write mode | | 0 | The content of the DMA buffer has been written to the location specified in DMADSTn or DMASRCn in | | | Null Write mode | #### Bits 14:8 - CHSEL[6:0] DMA Channel Trigger Selection bits ## Bit 7 - HIGHIF DMA High Address Limit Interrupt Flag bit(1,2) | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | The DMA channel has attempted to access an address higher than DMAH or the upper limit of the data | | | RAM space | | 0 | The DMA channel has not invoked the high address limit interrupt | ## Bit 6 - LOWIF DMA Low Address Limit Interrupt Flag bit(1,2) | Value | Description | |-------|--------------------------------------------------------------------------------------------| | 1 | The DMA channel has attempted to access the DMA SFR address lower than DMAL, but above the | | | SFR range (07FFh) | | 0 | The DMA channel has not invoked the low address limit interrupt | #### Bit 5 – DONEIF DMA Complete Operation Interrupt Flag bit<sup>(1)</sup> | Value | Description | |-------|-------------------------------------------------------| | | <u>If CHEN = 1:</u> | | 1 | The previous DMA session has ended with completion | | 0 | The current DMA session has not yet completed | | | <u>If CHEN = 0:</u> | | 1 | The previous DMA session has ended with completion | | 0 | The previous DMA session has ended without completion | ## Bit 4 – HALFIF DMA 50% Watermark Level Interrupt Flag bit<sup>(1)</sup> | Value | Description | |-------|------------------------------------------------| | 1 | DMACNTn has reached the halfway point to 0000h | | 0 | DMACNTn has not reached the halfway point | ## Bit 3 - OVRUNIF DMA Channel Overrun Flag bit (1) ## **Direct Memory Access (DMA) Controller** | Value | Description | |-------|-------------------------------------------------------------------------------------------------------| | 1 | The DMA channel is triggered while it is still completing the operation based on the previous trigger | | 0 | The overrun condition has not occurred | ## Bit 0 - HALFEN Halfway Completion Watermark bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Interrupts are invoked when DMACNTn has reached its halfway point and at completion | | 0 | An interrupt is invoked only at the completion of the transfer | ## 10.2.4 DMA Trigger Sources ## Table 10-1. DMA Channel Trigger Sources | CHSEL[6:0] | Trigger (Interrupt) | CHSEL[6:0] | Trigger (Interrupt) | CHSEL[6:0] | Trigger (Interrupt) | |------------|--------------------------------|------------|----------------------------|------------------------|------------------------| | 00h | INT0 – External<br>Interrupt 0 | 26h | SENT2 TX/RX | 4Bh | (Reserved, do not use) | | 01h | SCCP1 Interrupt | 27h | ADC1 Group<br>Convert Done | 4Ch | (Reserved, do not use) | | 02h | SPI1 Receiver | 28h | ADC Done AN0 | 4Dh | (Reserved, do not use) | | 03h | SPI1 Transmitter | 29h | ADC Done AN1 | 4Eh | (Reserved, do not use) | | 04h | UART1 Receiver | 2Ah | ADC Done AN2 | 4Fh | (Reserved, do not use) | | 05h | UART1 Transmitter | 2Bh | ADC Done AN3 | 50h | (Reserved, do not use) | | 06h | ECC Single Bit<br>Error | 2Ch | ADC Done AN4 | 51h | (Reserved, do not use) | | 07h | NVM Write<br>Complete | 2Dh | ADC Done AN5 | 52h | (Reserved, do not use) | | 08h | INT1 – External<br>Interrupt 1 | 2Eh | ADC Done AN6 | 53h | (Reserved, do not use) | | 09h | SI2C1 – I2C1<br>Client Event | 2Fh | ADC Done AN7 | 54h | (Reserved, do not use) | | 0Ah | MI2C1 – I2C1 Host<br>Event | 30h | ADC Done AN8 | 55h | (Reserved, do not use) | | 0Bh | INT2 – External<br>Interrupt 2 | 31h | ADC Done AN9 | 56h | (Reserved, do not use) | | 0Ch | SCCP2 Interrupt | 32h | ADC Done AN10 | 57h | PWM Event D | | 0Dh | INT3 – External<br>Interrupt 3 | 33h | ADC Done AN11 | 58h | PWM Event E | | 0Eh | UART2 Receiver | 34h | ADC Done AN12 | 59h | PWM Event F | | 0Fh | UART2 Transmitter | 35h | ADC Done AN13 | (Reserved, do not use) | (Reserved, do not use) | | 10h | SPI2 Receiver | 36h | ADC Done AN14 | (Reserved, do not use) | (Reserved, do not use) | | 11h | SPI2 Transmitter | 37h | ADC Done AN15 | 5Ch | SCCP7 Interrupt | | 12h | SCCP3 Interrupt | 38h | ADC Done AN16 | 5Dh | SCCP8 Interrupt | ## **Direct Memory Access (DMA) Controller** | continued | | | | | | |------------|------------------------------|------------|-----------------------------------|------------|---------------------------------| | CHSEL[6:0] | Trigger (Interrupt) | CHSEL[6:0] | Trigger (Interrupt) | CHSEL[6:0] | Trigger (Interrupt) | | 13h | SI2C2 – I2C2<br>Client Event | 39h | ADC Done AN17 | 5Eh | (Reserved, do not use) | | 14h | MI2C2 – I2C1 Host<br>Event | 3Ah | ADC Done AN18 | 5Fh | (Reserved, do not use) | | 15h | SCCP4 Interrupt | 3Bh | ADC Done AN19 | 60h | CLC3 Positive Edge<br>Interrupt | | 16h | SCCP5 Interrupt | 3Ch | ADC Done AN20 | 61h | CLC4 Positive Edge<br>Interrupt | | 17h | SCCP6 Interrupt | 3Dh | ADC Done AN21 | 62h | SPI3 Receiver | | 18h | CRC Generator<br>Interrupt | 3Eh | ADC Done AN22 | 63h | SPI3 Transmitter | | 19h | PWM Event A | 3Fh | ADC Done AN23 | 64h | SI2C3 – I2C3 Client<br>Event | | 1Bh | PWM Event B | 40h | AD1FLTR1 –<br>Oversample Filter 1 | 65h | MI2C3 – I2C3 Host<br>Event | | 1Ch | PWM<br>Generator 1 | 41h | AD1FLTR2 –<br>Oversample Filter 2 | 66h | SPI3 – Fault Interrupt | | 1Dh | PWM<br>Generator 2 | 42h | AD1FLTR3 –<br>Oversample Filter 3 | 67h | MCCP9 | | 1Eh | PWM<br>Generator 3 | 43h | AD1FLTR4 –<br>Oversample Filter 4 | 68h | UART3 Receiver | | 1Fh | PWM<br>Generator 4 | 44h | CLC1 Positive<br>Edge Interrupt | 69h | UART3 Transmitter | | 20h | PWM<br>Generator 5 | 45h | CLC2 Positive<br>Edge Interrupt | 6Ah | ADC Done AN24 | | 21h | PWM<br>Generator 6 | 46h | SPI1 – Fault<br>Interrupt | 6Bh | AN25 Done | | 22h | PWM<br>Generator 7 | 47h | SPI2 – Fault<br>Interrupt | 6Ch | PMP Event | | 23h | PWM<br>Generator 8 | 48h | (Reserved, do not use) | 6Dh | PMP Error | | 24h | PWM Event C | 49h | (Reserved, do not use) | 6Eh-7Fh | (Reserved, do not use) | | 25h | SENT1 TX/RX | 4Ah | (Reserved, do not use) | | | #### 11. Controller Area Network Flexible Data-Rate (CAN FD) Modules #### Notes: - This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "CAN Flexible Data-Rate (FD) Protocol Module" (www.microchip.com/DS70005340) in the "dsPIC33/PIC24 Family Reference Manual". - Not all device variants include the CAN FD peripheral. Refer to Table 1 for availability. #### 11.1 **Features** The CAN FD modules have the following features: #### General - · Nominal (Arbitration) Bit Rate up to 1 Mbps - · Data Bit Rate up to 8 Mbps - CAN FD Controller modes: - Mixed CAN 2.0B and CAN FD mode - CAN 2.0B mode - Conforms to ISO11898-1:2015 #### Message FIFOs - · Seven FIFOs, Configurable as Transmit or Receive FIFOs - One Transmit Queue (TXQ) - Transmit Event FIFO (TEF) with 32-Bit Timestamp #### Message Transmission - · Message Transmission Prioritization: - Based on priority bit field and/or - Message with lowest ID gets transmitted first using the TXQ - · Programmable Automatic Retransmission Attempts: - Unlimited, Three Attempts or Disabled #### Message Reception - · 16 Flexible Filter and Mask Objects. - · Each Object can be Configured to Filter either: - Standard ID + first 18 data bits or - Extended ID - · 32-Bit Timestamp. - The CAN FD Bit Stream Processor (BSP): by incrementing the head/tail of the FIFO. - Implements the Medium Access Control of the CAN FD Protocol Described in ISO11898-1:2015. It serializes and deserializes the bit stream, encodes and decodes the CAN FD frames, manages the medium access, Acknowledges frames, and detects and signals errors. - The TX Handler: Prioritizes the Messages that are Requested for Transmission by the Transmit FIFOs. It uses the RAM interface to fetch the transmit data from RAM and provides them to the BSP for transmission. - The BSP: Provides Received Messages to the RX Handler. The RX handler uses acceptance filters to filter out messages that shall be stored in the Receive FIFOs. It uses the RAM interface to store received data into RAM. - Each FIFO can be Configured either as a Transmit or Receive FIFO: The FIFO control keeps track of the FIFO head and tail, and calculates the user address. In a TX FIFO, the user address points to the address in RAM where the data for the next transmit message shall be stored. In an RX FIFO, the user address points to the address in RAM where the data of the next receive message shall be read. The user notifies the FIFO that a message was written to or read from RAM **Datasheet** 70005452B-page 411 © 2021 Microchip Technology Inc. - The Transmit Queue (TXQ): A Special Transmit FIFO that Transmits the Messages based on the ID of the Messages Stored in the Queue. - The Transmit Event FIFO (TEF): Stores the Message IDs of the Transmitted Messages. - A Free-Running Time Base Counter: Used to Timestamp Received Messages. Messages in the TEF can also be timestamped. - The CAN FD Controller Modules: Generate Interrupts when New Messages are Received or when Messages were Transmitted Successfully. Figure 11-1 shows the CAN FD system block diagram. Figure 11-1. CAN FD Module Block Diagram ## 11.2 CAN Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------|---------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------------------------------|------------------------|------------------------------------|--| | 0x05DC | C2FIFOCON1L | 15:8 | | | | | | FRESET | TXREQ | UINC | | | UXUSDC | CZFIFOCONIL | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | | 0x05DE | C2FIFOCON1H | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | | UXUSDE | CZFIFOCONTH | 7:0 | | TXA | Γ[1:0] | | | TXPRI[4:0] | | | | | 0x05E0 | C2FIFOSTA1 | 15:8 | | | | | | FIFOCI[4:0] | | | | | OXOGEO | OZI II GOIAT | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | 0x05E2 | C2FIFOSTA1H | 15:8 | | | | | | FIFOCI[4:0] | | | | | | | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | 0x05E4 | C2FIFOUA1L(1) | 15:8 | | | | W. 180 | A[15:8] | | | | | | | | 7:0 | | | | 00.300 | UA[7:0] | | | | | | 0x05E6 | C2FIFOUA1H(1) | 15:8 | | | | | A[31:24] | | | | | | | 3-10 | 7:0 | | | | FIFOU | A[23:16] | | | NO-90000 CO. | | | 0x05E8 | C2FIFOCON2L | 15:8 | | | | | | FRESET | TXREQ | UINC | | | | | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | | 0x05EA | C2FIFOCON2H | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | | | A STATE OF THE PARTY PAR | 7:0 | | TXA | Γ[1:0] | | | TXPRI[4:0] | | | | | 0x05EC | C2FIFOSTA2 | 15:8 | TVADT | TV/ 400 | TVEDD | T) (ATIE | DV0\#5 | FIFOCI[4:0] | TEUDEUUE | TENDENIE | | | | | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | 0x05EE | C2FIFOSTA2H | 15:8 | | | T)/EDD | | 51/51/15 | FIFOCI[4:0] | | | | | | | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | 0x05F0 | C2FIFOUA2L(1) | 15:8 | | | | | A[15:8] | | | | | | | | 7:0 | | | | | JA[7:0] | | | | | | 0x05F2 | C2FIFOUA2H(1) | 15:8 | | | | | A[31:24] | | | | | | | 10.00 10.00 10.00 10.00 10.00 10.00 | 7:0 | | | | FIFOU | A[23:16] | EDECET | TYPEO | LUNG | | | 0x05F4 | C2FIFOCON3L | 15:8 | TVEN | DTDEN | DYTOEN | TVATIE | DVOVIE | FRESET | TXREQ | UINC | | | | | 7:0<br>15:8 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | | 0x05F6 | C2FIFOCON3H | 7:0 | | PLSIZE[2:0] | Γ[1:0] | | | FSIZE[4:0]<br>TXPRI[4:0] | | | | | | | 15:8 | | IAA | [[1.0] | | | FIFOCI[4:0] | | | | | 0x05F8 | C2FIFOSTA3 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | | | 15:8 | IAADI | TALAND | IALKK | TAATIF | KXOVIF | FIFOCI[4:0] | TELIXELIII | TEINISTINIE | | | 0x05FA | C2FIFOSTA3H | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TEHREHIE | TENRENIE | | | | | 15:8 | IXABI | IXLAND | IXLINI | | A[15:8] | II LIXI I II | 11 1 11 11 1111 | TT INIXI INII | | | 0x05FC | C2FIFOUA3L(1) | 7:0 | | | | | JA[7:0] | | | | | | | | 15:8 | | | | | A[31:24] | | | | | | 0x05FE | C2FIFOUA3H(1) | 7:0 | | | | | A[23:16] | | | | | | | 1197521152115 17791111 | 15:8 | | | | 1 11 007 | ([20.10] | FRESET | TXREQ | UINC | | | 0x0600 | C2FIFOCON4L | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | | | | 15:8 | | PLSIZE[2:0] | | .20111 | | FSIZE[4:0] | | | | | 0x0602 | C2FIFOCON4H | 7:0 | | | Γ[1:0] | | | TXPRI[4:0] | | | | | | | 15:8 | | .,,,,, | 1 | | | FIFOCI[4:0] | | | | | 0x0604 | C2FIFOSTA4 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | 0x0606 | | | rac not then A | 21770 777 77 | 2000 7076 7 | 124 89,000 | 110 10000 5 15 150 | 2000 0000000000000000000000000000000000 | RO D SECTION | 200 X001 PS 12 PS 5 | | | | Reserved | | | | | | | | | | | | 0x0607 | | | | | | | | | | | | | 0x0608 | C2FIFOSTA4H | 15:8 | al No Abril 1997 | - | Selection of the Co. | And the state of t | DAYONAN OF THE LOCAL | FIFOCI[4:0] | AM SELECTION SELECTION | College (1900) (Account that house | | | | 57100570000 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | 0x0608 | C2FIFOUA4L(1) | 15:8 | | | | | A[15:8] | | | | | | | | 7:0 | | | | | JA[7:0] | | | | | | 0x060A | C2FIFOUA4H(1) | 15:8 | | | | | A[31:24] | | | | | | | | 7:0 | | | | FIFOU | A[23:16] | | | DESTRUCTION OF | | | 0x060C | C2FIFOCON5L | 15:8 | | | | | | FRESET | TXREQ | UINC | | | | 525001,02 | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | | 0x060E | C2FIFOCON5H | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | | and the same of th | | 7:0 | | 7:0 TXAT[1:0] TXPRI | | | | | | | | | continued | | | | | | | | | | | |------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------|-------------|-----------------------------------------|-----------------------------------------|--------------------|--------------------------|-------------|---------------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Oliset | Nume | | | | | | | | | | | 0x0610 | C2FIFOSTA5 | 15:8<br>7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | FIFOCI[4:0] | TFHRFHIF | TFNRFNIF | | 0x0612 | | 1.0 | 170101 | 77.27.11.2 | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 1000 | | | | | | Reserved | | | | | | | | | | | 0x0613 | | 45.0 | | | | | | FIE COLLA OL | | | | 0x0614 | C2FIFOSTA5H | 15:8<br>7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | FIFOCI[4:0] | TFHRFHIF | TFNRFNIF | | | 100000000000000000000000000000000000000 | 15:8 | 170101 | INDIA | TALITA | | JA[15:8] | TT EIGHT | | 11111111111 | | 0x0614 | C2FIFOUA5L(1) | 7:0 | | | | FIFO | JA[7:0] | | | | | 0x0616 | C2FIFOUA5H(1) | 15:8 | | | | | A[31:24] | | | | | 0,0010 | 7:0 FIFOUA[23:16] | | | | | | | | | | | 0x0618 | C2FIFOCON6L | 15:8 | T\/E11 | DEDEN | DVTOEN | T)/ATIF | DV01/15 | FRESET | TXREQ | UINC | | | | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 0x061A | C2FIFOCON6H | 15:8<br>7:0 | | PLSIZE[2:0] | T[4:0] | | | FSIZE[4:0]<br>TXPRI[4:0] | | | | | | 15:8 | | IXA | Γ[1:0] | | | FIFOCI[4:0] | | | | 0x061C | C2FIFOSTA6 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | 0x061E | | 7.0 | 177701 | IALAND | TALINA | 1793111 | 10.0011 | TI CIXITII | TI THAT THE | TT INIXI INII | | | Reserved | | | | | | | | | | | 0x061F | | 45.0 | | | | | | EIEOOI(4-01 | | | | 0x0620 | C2FIFOSTA6H | 15:8<br>7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | FIFOCI[4:0] | TFHRFHIF | TENRENIE | | | | 15:8 | IXABI | IXLARB | IXERR | | RXOVIF<br> A[15:8] | IFERFFIF | IFHREHIE | IFINKFINIF | | 0x0620 | C2FIFOUA6L(1) | 7:0 | | | | | JA[7:0] | | | | | | Source Service | 15:8 | | | | 0.750 | A[31:24] | | | | | 0x0622 | C2FIFOUA6H(1) | 7:0 | | | | | A[23:16] | | | | | | | 15:8 | | | | 1,11,00 | · (LO. FO) | FRESET | TXREQ | UINC | | 0x0624 | C2FIFOCON7L | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 00000 | 005150001711 | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | 0x0626 | C2FIFOCON7H | 7.0 | | TXA | Γ[1.0] | | | TXPRI[4.0] | | | | 0x0628 | C2FIFOSTA7 | 15:8 | | | | | | FIFOCI[4:0] | | | | | 02111 001711 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | 0x062A | | | | | | | | | | | | 0x062B | Reserved | | | | | | | | | | | | (1990 1 1 0 2 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 | 15:8 | | | | FIFOL | JA[15:8] | | | | | 0x062C | C2FIFOUA7L(1) | 7:0 | | | | | JA[7:0] | | | | | | | 15:8 | | | | 0.300 0.00 | | FIFOCI[4:0] | | | | 0x062E | C2FIFOSTA7H | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | 0x062E | C2FIFOUA7H(1) | 15:8 | | | | | A[31:24] | | | | | UXUUZL | CZI II OUATTI(1) | 7:0 | | | | FIFOU | A[23:16] | | | | | 0x0630 | C2FLTCON0L | 15:8 | FLTENb | | | | | FbBP[4:0] | | | | | | 7:0 | FLTENa | | | | | FaBP[4:0] | | | | 0x0632 | C2FLTCON0H | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | | -2-12-1-1-12-12-12-12-12-12-12-12-12-12- | 7:0 | FLTENC | | | | | FcBP[4:0] | | | | 0x0634 | C2FLTCON1L | 15:8<br>7:0 | FLTENb<br>FLTENa | | | | | FbBP[4:0]<br>FaBP[4:0] | | | | | Control of the Contro | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | 0x0636 | C2FLTCON1H | 7:0 | FLTENC | | | FcBP[4:0] | | | | | | | | 15:8 | FLTENb | | | | | FbBP[4:0] | | | | 0x0638 | C2FLTCON2L | 7:0 | FLTENa | | | | | FaBP[4:0] | | | | 0000 | OOFLEGGES | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | 0x063A | C2FLTCON2H | 7:0 | FLTENc | | | | | FcBP[4:0] | | | | 00000 | COFLECCNO | 15:8 | FLTENb | | | | | FbBP[4:0] | | | | 0x063C | C2FLTCON3L | 7:0 | FLTENa | | | | | FaBP[4:0] | | | | m 20.00000000000000000000000000000000000 | E C2FLTCON3H | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | 0x063E | | 7:0 | FLTENc | | | | | FcBP[4:0] | | | | conti | inued | | | | | | | | | |-----------------------------------------|-----------------------------------------|-------------|---|--------|-----------|--------|----------|-------------|------------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | | | rvanie | Dit i os. | | | · | | | | · · | | 0x0640 | Reserved | | | | | | | | | | 0x0641 | Reserveu | | | | | | | | | | | | 15:8 | | | EID[4:0] | | | | SID[10:8] | | 0x0642 | C2FLTOBJ0L | 7:0 | | | | SIDI | 7:01 | | [] | | | 10.000000000000000000000000000000000000 | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | 0x0644 | C2FLTOBJ0H | 7:0 | | | | EID[ | 12:5] | | | | 0,00044 | COMMERCI | 15:8 | | | MEID[4:0] | 71.0 | | | MSID[10:8] | | 0x0644 | C2MASK0L | 7:0 | | | | MSIE | 0[7:0] | ' | | | 0x0646 | C2MASK0H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | 000040 | CZWASKUH | 7:0 | | | | MEID | [12:5] | | | | 0x0648 | C2FLTOBJ1L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | 0,0040 | CZI ETOBSTE | 7:0 | | | | SID | [7:0] | | | | 0x064A | C2FLTOBJ1H | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | 0,000-7,1 | OZI ETOBOTIT | 7:0 | | | | EID[ | 12:5] | | | | 0x064C | C2MASK1L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | ,52,50.,12 | 7:0 | | | | MSIE | 0[7:0] | | | | 0x064E | C2MASK1H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | 0,100.12 | | 7:0 | | | | MEID | [12:5] | | | | 0x0650 | C2FLTOBJ2L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | 0.0000000000000000000000000000000000000 | | 7:0 | | | | SID | [7:0] | | | | 0x0652 | C2FLTOBJ2H | 15:8 | | EXIDE | SID11 | EID | 40.51 | EID[17:13] | | | | | 7:0 | | | MEIDIA O | EID[ | 12:5] | | MOIDIAO.O | | 0x0654 | C2MASK2L | 15:8 | | | MEID[4:0] | MSIE | NT-01 | | MSID[10:8] | | | | 7:0 | | MIDE | MCID11 | MOIL | נט. זוןנ | MEID[17:12] | | | 0x0656 | C2MASK2H | 15:8<br>7:0 | | MIDE | MSID11 | MEID | [12:5] | MEID[17:13] | | | | | 15:8 | | | EID[4:0] | MEID | [12.0] | | SID[10:8] | | 0x0658 | C2FLTOBJ3L | 7:0 | | | EID[4.0] | SIDI | 7:01 | | 310[10.0] | | | | 15:8 | | EXIDE | SID11 | 310 | [7.0] | EID[17:13] | | | 0x065A | C2FLTOBJ3H | 7:0 | | LAIDL | OIDTI | EID[ | 12:51 | LID[17.10] | | | pertinant and | Charles and the second research | 15:8 | | | MEID[4:0] | LIDE | 12.01 | | MSID[10:8] | | 0x065C | C2MASK3L | 7:0 | | | | MSIE | 0[7:0] | | | | | RESTORE STREET | 15:8 | | MIDE | MSID11 | | ale sea | MEID[17:13] | | | 0x065E | C2MASK3H | 7:0 | | | | MEID | [12:5] | | | | 00000 | COELTORIAL | 15:8 | | | EID[4:0] | | | | SID[10:8] | | 0x0660 | C2FLTOBJ4L | 7:0 | | | | SID | [7:0] | · | | | 0×0662 | COELTOR MU | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | 0x0662 | C2FLTOBJ4H | 7:0 | | | | EID[ | 12:5] | | | | 0x0664 | C2MASK4L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | UXUUU- | OZIWI KOKAL | 7:0 | | | | MSIE | [7:0] | | | | 0x0666 | C2MASK4H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | A11000 A110 A110 A110 A110 A110 A110 A1 | | 7:0 | | | | MEID | [12:5] | | alatia | | 0x0668 | C2FLTOBJ5L | 15:8 | | | EID[4:0] | Eyene. | | | SID[10:8] | | | | 7:0 | | EVIDE | l albu | SIDI | [7:0] | E15117 101 | | | 0x066A | C2FLTOBJ5H | 15:8 | | EXIDE | SID11 | -, | 40.51 | EID[17:13] | | | | -2-2211 - 24-24-24-27-27 | 7:0 | | | MEIDIA:01 | EID[ | 12:5] | | MCID[10:0] | | 0x066C | C2MASK5L | 15:8<br>7:0 | | | MEID[4:0] | MSIE | )[7·0] | | MSID[10:8] | | | | 15:8 | | MIDE | MSID11 | IVISIL | [0.1] | MEID[17:13] | | | 0x066E | C2MASK5H | 7:0 | | IVIIDE | MOIDII | MEID | [12:5] | MEID[17.13] | | | | | 15:8 | | | EID[4:0] | IVIEIU | [12.0] | | SID[10:8] | | 0x0670 | C2FLTOBJ6L | 7:0 | | | 니니[4.0] | SIDI | 7:01 | | 5/D[10.0] | | | | 15:8 | | EXIDE | SID11 | וטוט | | EID[17:13] | | | 0x0672 | C2FLTOBJ6H | 7:0 | | LAIDE | JIDTI | EID[ | 12:51 | LID[17.10] | | | | | 15:8 | | | MEID[4:0] | ביטנ | ] | | MSID[10:8] | | 0x0674 | C2MASK6L | 7:0 | | | | MSIE | 0[7:0] | | 515[10.0] | | | Water State State and Autor | 15:8 | | MIDE | MSID11 | 111012 | | MEID[17:13] | | | 0x0676 | C2MASK6H | 7:0 | | | | MEID | [12:5] | [] | | | | | | | | | WILID | L J | | | | conti | nued | | | | | | |----------------------------|----------------------------------------------------------------------------------------------------------------|-------------|--------|-----------|--------------------------|--------------| | Offset | Name | Bit Pos. | 7 6 | 5 | 4 3 | 2 1 0 | | 00070 | OOF TOP 171 | 15:8 | | EID[4:0] | | SID[10:8] | | 0x0678 | C2FLTOBJ7L | 7:0 | | | SID[7:0] | | | 0x067A | C2FLTOBJ7H | 15:8 | EXIDE | SID11 | | EID[17:13] | | 0,007 | CZI ETOBS/TT | 7:0 | | | EID[12:5] | | | 0x067C | C2MASK7L | 15:8 | | MEID[4:0] | | MSID[10:8] | | 0,0070 | CZIVIAGINI | 7:0 | | | MSID[7:0] | | | 0x067E | C2MASK7H | 15:8 | MIDE | MSID11 | | MEID[17:13] | | UNGUIL | OZIII/IOITI II | 7:0 | | | MEID[12:5] | | | 0x0680 | C2FLTOBJ8L | 15:8 | | EID[4:0] | 50-740, 50-00. PS-0-0-10 | SID[10:8] | | | | 7:0 | | | SID[7:0] | | | 0x0682 | C2FLTOBJ8H | 15:8 | EXIDE | SID11 | | EID[17:13] | | | W.31 5 30 30 30 30 30 30 30 30 30 30 30 30 30 | 7:0 | | | EID[12:5] | | | 0x0684 | C2MASK8L | 15:8 | | MEID[4:0] | | MSID[10:8] | | | NOSCHON DAY AND | 7:0 | | | MSID[7:0] | | | 0x0686 | C2MASK8H | 15:8 | MIDE | MSID11 | MEIDIAO | MEID[17:13] | | | | 7:0 | | EID[4:0] | MEID[12:5] | CID[40.0] | | 0x0688 | C2FLTOBJ9L | 15:8<br>7:0 | | EID[4:0] | SID[7:0] | SID[10:8] | | | | | EVIDE | CID44 | SID[7:0] | EID(47-42) | | 0x068A | C2FLTOBJ9H | 15:8<br>7:0 | EXIDE | SID11 | EID[12:5] | EID[17:13] | | | a Van de la companya | 15:8 | | MEID[4:0] | EID[12.3] | MSID[10:8] | | 0x068C | C2MASK9L | 7:0 | | MEID[4.0] | MSID[7:0] | MISID[10.6] | | | | 15:8 | MIDE | MSID11 | [U.1]UISIWI | MEID[17:13] | | 0x068E | C2MASK9H | 7:0 | WIDE | WOIDTI | MEID[12:5] | WIEID[17.13] | | | | 15:8 | | EID[4:0] | INICID[12.0] | SID[10:8] | | 0x0690 | C2FLTOBJ10L | 7:0 | | Lib[1.0] | SID[7:0] | OID[10.0] | | | | 15:8 | EXIDE | SID11 | 0.0[1.0] | EID[17:13] | | 0x0692 | C2FLTOBJ10H | 7:0 | 271102 | 0.0 | EID[12:5] | 2.5[5] | | | BROWN CONTRACT | 15:8 | | MEID[4:0] | | MSID[10:8] | | 0x0694 | C2MASK10I | 7:0 | | | MSID[7:0] | | | | 001110111011 | 15:8 | MIDE | MSID11 | | MEID[17:13] | | 0x0696 | C2MASK10H | 7:0 | | | MEID[12:5] | | | 0000 | COELTOD MAI | 15:8 | | EID[4:0] | | SID[10:8] | | 0x0698 | C2FLTOBJ11L | 7:0 | | | SID[7:0] | | | 0x069A | C2FLTOBJ11H | 15:8 | EXIDE | SID11 | | EID[17:13] | | UXUUSA | OZI LIOBITITI | 7:0 | | | EID[12:5] | | | 0x069C | C2MASK11L | 15:8 | | MEID[4:0] | | MSID[10:8] | | UNUUUU | OZIMIOKITE . | 7:0 | | | MSID[7:0] | | | 0x069E | C2MASK11H | 15:8 | MIDE | MSID11 | | MEID[17:13] | | | , espectation | 7:0 | | | MEID[12:5] | | | 0x06A0 | C2FLTOBJ12L | 15:8 | | EID[4:0] | | SID[10:8] | | 200301412000 | 350023000 - 51440 , VENTHANGO ANTO 4550 | 7:0 | | | SID[7:0] | | | 0x06A2 | C2FLTOBJ12H | 15:8 | EXIDE | SID11 | EIDI40 EI | EID[17:13] | | | | 7:0 | | MEIDIAO | EID[12:5] | MOID(40:01 | | 0x06A4 | C2MASK12L | 15:8 | | MEID[4:0] | MOIDIZ-01 | MSID[10:8] | | | | 7:0<br>15:8 | MIDE | MQID44 | MSID[7:0] | MEID[17:12] | | 0x06A6 | C2MASK12H | 7:0 | MIDE | MSID11 | MEID[12:5] | MEID[17:13] | | | | 15:8 | | EID[4:0] | MEID[12.0] | SID[10:8] | | 0x06A8 | C2FLTOBJ13L | 7:0 | | LID[4.0] | SID[7:0] | GID[10.0] | | | | 15:8 | EXIDE | SID11 | 0,0[1,0] | EID[17:13] | | 0x06AA | C2FLTOBJ13H | 7:0 | EXIDE | 5,511 | EID[12:5] | | | | Section (Section 1) | 15:8 | | MEID[4:0] | 2.5[12.0] | MSID[10:8] | | 0x06AC | C2MASK13L | 7:0 | | | MSID[7:0] | | | and a Construction Desired | | 15:8 | MIDE | MSID11 | :[1, 1,4] | MEID[17:13] | | 0x06AE | C2MASK13H | 7:0 | 2 | | MEID[12:5] | | | 0.0050 | 0051705144 | 15.8 | | FID[4:0] | 1,, | SID[10·8] | | 0x06B0 | C2FLTOBJ14L | 7:0 | | | SID[7:0] | | | | | - 10000000 | | | | | | 15.8 | | | | | | | | | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------------------------------|----------|--------|-------------------------|-----------|--------|---------------|-------------|------------|---------| | December Color C | cont | inued | | | | | | | | | | | DAMES CAMASKISE 7.0 | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 1 | 0 | | The color of | 0.0000 | OOF! TOP IA III | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | Decoration Camaskin 7.0 | 0X06B2 | C2FLTOBJ14H | 7:0 | | | | EID[ | 12:5] | | | | | 158 | 0.0004 | 00000000000 | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | Decoration 19.8 | UXU6B4 | C2MASK14L | 7:0 | | | | MSIC | [7:0] | | | | | 158 | 00000 | 000000000000000000000000000000000000000 | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | C2FLTOBJISH | 000086 | C2MASK14H | 7:0 | | | | MEID | [12:5] | | | | | 15.8 | 0000 | COLLIODIAE | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | DAMPSILE 15.8 | UXUOBO | CZFLIOBJISL | 7:0 | | | | SID | 7:0] | | | | | 70 | OVOCDA | COELTOD MELL | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | Mode | UXUUDA | CZFLIOBJ IJH | 7:0 | | | | EID[ | 12:5] | | | | | 158 | 0×06BC | C2MASK15I | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | DAMPS CANASKISH 7-0 | UXUUBC | CZIWASKISL | 7:0 | | | | MSIE | [7:0] | | | | | 158 | 0v06BE | C2MASK15H | 15:8 | | MIDE MSID11 MEID[17:13] | | | | | | | | December Carrest | OXOODL | CZIVIACICIOII | 7:0 | | | | MEID | [12:5] | | | | | 15.8 TRBWS 3:0 ABAT RECOP[2:0] | 0x06C0 | C1CONI | 15:8 | CON | | SIDL | BRSDIS | BUSY | | Γ[1:0] | WAKFIL | | December 15.8 Test 15. | 3,0000 | CICONE | | CLKSEL | | | | | DNCNT[4:0] | | | | 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 15.8 | 0x06C2 | C1CONH | | | | VS[3:0] | | 25 00 0000000 | | | | | Note Control 15.8 Sept | 2 | 5.55,01 | | | OPMOD[2:0] | | TXQEN | | SERRLOM | ESIGM | RTXAT | | 15.8 SNM(3) | 0x06C4 | C1NBTCFGL(1) | | | | | | | | | | | DAMPS | | 2, 22(1) | | | | | | | | | | | 15.8 | 0x06C6 | C1NBTCFGH(1) | | | | | | | | | | | DAMPS | | ``` | | | | | | | | | | | 15-8 | 0x06C8 | C1DBTCFGL(1) | | | | | | | | | | | Description Table | | CONTROL OF THE ST | | | | | | | SJW | /[3:0] | | | 15.8 TDCO[6:0] TDCV[5:0] | 0x06CA | C1DBTCFGH(1) | | | | | BKP | [7:0] | T050414.01 | | | | NAME | | | | | | | | TDCO(6:01 | 1SEG 1[4:0] | | | | DX06CF | 0x06CC | C1TDCL(1) | | | | | | | V(E:01 | | | | Marker M | | | | | | | | TDC | V[5.0] | EDOCUTEN | CID11EN | | 15.8 TBC[15.8] TBC[7.0] T | 0x06CF | C1TDCH(1) | | | | | | | | | | | December Color C | | | | | | | TRCI | 15:81 | | TBOWN | 3B[1.0] | | 15:8 | 0x06D0 | C1TBCL(1,2) | | | | | | | | | | | 15.8 | an brancon | | | | | | | | | | | | 15:8 TBCPRE[7:0] TBCPRE[ | 0x06D2 | C1TBCH(1,2) | | | | | | | | | | | 15:8 | | | | | | | , | , | | TBCPF | RE[9:8] | | December 2006 Cate | 0x06D4 | CTISCONL | 7:0 | | | | TBCPF | RE[7:0] | | | | | 15:8 TSEOF TBCEN | | 0.170.00.00 | 15:8 | | | | | | | | | | 15:8 VMIF VMKIF CERRIF SERRIF RXOVIF TXATIF TXIF | 000606 | CTISCONH | 7:0 | | | | | | TSRES | TSEOF | TBCEN | | 15:8 | 00000 | O4VEOL | 15:8 | | | | | | FILHIT[4:0] | | | | 15:8 | OXUODS | CIVECL | 7:0 | | | | | ICODE[6:0] | | | | | 15:8 | 0×06DA | C1VECH | 15:8 | | | | | RXCODE[6:0] | | | | | Ox06DC | OVOODA | OTVLOR | | | | | | | 1 | | | | 15:8 IVMIE WAKIE CERRIE SERRIE RXOVIE TXATIE | 0x06DC | CIINTI | | IVMIF | WAKIF | CERRIF | | | | | | | Ox06E CTINTH | 0,0000 | SHITE | | | | | | | | RXIF | TXIF | | 7:0 TEFIE MODIE IBCIE RXIE IXIE 0x06E0 C1RXIFL(1) 15:8 RFIF[31:24] 0x06E4 C1TXIFL(1) 15:8 RFIF[23:16] 0x06E6 C1TXIFL(1) 15:8 TFIF[7:0] 0x06E8 C1TXIFL(1) 15:8 TFIF[23:16] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06EA C1RXOVIFL(1) 15:8 RFOVIF[7:1] 0x06EA C1RXOVIFL(1) 15:8 RFOVIF[31:24] | 0x06DF | C1INTH | | IVMIE | WAKIE | CERRIE | | | | | | | 0X06E0 C1RXIFL(1) 7:0 RFIF[7:1] 0x06E2 C1RXIFH(1) 15:8 RFIF[31:24] 0x06E4 C1TXIFL(1) 15:8 TFIF[15:8] 0x06E6 C1TXIFH(1) 15:8 TFIF[31:24] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[7:1] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[31:24] | ,,,,,,,,, | - marin | | | | | | | TBCIE | RXIE | TXIE | | 7:0 RFIF[7:1] 0x06E2 C1RXIFH(1) 15:8 RFIF[31:24] 7:0 RFIF[23:16] 0x06E4 C1TXIFL(1) 15:8 TFIF[15:8] 0x06E6 C1TXIFH(1) 15:8 TFIF[7:0] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[7:1] | 0x06E0 | C1RXIFL(1) | | | | | | [15:8] | | | | | 0x06E2 C1RXIFH(1) 7:0 RFIF[23:16] 0x06E4 C1TXIFL(1) 15:8 TFIF[15:8] 0x06E6 C1TXIFH(1) 15:8 TFIF[31:24] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[7:1] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[31:24] | | =(.7 | | | | | | | | | | | 0x06E4 C1TXIFL(1) 15:8 TFIF[15:8] 0x06E6 C1TXIFH(1) 15:8 TFIF[31:24] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[31:24] | 0x06E2 | C1RXIFH(1) | | | | | | | | | | | 0x06E4 C1TXIFL(1) 7:0 TFIF[7:0] 0x06E6 C1TXIFH(1) 15:8 TFIF[31:24] 7:0 TFIF[23:16] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[31:24] | | Commence of the A | | | | | | | | | | | 0x06E6 C1TXIFH(1) 15:8 TFIF[31:24] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[5:8] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[31:24] | 0x06E4 | C1TXIFL(1) | | | | | | | | | | | 0X06E6 C1TXIFH(1) 7:0 TFIF[23:16] 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 0x06EA C1RXOVIFH(1) 15:8 RFOVIF[31:24] | | | | | | | | | | | | | 0x06E8 C1RXOVIFL(1) 15:8 RFOVIF[15:8] 7:0 RFOVIF[7:1] 0x06E4 C1RXOVIEH(1) 15:8 RFOVIF[31:24] | 0x06E6 | C1TXIFH(1) | | | | | | | | | | | 0x06E8 C1RXOVIFL(1) 7:0 RFOVIF[7:1] 0x06E4 C1RXOVIEH(1) 15:8 RFOVIF[31:24] | | | | | | | | | | | | | 0v06EA C1RXOVIEH(1) 15:8 RFOVIF[31:24] | 0x06E8 | C1RXOVIFL(1) | | | | | | F[15:8] | | | | | 0906EA C1RXOVIEH(1) | | | | | | | | -134-041 | | | | | 1.0 KFOVIF[25, 10] | 0x06EA | C1RXOVIFH(1) | | | | | | | | | | | | | | 7.0 | | | | KEUVIE | [20.10] | | | | | conti | | | | | | | | | | | |------------|------------------------|-------------|---------|-------------|---------|----------------|-----------|-------------|----------|-----------| | | | D' D | | | | | | | , | | | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x06EC | C1TXATIFL(1) | 15:8 | | | | TFATII | 100 | | | | | | , , | 7:0 | | | | | IF[7:0] | | | | | 0x06EE | C1TXATIFH(1) | 15:8 | | | | TFATIF | | | | | | | Care | 7:0 | | | | TFATIF | | | | | | 0x06F0 | C1TXREQL | 15:8 | | | | TXREC | 7[10:8] | | | TVDEOO | | | | 7:0<br>15:8 | | | | TXREQ[7:1] | Q[31:24] | | | TXREQ0 | | 0x06F2 | C1TXREQH | 7:0 | | | | TXREQ[23:17] | | | | TXREQ[16] | | 0x06F4 | | 1.0 | | | | TXINE Q[20:17] | | | ) | TARLEGIO | | | Reserved | | | | | | | | | | | 0x06F7 | | | | | | | | | | | | | | 15:8 | | | | NTERRO | CNT[7:0] | | 1 | | | 0x06F8 | C1BDIAG0L | 7:0 | | | | NRERR | CNT[7:0] | | | | | 0.0054 | 0.40014.0014 | 15:8 | | | | DTERRO | CNT[7:0] | | | | | 0x06FA | C1BDIAG0H | 7:0 | | | | | CNT[7:0] | | | | | 00050 | CARDIACAL | 15:8 | | | | EFMSGC | ONT[15:8] | | | | | 0x06FC | C1BDIAG1L | 7:0 | | | | EFMSG | CNT[7:0] | | | | | OVOCEE | C1BDIAG1H | 15:8 | DLCMM | ESI | DCRCERR | DSTUFERR | DFORMERR | | DBIT1ERR | DBIT0ERR | | 0x06FE | CIBDIAGIH | 7:0 | TXBOERR | | NCRCERR | NSTUFERR | NFORMERR | NACKERR | NBIT1ERR | NBIT0ERR | | 0x0700 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x070B | | | | | | | | | | | | 0x070C | C1FIFOBAL | 15:8 | | | | | A[15:8] | | | | | | | 7:0 | | | FIFO | BA[7:2] | | | FIFOE | BA[1:0] | | 0x070E | C1FIFOBAH | 15:8 | | | | 0.00 | A[31:24] | | | | | | | 7:0 | | | FIFOB | A[23:18] | 10 | | | \[17:16] | | 0x0710 | C1TXQCONL | 15:8 | | | | | | FRESET | TXREQ | UINC | | | | 7:0 | TXEN | | | TXATIE | | TXQEIE | | TXQNIE | | 0x0712 | C1TXQCONH | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | | | 7.0 | | TXA | T[1.0] | | | TXPRI[4.0] | | | | 0x0714 | C1TXQSTAL | 15:8 | TVADT | T)(( A D D | TVEDD | TYATIF | | TXQCI[4:0] | | TVOLUE | | 0.0716 | | 7:0 | TXABT | TXLARB | TXERR | TXATIF | | TXQEIF | | TXQNIF | | 0x0716 | Reserved | | | | | | | | | | | <br>0x0717 | Neserveu | | | | | | | | | | | OXOT IT | | 15:8 | | | 1 | TXQU | A[15:8] | | | | | 0x0718 | C1TXQUAL(1) | 7:0 | | | | | JA[7:0] | | | | | | 1470-7-0-950/1-07/1-07 | 15:8 | | | | | \[31:24] | | | | | 0x071A | C1TXQUAH(1) | 7:0 | | | | | A[23:16] | | | | | | | 15:8 | | | | | | FRESET | TXREQ | UINC | | 0x071C | C1FIFOCON0L | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 00745 | OAFIFOOCHS! | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | 0x071E | C1FIFOCON0H | 7:0 | | | T[1:0] | | | TXPRI[4:0] | | | | 0×0720 | C1FIFOSTA0 | 15:8 | | | | | | FIFOCI[4:0] | | | | 0x0720 | CIFIFUSIAU | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | 0x0722 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0723 | | | | | | | | | | | | 0x0724 | C1FIFOUA0L(1) | 15:8 | | | | FIFOU | | | | | | | | 7:0 | | | | | JA[7:0] | | | | | 0x0726 | C1FIFOUA0H(1) | 15:8 | | | | | A[31:24] | | | | | | | 7:0 | | | | FIFOU | A[23:16] | | | | | 0x0728 | C1FIFOCON1L | 15:8 | | | | | | FRESET | TXREQ | UINC | | | | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 0x072A | C1FIFOCON1H | 15:8 | | PLSIZE[2:0] | Tr. 03 | | | FSIZE[4:0] | | | | | | 7:0 | | TXA | T[1:0] | | | TXPRI[4:0] | | | | 0x072C | C1FIFOSTA1 | 15:8 | TVADT | TVI ADD | TVEDD | TVATIE | DVCVIII | FIFOCI[4:0] | TEUDELUE | TENDENIE | | | | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | cont | inued | | | | | | | | | | |------------|-----------------------------------------|-------------|--------------|-------------|----------|------------------|--------------------|---------------------------|--------------|--------------| | Offset | | Dit Doc | 7 | 6 | 5 | 4 | 3 | 2 | 4 | | | | Name | Bit Pos. | 7 | • | - 5 | 4 | 3 | 2 | 1 | 0 | | 0x072E | Reserved | | | | | | | | | | | 0x072F | Reserved | | | | | | | | | | | | | 15:8 | | | | FIFOU | A[15:8] | | | | | 0x0730 | C1FIFOUA1L(1) | 7:0 | | | | | JA[7:0] | | | | | 0,0722 | CATITOLIAALI(A) | 15:8 | | | | FIFOU | A[31:24] | | | | | 0x0732 | C1FIFOUA1H(1) | 7:0 | | | | FIFOU | \[23:16] | | | | | 0x0734 | C1FIFOCON2L | 15:8 | | | | | | FRESET | TXREQ | UINC | | | | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 0x0736 | C1FIFOCON2H | 15:8<br>7:0 | | PLSIZE[2:0] | Γ[1:0] | | | FSIZE[4:0] | | | | | | 15:8 | | IAA | [1.0] | | | TXPRI[4:0]<br>FIFOCI[4:0] | | | | 0x0738 | C1FIFOSTA2 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | 0x073A | | 1.0 | 170101 | 17AE/ARB | TALITA | 170 ((1) | 10.0111 | TI EIGITH | 117111111111 | 11.14.4.14.1 | | *** | Reserved | | | | | | | | | | | 0x073B | | | | | | | | | | | | 0x073C | C1FIFOUA2L(1) | 15:8 | FIFOUA[15:8] | | | | | | | | | | | 7:0 | | | | FIFOL | | | | | | 0x073E | C1FIFOUA2H(1) | 15:8<br>7:0 | | | | FIFOUA<br>FIFOUA | | | | | | | 100001101000000000000000000000000000000 | 15:8 | | | | FIFOUA | 4[23:16] | FRESET | TXREQ | UINC | | 0x0740 | C1FIFOCON3L | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | | Paragraph SM Carry Arthrol | 15:8 | IXLIT | PLSIZE[2:0] | TOTTOLIT | 170 trie | TOTOTIL | FSIZE[4:0] | 1111101111 | TITAL TALE | | 0x0742 | C1FIFOCON3H | 7:0 | | | Γ[1:0] | | | TXPRI[4:0] | | | | 0x0744 | C1FIFOSTA3 | 15:8 | | | | | | FIFOCI[4:0] | | | | 0.0744 | CIFIFOSTAS | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TENRENIE | | 0x0746 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0747 | | 15:8 | | | | FIFOU | A[15:8] | | | | | 0x0748 | C1FIFOUA3L(1) | 7:0 | | | | FIFOL | | | | | | | | 15:8 | | | | FIFOU | | | | | | 0x074A | C1FIFOUA3H(1) | 7:0 | | | | FIFOU | | | | | | 0x074C | C1FIFOCON4L | 15:8 | | | | | | FRESET | TXREQ | UINC | | 0,0740 | CIFIFOCON4L | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 0x074C | C1FIFOCON4H | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | 0.0745 | | 7:0 | | TXA | Γ[1:0] | | | TXPRI[4:0] | | | | 0x074E | Reserved | | | | | | | | | | | 0x074F | Reserved | | | | | | | | | | | SACTOR NO. | OJE E OOTA I | 15:8 | | | | | | FIFOCI[4:0] | | | | 0x0750 | C1FIFOSTA4 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TENRENIE | | 0x0752 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0753 | | 15:0 | | | | FIECU | V14 E · O1 | | | | | 0x0754 | C1FIFOUA4L(1) | 15:8<br>7:0 | | | | | A[15:8]<br>JA[7:0] | | | | | | | 15:8 | | | | FIFOU | | | | | | 0x0756 | C1FIFOUA4H(1) | 7:0 | | | | FIFOU | | | | | | 00750 | OAFIFO OONEL | 15:8 | | | | | | FRESET | TXREQ | UINC | | 0x0758 | C1FIFOCON5L | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 0x075A | C1FIFOCON5H | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | 2.0107 | 5 | 7:0 | | TXA | Γ[1:0] | | | TXPRI[4:0] | | | | 0x075C | C1FIFOSTA5 | 15:8 | TVAST | TWISS | TVESS | TVATIE | DVC) "E | FIFOCI[4:0] | TELIBELIE | TENDENCE | | 0x075E | | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | | Reserved | | | | | | | | | | | <br>0x0/5⊢ | 1 COCIVEU | | | | | | | | | | | | | | | | | | | | | | | cont | inued | | | | | | | | | | |---------------------|---------------------------------------------------------------------------------------------------------------|-------------|----------|----------------|-----------------------------------------|----------|-----------------------|-----------------|------------|----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0.0700 | OAFIFOLIASI (4) | 15:8 | | | | FIFOU | A[15:8] | | | | | 0x0760 | C1FIFOUA5L(1) | 7:0 | | | | | JA[7:0] | | | | | 00700 | CATITOLIA FILIA | 15:8 | | | | FIFOU | A[31:24] | | | | | 0x0762 | C1FIFOUA5H(1) | 7:0 | | | | FIFOU | A[23:16] | | | | | 00704 | CAFIFOCONICI | 15:8 | | | | | | FRESET | TXREQ | UINC | | 0x0764 | C1FIFOCON6L | 7:0 | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | 0x0766 | C1FIFOCON6H | 15:8 | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | 0.0700 | CTTT OCCINOT | 7:0 | | TXAT | [1:0] | | | TXPRI[4:0] | | | | 0x0768 | C1FIFOSTA6 | 15:8 | | | | | | FIFOCI[4:0] | | | | | 011111 0011110 | 7:0 | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | 0x076A | | | | | | | | | | | | <br>007CD | Reserved | | | | | | | | | | | 0x076B | | 15:8 | | | | FIFOLI | A[15:8] | | | | | 0x076C | C1FIFOUA6L(1) | 7:0 | | | | | JA[7:0] | | | | | | | 15:8 | | | | | A[31:24] | | | | | 0x076E | C1FIFOUA6H(1) | 7:0 | | | | | A[23:16] | | | | | | Name and Association | 15:8 | FLTENb | | | 1 11 00/ | . <sub>[</sub> _0.10] | FbBP[4:0] | | | | 0x0770 | C1FLTCON0L | 7:0 | FLTENa | | | | | FaBP[4:0] | | | | | CONTROL DE | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | 0x0772 | C1FLTCON0H | 7:0 | FLTENC | | | | | FcBP[4:0] | | | | | | 15:8 | FLTENb | | | | | FbBP[4:0] | | | | 0x0774 | C1FLTCON1L | 7:0 | FLTENa | | | | | FaBP[4:0] | | | | 00 10000000 | face " man brown territoria et glante! | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | 0x0776 | C1FLTCON1H | 7:0 | FLTENC | | | | | FcBP[4:0] | | | | 0.0770 | CAFITOONIO | 15:8 | FLTENb | | | | | FbBP[4:0] | | | | 0x0778 | C1FLTCON2L | 7:0 | FLTENa | | | | | FaBP[4:0] | | | | 0.0774 | CAFLTCONOLL | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | 0x077A | C1FLTCON2H | 7:0 | FLTENc | | | | | FcBP[4:0] | | | | 0x077C | C1FLTCON3L | 15:8 | FLTENb | | | | | FbBP[4:0] | | | | OXOTTO | O II ET CONCE | 7:0 | FLTENa | | | | | FaBP[4:0] | | | | 0x077E | C1FLTCON3H | 15:8 | FLTENd | | | | | FdBP[4:0] | | | | | | 7:0 | FLTENc | | | | | FcBP[4:0] | | | | 0x0780 | C1FLTOBJ0L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | | | 7:0 | | EVIDE | OID44 | SID | [7:0] | EID147 401 | | | | 0x0782 | C1FLTOBJ0H | 15:8 | | EXIDE | SID11 | FIDI | 40.51 | EID[17:13] | | | | | 0.0000000000000000000000000000000000000 | 7:0<br>15:8 | | | MEIDIA:01 | EID[ | 12:5] | I | MOIDIAO:01 | | | 0x0784 | C1MASK0L | 7:0 | | | MEID[4:0] | Meli | D[7:0] | | MSID[10:8] | | | | | 15:8 | | MIDE | MSID11 | IVIOIL | J[7.0] | MEID[17:13] | | | | 0x0786 | C1MASK0H | 7:0 | | MIDE | וו חוסוייו | MEID | [12:5] | [וו]טובוטן | | | | 22 | | 15:8 | | | EID[4:0] | IVILID | [,2.0] | | SID[10:8] | | | 0x0788 | C1FLTOBJ1L | 7:0 | | | 2.5[1.0] | SID | [7:0] | | 0.5[10.0] | | | | particular second or | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | 0x078A | C1FLTOBJ1H | 7:0 | | N. 30. 3000 30 | 220000000000000000000000000000000000000 | EID[ | 12:5] | 50,000 1000 000 | | | | 00700 | 0411401441 | 15:8 | | | MEID[4:0] | | - | | MSID[10:8] | | | 0x078C | C1MASK1L | 7:0 | | | 10. | MSI | D[7:0] | | | | | 0x078E | C1MASK1H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | UXUTUL | CHWAGKITI | 7:0 | | | | MEID | [12:5] | | | | | 0x0790 | C1FLTOBJ2L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | 0.07.50 | O II ETOBOZE | 7:0 | | | | SID | [7:0] | | | | | 0x0792 | C1FLTOBJ2H | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | 0,0102 | 5 11 E1 OD0211 | 7:0 | | | | EID[ | 12:5] | | | | | 0x0794 | C1MASK2L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | | | 7:0 | | | | MSI | D[7:0] | | | | | 0x0796 | C1MASK2H | 15:8 | | MIDE | MSID11 | !- | | MEID[17:13] | | | | community the state | Personal new Principal Pyrintin | 7:0 | | | FIDIAGO | MEID | [12:5] | | OIDI40 01 | | | 0x0798 | C1FLTOBJ3L | 15:8<br>7:0 | | | EID[4:0] | CID | [7:0] | | SID[10:8] | | | | | 7:0 | SID[7:0] | | | | | | | | | conti | inued | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---|-------|-----------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 3 | 2 1 0 | | 0×0704 | C4FLTOD I2LL | 15:8 | | EXIDE | SID11 | | EID[17:13] | | 0x079A | C1FLTOBJ3H | 7:0 | | | | EID[12:5] | | | 0x079C | C1MASK3L | 15:8 | | | MEID[4:0] | | MSID[10:8] | | 0.0730 | CHWAGROL | 7:0 | | | | MSID[7:0] | | | 0x079E | C1MASK3H | 15:8 | | MIDE | MSID11 | | MEID[17:13] | | OXOTOL | OTWACKOTT | 7:0 | | | | MEID[12:5] | | | 0x07A0 | C1FLTOBJ4L | 15:8 | | | EID[4:0] | | SID[10:8] | | | | 7:0 | | | | SID[7:0] | | | 0x07A2 | C1FLTOBJ4H | 15:8 | | EXIDE | SID11 | | EID[17:13] | | | | 7:0 | | | MEIDIA | EID[12:5] | MOUDIAGO | | 0x07A4 | C1MASK4L | 15:8 | | | MEID[4:0] | MOUDIT O | MSID[10:8] | | | Configuration Production | 7:0 | | MIDE | MOID44 | MSID[7:0] | MEIDIA7.401 | | 0x07A6 | C1MASK4H | 15:8 | | MIDE | MSID11 | MEIDIAO.EI | MEID[17:13] | | | | 7:0 | | | EIDI4:01 | MEID[12:5] | CID(10.0) | | 0x07A8 | C1FLTOBJ5L | 15:8<br>7:0 | | | EID[4:0] | SID[7:0] | SID[10.8] | | | | 15:8 | | EXIDE | SID11 | 310[7.0] | EID[17:13] | | 0x07AA | C1FLTOBJ5H | 7:0 | | EXIDE | 31011 | EID[12:5] | EID[17.13] | | | | 15:8 | | | MEID[4:0] | LID[12.0] | MSID[10:8] | | 0x07AC | C1MASK5L | 7:0 | | | WEID[4.0] | MSID[7:0] | WOID[10.0] | | | Control Control Control | 15:8 | | MIDE | MSID11 | moio[r.o] | MEID[17:13] | | 0x07AE | C1MASK5H | 7:0 | | | | MEID[12:5] | Encoded | | | | 15:8 | | | EID[4:0] | | SID[10:8] | | 0x07B0 | C1FLTOBJ6L | 7:0 | | | | SID[7:0] | | | 0.0700 | O 4 E L TOD 10 L | 15:8 | | EXIDE | SID11 | | EID[17:13] | | 0x07B2 | C1FLTOBJ6H | 7:0 | | | | EID[12:5] | | | 00704 | 0414401401 | 15:8 | | | MEID[4:0] | | MSID[10:8] | | 0x07B4 | C1MASK6L | 7:0 | | | | MSID[7:0] | | | 0x07B6 | C1MASK6H | 15:8 | | MIDE | MSID11 | | MEID[17:13] | | UXU7 DU | CHWASKOH | 7:0 | | | | MEID[12:5] | | | 0x07B8 | C1FLTOBJ7L | 15:8 | | | EID[4:0] | | SID[10:8] | | | 0.11.000.12 | 7:0 | | | | SID[7:0] | | | 0x07BA | C1FLTOBJ7H | 15:8 | | EXIDE | SID11 | 0.0000000000000000000000000000000000000 | EID[17:13] | | 1 A A A A A A A A A A A A A A A A A A A | \$10 PM 1, \$60 PM 15 C 200 1 | 7:0 | | | MEIDIA | EID[12:5] | MolPring | | 0x07BC | C1MASK7L | 15:8 | | | MEID[4:0] | MOIDI7.01 | MSID[10:8] | | | | 7:0 | | MIDE | MOID44 | MSID[7:0] | MEIDIA7.401 | | 0x07BE | C1MASK7H | 15:8<br>7:0 | | MIDE | MSID11 | MEID[12:5] | MEID[17:13] | | | | 15:8 | | | EID[4:0] | MEID[12.0] | SID[10:8] | | 0x07C0 | C1FLTOBJ8L | 7:0 | | | LID[4.0] | SID[7:0] | [10.0] | | | | 15:8 | | EXIDE | SID11 | ره. ۱۲ مات | EID[17:13] | | 0x07C2 | C1FLTOBJ8H | 7:0 | | | 2,2,1 | EID[12:5] | | | The second secon | | 15:8 | | | MEID[4:0] | [] | MSID[10:8] | | 0x07C4 | C1MASK8L | 7:0 | | | | MSID[7:0] | and the second s | | 00763 | O4F4 OUSS!! | 15:8 | | MIDE | MSID11 | | MEID[17:13] | | 0x07C6 | C1MASK8H | 7:0 | | | | MEID[12:5] | | | 0.0709 | C4ELTOR IN | 15:8 | | | EID[4:0] | | SID[10:8] | | 0x07C8 | C1FLTOBJ9L | 7:0 | | | | SID[7:0] | | | 0x07CA | C1FLTOBJ9H | 15:8 | | EXIDE | SID11 | | EID[17:13] | | UNUTUA | O II ETOBJAN | 7:0 | | | | EID[12:5] | | | 0x07CC | C1MASK9L | 15:8 | | | MEID[4:0] | | MSID[10:8] | | 3,3100 | O INFORME | 7:0 | | | | MSID[7:0] | | | 0x07CE | C1MASK9H | 15:8 | | MIDE | MSID11 | | MEID[17:13] | | | 2 | 7:0 | | | | MEID[12:5] | | | 0x07D0 | C1FLTOBJ10L | 15:8 | | | EID[4:0] | | SID[10:8] | | ONOTED OTPLIODITUL | 7:0 | | | a.e. | SID[7:0] | | | | 0x07D2 | C1FLTOBJ10H | 15.8 | | FXIDE | SID11 | EID! (C. E. | FID[17:13] | | | areas on community and a second division. | 7:0 | | | | EID[12:5] | | | cont | inued | | | | | | | | | | |---------|--------------------------|----------|---|-------|-----------|----------|-----|-------------|------------|---| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x07D4 | C1MASK10L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | 0,0704 | CHMASKICE | 7:0 | | | | MSID[7:0 | 0] | | | | | 0x07D6 | C1MASK10H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | | OTWASKION | 7:0 | | | | MEID[12: | 5] | | | | | 0x07D8 | C1FLTOBJ11L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | OXOTEO | OTILIOBITIL | 7:0 | | | | SID[7:0] | | | | | | 0x07DA | C1FLTOBJ11H | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | OXOTER | OH ETOBOTHI | 7:0 | | | | EID[12:5 | 5] | | | | | 0x07DC | C1MASK11L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | OXOTEO | OTWACKTIE | 7:0 | | | | MSID[7:0 | )] | | | | | 0x07DE | C1MASK11H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | OXOTEL | OTWACKTITI | 7:0 | | | | MEID[12: | 5] | | | | | 0x07E0 | C1FLTOBJ12L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | UNUTEO | O II ETODOTZE | 7:0 | | | | SID[7:0] | | | | | | 0x07E2 | C1FLTOBJ12H | 15.8 | | EXIDE | SID11 | | | EID[17:13] | | | | UNUTLZ | OTI ETOBOTZIT | 7:0 | | | | EID[12:5 | [i] | | | | | 0x07E4 | C1MASK12L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | 0,07,04 | | 7:0 | | | | MSID[7:0 | 0] | | | | | 0x07E6 | C1MASK12H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | UXU7LU | | 7:0 | | | | MEID[12: | 5] | | | | | 0x07E8 | C1FLTOBJ13L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | OXO7 LO | | 7:0 | | | | SID[7:0] | | | | | | 0x07EA | C1FLTOBJ13H | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | OXOTEA | | 7:0 | | | | EID[12:5 | j] | | | | | 0x07EC | C1MASK13I | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | UXUTEC | C1MASK13L | 7:0 | | | | MSID[7:0 | 0] | | | | | 0x07EE | C1MASK13H<br>C1FITOBJ14I | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | UXUTEE | | 7:0 | | | | MEID[12: | 5] | | | | | 0x07F0 | | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | UXU/FU | | 7:0 | | | | SID[7:0] | | | | | | 0x07F2 | C1FLTOBJ14H | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | 0.0112 | CTFLTOBJ14H | 7:0 | | | | EID[12:5 | j] | | | | | 0x07F4 | C1MASK14L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | 0,0/14 | CTMASK14L | 7:0 | | | | MSID[7:0 | 0] | | | | | 0x07F6 | C1MASK14H | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | CAUTE O | C IIVIASK 14H | 7:0 | | | | MEID[12: | 5] | | | | | 0x07F8 | C1FLTOBJ15L | 15:8 | | | EID[4:0] | | | | SID[10:8] | | | 0,0710 | C1FL1OBJ15L | 7:0 | | | | SID[7:0] | | | | | | 0x07FA | C1FLTOBJ15H | 15:8 | | EXIDE | SID11 | | | EID[17:13] | | | | ONUTTA | | 7:0 | | | | EID[12:5 | j] | | | | | 0x07FC | C1MASK15L | 15:8 | | | MEID[4:0] | | | | MSID[10:8] | | | UNUTFU | | 7:0 | | | | MSID[7:0 | 0] | | | | | 0×0755 | C1MASK15U | 15:8 | | MIDE | MSID11 | | | MEID[17:13] | | | | 0x07FE | C1MASK15H | 7:0 | | | | MEID[12: | 5] | | | | ## 11.2.1 CAN2 FIFO Control Register x Low (x = 1 to 7) Name: C2FIFOCONxL **Offset:** 0x5DC, 0x5E8, 0x5F4, 0x600, 0x60C, 0x618, 0x624 #### Note: 1. This bit can only be modified in Configuration mode (OPMOD[2:0] = 100). Legend: S = Settable bit; HC = Hardware Clearable bit #### Bit 10 - FRESET FIFO Reset bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 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 TXEN = 0 (FIFO configured as a receive FIFO): This bit has no effect. TXEN = 1 (FIFO configured as a transmit FIFO): | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 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 | ## 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 | Value | Description | |-------|--------------------------| | 1 | Transmits message object | | 0 | Receives message object | ## Bit 6 - RTREN Auto-Remote Transmit (RTR) Enable bit | Value | Description | |-------|--------------------------------------------------------------| | 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 Timestamp Enable bit(1) | Value | Description | |-------|------------------------------------------------------| | 1 | Captures timestamp in received message object in RAM | | 0 | Does not capture timestamp | ## Bit 4 - TXATIE Transmit Attempts Exhausted Interrupt Enable bit ## Controller Area Network Flexible Data-Rate (... | Value | Description | |-------|--------------------| | 1 | Enables interrupt | | 0 | Disables interrupt | #### Bit 3 - RXOVIE Overflow Interrupt Enable bit | Value | Description | |-------|------------------------------------------| | 1 | Interrupt is enabled for overflow event | | 0 | Interrupt is disabled for overflow event | #### 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 is enabled for FIFO empty - 0 = Interrupt is disabled for FIFO empty TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Full Interrupt Enable. - 1 = Interrupt is enabled for FIFO full - 0 = Interrupt is 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 is enabled for FIFO half empty - 0 = Interrupt is disabled for FIFO half empty TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Half Full Interrupt Enable. - 1 = Interrupt is enabled for FIFO half full - 0 = Interrupt is 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 is enabled for FIFO not full - 0 = Interrupt is disabled for FIFO not full TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Not Empty Interrupt Enable. - 1 = Interrupt is enabled for FIFO not empty - 0 = Interrupt is disabled for FIFO not empty ## 11.2.2 CAN2 FIFO Control Register x High (x = 1 to 7) Name: C2FIFOCONxH **Offset:** 0x5DE, 0x5EA, 0x5F6, 0x602, 0x60E, 0x61A, 0x626 #### Note: 1. These bits can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-------------|--------|-----|-----|------------|-----|-----| | | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TXA | Γ[1:0] | | | TXPRI[4:0] | | | | Access | | R/W | Reset | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | ### Bits 15:13 - PLSIZE[2:0] Payload Size bits(1) | Value | Description | |-------|---------------| | 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 | #### Bits 12:8 - FSIZE[4:0] FIFO Size bits(1) | Value | Description | |-------|--------------------------| | 11111 | FIFO is 32 messages deep | | | | | 00010 | FIFO is 3 messages deep | | 00001 | FIFO is 2 messages deep | | 00000 | FIFO is 1 message deep | ## Bits 6:5 – TXAT[1:0] Retransmission Attempts bits This feature is enabled when RTXAT (C1CONH[0]) is set. | Value | Description | |-------|---------------------------------------------| | 11 | Unlimited number of retransmission attempts | | 10 | Unlimited number of retransmission attempts | | 01 | Three retransmission attempts | | 00 | Disables retransmission attempts | ## Bits 4:0 - TXPRI[4:0] Message Transmit Priority bits | Value | Description | |---------|--------------------------| | 11111 | Highest message priority | | · • • • | | | 00000 | Lowest message priority | ## Controller Area Network Flexible Data-Rate (... ## 11.2.3 CAN2 FIFO Status Register x (x = 1 to 7) Name: C2FIFOSTAx **Offset:** 0x5E0, 0x5EC, 0x5F8, 0x604, 0x610, 0x61C, 0x628 #### Notes: - 1. FIFOCI[4:0] bits give a zero-indexed value to the message in the FIFO. If the FIFO is four messages deep (FSIZE[4:0] = 3), FIFOCIx will take on a value of 0 to 3, depending on the state of the FIFO. - 2. These bits are updated when a message completes (or aborts) or when the FIFO is reset. - This bit is reset on any read of this register or when the TXQ is reset. The bits are cleared when TXREQ is set or using an SPI write. Legend: HS = Hardware Settable bit; C = Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|--------|-------|--------|--------|-------------|----------|----------| | | | | | | | FIFOCI[4:0] | | | | Access | | | | R | R | R | R | R | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | Access | R | R | R | HS/C | HS/C | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bits 12:8 - FIFOCI[4:0] FIFO Message Index bits(1) 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(3) | Value | Description | |-------|--------------------------------| | 1 | Message was aborted | | 0 | Message completed successfully | ### Bit 6 - TXLARB Message Lost Arbitration Status bit(2) | Value | Description | |-------|---------------------------------------------------| | 1 | Message lost arbitration while being sent | | 0 | Message did not lose arbitration while being sent | ### Bit 5 - TXERR Error Detected During Transmission bit(2) | Value | Description | |-------|------------------------------------------------------------| | 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 = 0 (FIFO configured as a receive buffer): Unused, read as '0'. TXEN = 1 (FIFO configured as a transmit buffer): | Value | Description | |-------|--------------------------| | 1 | Interrupt is pending | | 0 | Interrupt is not pending | #### Bit 3 - RXOVIF Receive FIFO Overflow Interrupt Flag bit TXEN = 1 (FIFO configured as a transmit buffer): Unused, read as '0'. © 2021 Microchip Technology Inc. and its subsidiaries ## Controller Area Network Flexible Data-Rate (... TXEN = 0 (FIFO configured as a receive buffer): | Value | Description | |-------|--------------------------------| | 1 | Overflow event has occurred | | 0 | No overflow event has occurred | #### 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 one message is 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 ≤ half full 0 = FIFO is > half full TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Half Full Interrupt Flag. 1 = FIFO is ≥ half full 0 = FIFO is < 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 ## 11.2.4 CAN2 FIFO Status High Register x (x = 1 to 7) Name: C2FIFOSTAxH **Offset:** 0x5E2, 0x5EE, 0x5FA, 0x608, 0x614, 0x620, 0x62E #### Notes: - 1. FIFOCI[4:0] gives a zero-indexed value to the message in the FIFO. If the FIFO is four messages deep (FSIZE[4:0] = 3), FIFOCIx will take on a value of 0 to 3, depending on the state of the FIFO. - 2. These bits are updated when a message completes (or aborts) or when the FIFO is reset. - 3. This bit is reset on any read of this register or when the TXQ is reset. The bits are cleared when TXREQ is set or using an SPI write. Legend: HS = Hardware Settable bit; C = Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|--------|-------|--------|--------|-------------|----------|----------| | | | | | | | FIFOCI[4:0] | | | | Access | | | | R | R | R | R | R | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | Access | R | R | R | HS/C | HS/C | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bits 12:8 - FIFOCI[4:0] FIFO Message Index bits(1) 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(3) | Value | Description | |-------|--------------------------------| | 1 | Message was aborted | | 0 | Message completed successfully | #### Bit 6 - TXLARB Message Lost Arbitration Status bit(2) | Dit o 17 | LEARS Wessage Esst / Wolfraction States bit | |----------|---------------------------------------------------| | Value | Description | | 1 | Message lost arbitration while being sent | | 0 | Message did not lose arbitration while being sent | #### Bit 5 - TXERR Error Detected During Transmission bit(2) | Value | Description | |-------|------------------------------------------------------------| | 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 = 0 (FIFO configured as a receive buffer): Unused, read as '0'. TXEN = 1 (FIFO configured as a transmit buffer): | Value | Description | |-------|--------------------------| | 1 | Interrupt is pending | | 0 | Interrupt is not pending | #### Bit 3 - RXOVIF Receive FIFO Overflow Interrupt Flag bit TXEN = 1 (FIFO configured as a transmit buffer): Unused, read as '0'. ## Controller Area Network Flexible Data-Rate (... TXEN = 0 (FIFO configured as a receive buffer): | Value | Description | |-------|--------------------------------| | 1 | Overflow event has occurred | | 0 | No overflow event has occurred | #### 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 one message is 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 ≤ half full 0 = FIFO is > half full TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Half Full Interrupt Flag. 1 = FIFO is ≥ half full 0 = FIFO is < 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 ## Controller Area Network Flexible Data-Rate (... ## 11.2.5 CAN2 FIFO User Address Register x Low (x = 1 to 7) Name: C2FIFOUAxL<sup>(1)</sup> **Offset:** 0x5E4, 0x5F0, 0x5FC, 0x608, 0x614, 0x620, 0x62C #### Note: This register is not ensured to read correctly in Configuration mode and should only be accessed when the module is not in Configuration mode. ## Legend: x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-------|---------|----|---|---| | | | | | FIFOU | A[15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | x | X | X | X | X | X | X | X | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FIFOL | JA[7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | X | X | X | X | X | X | X | X | #### Bits 15:0 - FIFOUA[15: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). ## Controller Area Network Flexible Data-Rate (... ## 11.2.6 CAN2 FIFO User Address Register x High (x = 1 to 7) Name: C2FIFOUAxH<sup>(1)</sup> **Offset:** 0x5E6, 0x5F2, 0x5FE, 0x60A, 0x616, 0x622, 0x62E #### Note: This register is not ensured to read correctly in Configuration mode and should only be accessed when the module is not in Configuration mode. ### Legend: x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-------|----------|----|---|---| | | | | | FIFOU | A[31:24] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FIFOU | A[23:16] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X | #### Bits 15:0 - FIFOUA[31:16] 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). ## 11.2.7 CAN2 Filter Control Register x Low (x = 0 to 3; a = 0, 4, 8, 12; b = 1, 5, 9, 13) Name: C2FLTCONxL **Offset:** 0x630, 0x634, 0x638, 0x63C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|----|-----|-----|-----------|-----|-----| | | FLTENb | | | | | FbBP[4:0] | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FLTENa | | | | | FaBP[4:0] | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - FLTENb Enable Filter b to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | ### Bits 12:8 - FbBP[4:0] Pointer to Object When Filter b Hits bits | Value | Description | |-------------|---------------------------------------------------------------| | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | | | | 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 can't receive messages | ## Bit 7 - FLTENa Enable Filter a to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | ## Bits 4:0 - FaBP[4:0] Pointer to Object When Filter a Hits bits | Value | Description | |--------------|---------------------------------------------------------------| | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | <b>4</b> • • | | | 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 can't receive messages | ## 11.2.8 CAN2 Filter Control Register x High (x = 0 to 3; c = 2, 6, 10, 14; d = 3, 7, 11, 15) Name: C2FLTCONxH **Offset:** 0x632, 0x636, 0x63A, 0x63E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|--------|----|----|-----------|-----|-----|-----|-----|--|--| | | FLTENd | | | FdBP[4:0] | | | | | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | FLTENc | | | FcBP[4:0] | | | | | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | | | #### Bit 15 - FLTENd Enable Filter d to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | #### Bits 12:8 - FdBP[4:0] Pointer to Object When Filter d Hits bits | Value | Description | |-------------|---------------------------------------------------------------| | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | | | | 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 can't receive messages | ### Bit 7 - FLTENc Enable Filter c to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | ## Bits 4:0 - FcBP[4:0] Pointer to Object When Filter c Hits bits | Value | Description | |--------------|---------------------------------------------------------------| | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | <b>4</b> • • | | | 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 can't receive messages | # Controller Area Network Flexible Data-Rate (... # 11.2.9 CAN2 Filter Object Register x Low (x = 0 to 15) Name: C2FLTOBJxL **Offset:** 0x642, 0x648, 0x650, 0x658,0x660, 0x668, 0x670, 0x678, 0x680, 0x688, 0x690, 0x698, 0x6A0, 0x6A8, 0x6B0, 0x6B8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------|-----|----------|-----|-----|-----------|-----|-----|--|--| | | | | EID[4:0] | | | SID[10:8] | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SID[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:11 - EID[4:0] Extended Identifier Filter bits In DeviceNet<sup>™</sup> mode, these are the filter bits for the first two data bytes. Bits 10:0 - SID[10:0] Standard Identifier Filter bits ## Controller Area Network Flexible Data-Rate (... ## 11.2.10 CAN2 Filter Object Register x High (x = 0 to 15) Name: C2FLTOBJxH **Offset:** 0x644, 0x64A, 0x652, 0x65A,0x662, 0x66A, 0x672, 0x67A, 0x682, 0x68A, 0x692, 0x69A, 0x6A2, 0x6AA, 0x6B2, 0x6BA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----------|-------|-------|-----|------------|-----|-----|-----|--|--|--| | | | EXIDE | SID11 | | EID[17:13] | | | | | | | | Access | | R/W | | | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | EID[12:5] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bit 14 - EXIDE Extended Identifier Enable bit If MIDE = 1: | Value | Description | |-------|----------------------------------------------------------| | 1 | Matches only messages with Extended Identifier addresses | | 0 | Matches only messages with Standard Identifier addresses | #### Bit 13 - SID11 Standard Identifier Filter bit ### Bits 12:0 - EID[17:5] Extended Identifier Filter bits In DeviceNet<sup>™</sup> mode, these are the filter bits for the first two data bytes. # Controller Area Network Flexible Data-Rate (... # 11.2.11 CAN 2 Mask Register x Low (x = 0 to 15) Name: C2MASKxL **Offset:** 0x644, 0x64C, 0x654, 0x65C, 0x664, 0x66C, 0x674, 0x67C, 0x684, 0x68C, 0x694, 0x69C, 0x6A4, 0x6AC, 0x6B4, 0x6BC | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----------|-----|-----------|-----|-----|------------|-----|-----|--|--| | | | | MEID[4:0] | | | MSID[10:8] | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Γ | MSID[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:11 - MEID[4:0] Extended Identifier Mask bits In DeviceNet<sup>™</sup> mode, these are the mask bits for the first two data bytes. Bits 10:0 - MSID[10:0] Standard Identifier Mask bits # 11.2.12 CAN2 Mask Register x High (x = 0 to 15) Name: C2MASKxH **Offset:** 0x646, 0x64E, 0x656, 0x65E, 0x666, 0x66E, 0x676, 0x67E, 0x686, 0x68E, 0x696, 0x69E, 0x6A6, 0x6AE, 0x6B6, 0x6BE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|------------|------|--------|-----|-------------|-----|-----|-----|--|--|--| | | | MIDE | MSID11 | | MEID[17:13] | | | | | | | | Access | | R/W | | | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | MEID[12:5] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bit 14 - MIDE Identifier Receive Mode bit | Value | Description | |-------|---------------------------------------------------------------------------------------------------| | 1 | Matches only message types (standard or extended address) that correspond to the EXIDE bit in the | | | filter | | 0 | Matches 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 13 - MSID11 Standard Identifier Mask bit ### Bits 12:0 - MEID[17:5] Extended Identifier Mask bits In DeviceNet<sup>™</sup> mode, these are the mask bits for the first two data bytes. ## Controller Area Network Flexible Data-Rate (... ## 11.2.13 CAN Control Register Low Name: C1CONL Offset: 0x6C0 #### Note: 1. These bits can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|----------|--------|------|------------|-----|--------| | | CON | | SIDL | BRSDIS | BUSY | WFT[1:0] | | WAKFIL | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CLKSEL | PXEDIS | ISOCRCEN | | | DNCNT[4:0] | | | | Access | R/W | Reset | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - CON CAN Enable bit | Value Description | | |-------------------|------------------------| | 1 | CAN module is enabled | | 0 | CAN module is disabled | ### Bit 13 - SIDL CAN Stop in Idle Control bit | Value | Description | | | | |-------|---------------------------------------------|--|--|--| | 1 | Stops module operation in Idle mode | | | | | 0 | Does not stop module operation in Idle mode | | | | ### Bit 12 - BRSDIS Bit Rate Switching (BRS) Disable bit | Value | Description | |-------|----------------------------------------------------------------------------------| | 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 | Value Description | | | |-------------------|----------------------------|--| | 1 | The CAN module is active | | | 0 | The CAN module is inactive | | ### Bits 10:9 - WFT[1:0] Selectable Wake-up Filter Time bits | Value | Description | |-------|-----------------------| | 11 | T11 <sub>FILTER</sub> | | 10 | T10 <sub>FILTER</sub> | | 01 | T01 <sub>FILTER</sub> | | 00 | T00 <sub>FILTER</sub> | #### Bit 8 - WAKFIL Enable CAN Bus Line Wake-up Filter bit(1) | Value | Description | | | | |-------|---------------------------------------------|--|--|--| | 1 | Uses CAN bus line filter for wake-up | | | | | 0 | CAN bus line filter is not used for wake-up | | | | #### Bit 7 - CLKSEL Module Clock Source Select bit(1) | Valu | e Description | |------|--------------------------------------------------| | 1 | Auxiliary clock is active when module is enabled | | 0 | CAN clock is not active when module is enabled | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 438 # Controller Area Network Flexible Data-Rate (... Bit 6 - PXEDIS Protocol Exception Event Detection Disabled bit(1) A recessive "reserved bit" following a recessive FDF bit is called a Protocol Exception. | Value | Description | | | | |-------|-------------------------------------------------------------------------------|--|--|--| | 1 | Protocol Exception is treated as a form error | | | | | 0 | If a Protocol Exception is detected, CAN will enter the bus integrating state | | | | #### Bit 5 - ISOCRCEN Enable ISO CRC in CAN FD Frames bit(1) | V | alue | Description | | | | |---|------|-------------------------------------------------------------------------------------------------|--|--|--| | 1 | | Includes stuff bit count in CRC field and uses non-zero CRC initialization vector | | | | | 0 | | Does not include stuff bit count in CRC field and uses CRC initialization vector with all zeros | | | | # Bits 4:0 - DNCNT[4:0] DeviceNet<sup>™</sup> Filter Bit Number bits | Value | Description | | | | |-------------|-------------------------------------------------------------|--|--|--| | 10011-11111 | Invalid selection (compares up to 18 bits of data with EID) | | | | | 10010 | Compares up to Data Byte 2, bit 6 with EID17 | | | | | | | | | | | 00001 | Compares up to Data Byte 0, bit 7 with EID0 | | | | | 00000 | Does not compare data bytes | | | | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 439 ## 11.2.14 CAN Control Register High Name: C1CONH Offset: 0x6C2 #### Note: 1. These bits can only be modified in Configuration mode (OPMOD[2:0] = 100). Legend: S = Settable bit; HC = Hardware Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|------------|-----|-------|------|---------|------------|-------| | | | TXBWS[3:0] | | | ABAT | | REQOP[2:0] | | | Access | R/W | R/W | R/W | R/W | S/HC | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | OPMOD[2:0] | | TXQEN | STEF | SERRLOM | ESIGM | RTXAT | | Access | R | R | R | R/W | R/W | R/W | R/W | R/W | | Reset | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | ### Bits 15:12 - TXBWS[3:0] Transmit Bandwidth Sharing bits | Value | Description | |-----------|-------------| | 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 11 - ABAT Abort All Pending Transmissions bit | V | alue | Description | | | | | |---|------|---------------------------------------------------------------|--|--|--|--| | 1 | ē. | Signals all transmit buffers to abort transmission | | | | | | 0 | | Module will clear this bit when all transmissions are aborted | | | | | #### Bits 10:8 - REQOP[2:0] Request Operation Mode bits | Value | Description | |-------|------------------------------------------------------------------------------------| | 111 | Sets Restricted Operation mode | | 110 | Sets Normal CAN 2.0 mode; error frames on CAN FD frames | | 101 | Sets External Loopback mode | | 100 | Sets Configuration mode | | 011 | Sets Listen Only mode | | 010 | Sets Internal Loopback mode | | 001 | Sets Disable mode | | 000 | Sets Normal CAN FD mode; supports mixing of full CAN FD and classic CAN 2.0 frames | #### Bits 7:5 - OPMODI2:01 Operation Mode Status bits | Dits 7.3 - OF MODIZ.0] Operation wode otatus bits | | | | | |---------------------------------------------------|-----------------------------------------------------------------|--|--|--| | Value | Description | | | | | 111 | Module is in Restricted Operation mode | | | | | 110 | Module is in Normal CAN 2.0 mode; error frames on CAN FD frames | | | | | 101 | Module is in External Loopback mode | | | | # Controller Area Network Flexible Data-Rate (... | Value | Description | |-------|--------------------------------------------------------------------------------------------| | 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 | ### Bit 4 - TXQEN Enable Transmit Queue bit(1) | Value Description | | | | |-------------------|----------------------------------------------------------------|--|--| | 1 | Enables Transmit Message Queue (TXQ) and reserves space in RAM | | | | 0 | Does not reserve space in RAM for TXQ | | | ## Bit 3 - STEF Store in Transmit Event FIFO bit(1) | Value Description | | | | | |-------------------|-------------------------------------------|--|--|--| | 1 | Saves transmitted messages in TEF | | | | | 0 | Does not save transmitted messages in TEF | | | | ### Bit 2 – SERRLOM Transition to Listen Only Mode on System Error bit(1) | Value | Description | | | | |-------|------------------------------------------|--|--|--| | 1 | Transitions to Listen Only mode | | | | | 0 | Transitions to Restricted Operation mode | | | | ## Bit 1 - ESIGM Transmit ESI in Gateway Mode bit(1) | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | ESI is transmitted as recessive when ESI of the message is high or CAN controller is error passive | | 0 | ESI reflects error status of CAN controller | ## Bit 0 - RTXAT Restrict Retransmission Attempts bit(1) | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Restricted retransmission attempts, uses TXAT[1:0] bits (C1TXQCONH[6:5]) | | 0 | Unlimited number of retransmission attempts, TXAT[1:0] bits will be ignored | Controller Area Network Flexible Data-Rate (... ## 11.2.15 CAN Nominal Bit Time Configuration Register Low Name: C1NBTCFGL<sup>(1)</sup> Offset: 0x6C4 #### Note: 1. These bits can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----|-----|-----|-----|----------|-----|-----|-----| | TSEG2[6:0] | | | | | | | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | SJW[6:0] | | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 1 | 1 | 1 | 1 | ### Bits 14:8 - TSEG2[6:0] Time Segment 2 bits (Phase Segment 2) | Value | Description | | |----------|--------------------------------|--| | 111 1111 | Length is 128 x T <sub>Q</sub> | | | | | | | 000 0000 | Length is 1 x T <sub>Q</sub> | | ## Bits 6:0 - SJW[6:0] Synchronization Jump Width bits | Value | Description | | |----------|--------------------------------|--| | 111 1111 | Length is 128 x T <sub>Q</sub> | | | | | | | 000 0000 | Length is 1 x T <sub>Q</sub> | | Controller Area Network Flexible Data-Rate (... ## 11.2.16 CAN Nominal Bit Time Configuration Register High Name: C1NBTCFGH<sup>(1)</sup> Offset: 0x6C6 #### Note: 1. These bits can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | | | | | BRP | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TSEG | 1[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | ### Bits 15:8 - BRP[7:0] Baud Rate Prescaler bits | Value | Description | |-----------|---------------------| | 1111 1111 | $T_Q = 256/F_{SYS}$ | | | | | 0000 0000 | $T_Q = 1/F_{SYS}$ | ### Bits 7:0 - TSEG1[7:0] Time Segment 1 bits (Propagation Segment + Phase Segment 1) | Value | Description | | |-----------|--------------------------------|--| | 1111 1111 | Length is 256 x T <sub>Q</sub> | | | | | | | 0000 0000 | Length is 1 x T <sub>Q</sub> | | Controller Area Network Flexible Data-Rate (... ## 11.2.17 CAN Data Bit Time Configuration Register Low Name: C1DBTCFGL<sup>(1)</sup> Offset: 0x6C8 #### Note: 1. This register can only be modified in Configuration mode (OPMOD[2:0] = 100). Bits 11:8 - TSEG2[3:0] Time Segment 2 bits (Phase Segment 2) | Value | Description | |-------|-------------------------------| | 1111 | Length is 16 x T <sub>Q</sub> | | | | | 0000 | Length is 1 x T <sub>Q</sub> | Bits 3:0 - SJW[3:0] Synchronization Jump Width bits | Value | Description | |-------|-------------------------------| | 1111 | Length is 16 x T <sub>Q</sub> | | | | | 0000 | Length is 1 x T <sub>Q</sub> | Controller Area Network Flexible Data-Rate (... ## 11.2.18 CAN Data Bit Time Configuration Register High Name: C1DBTCFGH<sup>(1)</sup> Offset: 0x6CA #### Note: 1. This register can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-----|-------|------------|-----|-----| | | | | | BRP | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TSEG1[4:0] | | | | Access | | • | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 1 | 1 | 1 | 0 | ### Bits 15:8 - BRP[7:0] Baud Rate Prescaler bits | Value | Description | |-----------|---------------------| | 1111 1111 | $T_Q = 256/F_{SYS}$ | | | | | 0000 0000 | $T_Q = 1/F_{SYS}$ | # Bits 4:0 - TSEG1[4:0] Time Segment 1 bits (Propagation Segment + Phase Segment 1) | Value | Description | | |--------|-------------------------------|--| | 1 1111 | Length is 32 x T <sub>Q</sub> | | | | | | | 0 0000 | Length is 1 x T <sub>Q</sub> | | # 11.2.19 CAN Transmitter Delay Compensation Register Low Name: C1TDCL<sup>(1)</sup> Offset: 0x6CC #### Note: 1. This register can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-----|-----|-----------|--------|-----|-----| | | | | | | TDCO[6:0] | | | | | Access | | R/W | Reset | | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | TDC | /[5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | Bits 14:8 - TDC0[6:0] Transmitter Delay Compensation Offset bits (Secondary Sample Point (SSP)) | Value | Description | |----------|------------------------| | 111 1111 | -64 x T <sub>SYS</sub> | | | | | 011 1111 | 63 x T <sub>SYS</sub> | | | | | 000 0000 | 0 x T <sub>SYS</sub> | Bits 5:0 - TDCV[5:0] Transmitter Delay Compensation Value bits (Secondary Sample Point (SSP)) | Value | Description | |---------|--------------------| | 11 1111 | F <sub>P</sub> | | • • | | | 00 0000 | 0 x F <sub>P</sub> | ### 11.2.20 CAN Transmitter Delay Compensation Register High Name: C1TDCH<sup>(1)</sup> Offset: 0x6CE #### Note: 1. This register can only be modified in Configuration mode (OPMOD[2:0] = 100). #### Bit 9 - EDGFLTEN Enable Edge Filtering During Bus Integration State bit | Value | Description | |-------|--------------------------------------------------------| | 1 | Edge filtering is enabled according to ISO11898-1:2015 | | 0 | Edge filtering is disabled | ### Bit 8 - SID11EN Enable 12-Bit SID in CAN FD Base Format Messages bit | ı | Value | Description | |---|-------|-------------------------------------------------------------------------------------| | | 1 | RRS is used as SID11 in CAN FD base format messages: SID[11:0] = {SID[10:0], SID11} | | | 0 | Does not use RRS; SID[10:0] | ### Bits 1:0 - TDCMOD[1:0] Transmitter Delay Compensation Mode bits (Secondary Sample Point (SSP)) | Value | Description | |-------|---------------------------------------------------------------------------| | 10-11 | Auto: Measures delay and adds TSEG1[4:0] (C1DBTCFGH[4:0]), adds TDCO[6:0] | | 01 | Manual: Does not measure, uses TDCV[5:0] + TDCO[6:0] from register | | 00 | Disabled | Controller Area Network Flexible Data-Rate (... ## 11.2.21 CAN Time Base Counter Register Low Name: C1TBCL<sup>(1,2)</sup> Offset: 0x6D0 #### Notes: 1. The Time Base Counter (TBC) will be stopped and reset when TBCEN = 0 to save power. 2. The TBC prescaler count will be reset on any write to C1TBCH/L (TBCPREx will be unaffected). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |----------|-----------|-----|-----|-----|-----|-----|-----|-----|--| | | TBC[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TBC[7:0] | | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ### Bits 15:0 - TBC[15:0] CAN Time Base Counter bits This is a free-running timer that increments every TBCPREx clock when TBCEN is set. Controller Area Network Flexible Data-Rate (... ## 11.2.22 CAN Time Base Counter Register High Name: C1TBCH<sup>(1,2)</sup> Offset: 0x6D2 #### Notes: 1. The Time Base Counter (TBC) will be stopped and reset when TBCEN = 0 to save power. 2. The TBC prescaler count will be reset on any write to C1TBCH/L (TBCPREx will be unaffected). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|------------|-----|-----|-------|--------|-----|-----|-----|--| | | TBC[31:24] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | TBC[2 | 23:16] | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ### Bits 15:0 - TBC[31:16] CAN Time Base Counter bits This is a free-running timer that increments every TBCPREx clock when TBCEN is set. Controller Area Network Flexible Data-Rate (... # 11.2.23 CAN Timestamp Control Register Low Name: C1TSCONL Offset: 0x6D4 Bits 9:0 - TBCPRE[9:0] CAN Time Base Counter Prescaler bits | Value | Description | |-------|----------------------------------| | 1023 | TBC increments every 1024 clocks | | | | | O | TBC increments every 1 clock | # Controller Area Network Flexible Data-Rate (... ## 11.2.24 CAN Timestamp Control Register High Name: C1TSCONH Offset: 0x6D6 ### Bit 2 - TSRES Timestamp Reset bit (CAN FD frames only) | Value | Description | |-------|--------------------------------------------------| | 1 | At sample point of the bit following the FDF bit | | 0 | At sample point of Start-of-Frame (SOF) | ## Bit 1 - TSEOF Timestamp End-of-Frame (EOF) bit | Value | Description | | | | | | | | |-------|-----------------------------------------------------|--|--|--|--|--|--|--| | 1 | Timestamp 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 | Timestamp at "beginning" of frame: | | | | | | | | | | Classical Frame: At sample point of SOF | | | | | | | | | | FD Frame: see TSRES bit | | | | | | | | #### Bit 0 - TBCEN Time Base Counter Enable bit | Value | Description | |-------|----------------------| | 1 | Enables TBC | | 0 | Stops and resets TBC | ## 11.2.25 CAN Interrupt Code Register Low Name: C1VECL Offset: 0x6D8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----|----|----|-------------|------------|----|---|---|--| | | | | | FILHIT[4:0] | | | | | | | Access | | | | R | R | R | R | R | | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | ICODE[6:0] | | | | | | Access | | R | R | R | R | R | R | R | | | Reset | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 12:8 - FILHIT[4:0] Filter Hit Number bits | Value | Description | |-------|-------------| | 01111 | Filter 15 | | 01110 | Filter 14 | | | | | 00001 | Filter 1 | | 00000 | Filter 0 | Bits 6:0 - ICODE[6:0] Interrupt Flag Code bits | Value | Description | |-----------------|--------------------------------------------------------------------------------------| | 1001011-1111111 | Reserved | | 1001010 | Transmit attempt interrupt (any bit in C1TXATIF is set) | | 1001001 | Transmit event FIFO interrupt (any bit in C1TEFSTA is set) | | 1001000 | Invalid message occurred (IVMIF/IE) | | 1000111 | CAN module mode change occurred (MODIF/IE) | | 1000110 | CAN timer overflow (TBCIF/IE) | | 1000101 | RX/TX MAB overflow/underflow (RX: Message received before previous message was saved | | | to memory; TX: Can't feed TX MAB fast enough to transmit consistent data) | | 1000100 | Address error interrupt (illegal FIFO address presented to system) | | 1000011 | Receive FIFO overflow interrupt (any bit in C1RXOVIF is set) | | 1000010 | Wake-up interrupt (WAKIF/WAKIE) | | 1000001 | Error interrupt (CERRIF/IE) | | 1000000 | No interrupt | | 0001000-0111111 | Reserved | | 0000111 | FIFO 7 interrupt (TFIF7 or RFIF7 is set) | | | | | 0000001 | FIFO 1 interrupt (TFIF1 or RFIF1 is set) | | 0000000 | FIFO 0 interrupt (TFIF0 is set) | # Controller Area Network Flexible Data-Rate (... # 11.2.26 CAN Interrupt Code Register High Name: C1VECH Offset: 0x6DA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------------|----|----|----|----|----|----|---|---| | RXCODE[6:0] | | | | | | | | | | Access | | R | R | R | R | R | R | R | | Reset | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TXCODE[6:0] | | | | | | | | | | Access | | R | R | R | R | R | R | R | | Reset | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 14:8 - RXCODE[6:0] Receive Interrupt Flag Code bits | Value | Description | |-----------------|---------------------------------| | 1000001-1111111 | Reserved | | 1000000 | No interrupt | | 0001000-0111111 | Reserved | | 0000111 | FIFO 7 interrupt (RFIF7 is set) | | | | | 0000010 | FIFO 2 interrupt (RFIF2 is set) | | 0000001 | FIFO 1 interrupt (RFIF1 is set) | | 000000 | Reserved; FIFO 0 cannot receive | Bits 6:0 - TXCODE[6:0] Transmit Interrupt Flag Code bits | | -pr. 129 - c 20 - c 10 | |-----------------|---------------------------------| | Value | Description | | 1000001-1111111 | Reserved | | 1000000 | No interrupt | | 0001000-0111111 | Reserved | | 0000111 | FIFO 7 interrupt (TFIF7 is set) | | | | | 0000001 | FIFO 1 interrupt (TFIF1 is set) | | 000000 | FIFO 0 interrupt (TFIF0 is set) | ### 11.2.27 CAN Interrupt Register Low Name: C1INTL Offset: 0x6DC Note: 1. C1INTL: Flags are set by hardware and cleared by application. Legend: C = Clearable bit; HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|--------|--------|--------|--------|------|------| | | IVMIF | WAKIF | CERRIF | SERRIF | RXOVIF | TXATIF | | | | Access | HS/C | HS/C | HS/C | HS/C | R | R | | - | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TEFIF | MODIF | TBCIF | RXIF | TXIF | | Access | | | | R | HS/C | HS/C | R | R | | Reset | | | | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - IVMIF Invalid Message Interrupt Flag bit(1) | Value | Description | |-------|------------------------------------| | 1 | Invalid message interrupt occurred | | 0 | No invalid message interrupt | #### Bit 14 - WAKIF Bus Wake-up Activity Interrupt Flag bit(1) | Value | Description | |-------|-------------------------------------| | 1 | Wake-up activity interrupt occurred | | 0 | No wake-up activity interrupt | # Bit 13 - CERRIF CAN Bus Error Interrupt Flag bit(1) | Value | Description | |-------|----------------------------------| | 1 | CAN bus error interrupt occurred | | 0 | No CAN bus error interrupt | ### Bit 12 - SERRIF System Error Interrupt Flag bit(1) | Value | Description | |-------|---------------------------------| | 1 | System error interrupt occurred | | 0 | No system error interrupt | #### Bit 11 - RXOVIF Receive Buffer Overflow Interrupt Flag bit | Value | Description | |-------|--------------------------------------------| | 1 | Receive buffer overflow interrupt occurred | | 0 | No receive buffer overflow interrupt | #### Bit 10 - TXATIF Transmit Attempt Interrupt Flag bit | Value | Description | |-------|-------------------------------------| | 1 | Transmit attempt interrupt occurred | | 0 | No transmit attempt interrupt | #### Bit 4 - TEFIF Transmit Event FIFO Interrupt Flag bit | DICT T | Et ii Hallstille Event i ii e interrupt i lag bit | |--------|---------------------------------------------------| | Value | Description | | 1 | Transmit event FIFO interrupt occurred | | 0 | No transmit event FIFO interrupt | #### Bit 3 - MODIF CAN Mode Change Interrupt Flag bit(1) # Controller Area Network Flexible Data-Rate (... | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | CAN module mode change occurred (OPMOD[2:0] have changed to reflect REQOP[2:0]) | | 0 | No mode change occurred | ### Bit 2 - TBCIF CAN Timer Overflow Interrupt Flag bit(1) | Value | Description | |-------|------------------------| | 1 | TBC has overflowed | | 0 | TBC has not overflowed | #### Bit 1 - RXIF Receive Object Interrupt Flag bit | Value | Description | |-------|------------------------------------------| | 1 | Receive object interrupt is pending | | 0 | No receive object interrupts are pending | ### Bit 0 - TXIF Transmit Object Interrupt Flag bit | ı | Value | Description | |---|-------|-------------------------------------------| | | 1 | Transmit object interrupt is pending | | | 0 | No transmit object interrupts are pending | **Datasheet** 70005452B-page 455 © 2021 Microchip Technology Inc. # Controller Area Network Flexible Data-Rate (... ## 11.2.28 CAN Interrupt Register High Name: C1INTH Offset: 0x6DE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|--------|--------|--------|--------|------|------| | | IVMIE | WAKIE | CERRIE | SERRIE | RXOVIE | TXATIE | | | | Access | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TEFIE | MODIE | TBCIE | RXIE | TXIE | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - IVMIE Invalid Message Interrupt Enable bit | Value | Description | |-------|---------------------------------------| | 1 | Invalid message interrupt is enabled | | 0 | Invalid message interrupt is disabled | #### Bit 14 - WAKIE Bus Wake-up Activity Interrupt Enable bit | Value | Description | |-------|----------------------------------------| | 1 | Wake-up activity interrupt is enabled | | 0 | Wake-up Activity Interrupt is disabled | #### Bit 13 - CERRIE CAN Bus Error Interrupt Enable bit | Value | Description | |-------|-------------------------------------| | 1 | CAN bus error interrupt is enabled | | 0 | CAN bus error interrupt is disabled | ## Bit 12 - SERRIE System Error Interrupt Enable bit | Value | Description | |-------|------------------------------------| | 1 | System error interrupt is enabled | | 0 | System error interrupt is disabled | #### Bit 11 - RXOVIE Receive Buffer Overflow Interrupt Enable bit | Value | Description | |-------|-----------------------------------------------| | 1 | Receive buffer overflow interrupt is enabled | | 0 | Receive buffer overflow interrupt is disabled | #### Bit 10 - TXATIE Transmit Attempt Interrupt Enable bit | Value | Description | |-------|----------------------------------------| | 1 | Transmit attempt interrupt is enabled | | 0 | Transmit attempt interrupt is disabled | ### Bit 4 - TEFIE Transmit Event FIFO Interrupt Enable bit | DIL 4 - IL | Bit 4 - ILI IL Transmit Event in O Interrupt Enable bit | | | |------------|---------------------------------------------------------|--|--| | Value | Description | | | | 1 | Transmit event FIFO interrupt is enabled | | | | 0 | Transmit event FIFO interrupt is disabled | | | #### Bit 3 - MODIE Mode Change Interrupt Enable bit | Value | Description | |-------|-----------------------------------| | 1 | Mode change interrupt is enabled | | 0 | Mode change interrupt is disabled | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 456 # Controller Area Network Flexible Data-Rate (... | Bit 2 – TBCIE CAN Timer Interrupt Enable bit | | | |----------------------------------------------|---------------------------------|--| | Value | Description | | | 1 | CAN timer interrupt is enabled | | | 0 | CAN timer interrupt is disabled | | #### Bit 1 - RXIE Receive Object Interrupt Enable bit | Value | Description | |-------|--------------------------------------| | 1 | Receive object interrupt is enabled | | 0 | Receive object interrupt is disabled | ### Bit 0 - TXIE Transmit Object Interrupt Enable bit | 1 | ∕alue | Description | |---|-------|---------------------------------------| | 1 | 1 | Transmit object interrupt is enabled | | ( | ) | Transmit object interrupt is disabled | Controller Area Network Flexible Data-Rate (... ## 11.2.29 CAN Receive Interrupt Status Register Low Name: C1RXIFL<sup>(1)</sup> Offset: 0x6E0 #### Note: 1. C1RXIFL: FIFO: RFIFx = 'or' of enabled RX FIFO flags (flags need to be cleared in the FIFO register). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|------------|----|----|----|----|----|---|---|--|--|--|--| | | RFIF[15:8] | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RFIF[7:1] | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | ### Bits 15:8 - RFIF[15:8] Unimplemented #### Bits 7:1 - RFIF[7:1] Receive FIFO Interrupt Pending bits | Value | Description | |-------|---------------------------------------------------------| | 1 | One or more enabled receive FIFO interrupts are pending | | 0 | No enabled receive FIFO interrupts are pending | Controller Area Network Flexible Data-Rate (... ## 11.2.30 CAN Receive Interrupt Status Register High Name: C1RXIFH<sup>(1)</sup> Offset: 0x6E2 #### Note: 1. C1RXIFH: FIFO: RFIFx = 'or' of enabled RX FIFO flags (flags need to be cleared in the FIFO register). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-------------|----|----|----|----|----|---|---|--|--|--|--| | | RFIF[31:24] | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RFIF[23:16] | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - RFIF[31:16] Unimplemented Controller Area Network Flexible Data-Rate (... ## 11.2.31 CAN Transmit Interrupt Status Register Low Name: C1TXIFL<sup>(1)</sup> Offset: 0x6E4 #### Notes: 1. C1TXIFL: FIFO: TFIFx = 'or' of the enabled TX FIFO flags (flags need to be cleared in the FIFO register). 2. TFIF0 is for the Transmit Queue. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|------------|----|----|----|----|----|---|---|--|--|--| | | TFIF[15:8] | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TFIF[7:0] | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 - TFIF[15:8] Unimplemented #### Bits 7:0 - TFIF[7:0] Transmit FIFO/TXQ Attempt Interrupt Pending bits(2) | Value | Description | |-------|--------------------------------------------------------------| | 1 | One or more enabled transmit FIFO/TXQ interrupts are pending | | 0 | No enabled transmit FIFO/TXQ interrupts are pending | Controller Area Network Flexible Data-Rate (... ## 11.2.32 CAN Transmit Interrupt Status Register High Name: C1TXIFH<sup>(1)</sup> Offset: 0x6E6 #### Note: 1. C1TXIFH: FIFO: TFIFx = 'or' of the enabled TX FIFO flags (flags need to be cleared in the FIFO register). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-------------|----|----|--------|--------|----|---|---|--|--|--|--| | | TFIF[31:24] | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | TFIF[: | 23:16] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - TFIF[31:16] Unimplemented Controller Area Network Flexible Data-Rate (... ## 11.2.33 CAN Receive Overflow Interrupt Status Register Low Name: C1RXOVIFL<sup>(1)</sup> Offset: 0x6E8 Note: 1. C1RXOVIFL: FIFO: RFOVIFx (flag needs to be cleared in the FIFO register). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|--------------|----|----|----|----|----|---|---|--|--|--|--| | | RFOVIF[15:8] | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RFOVIF[7:1] | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Bits 15:8 - RFOVIF[15:8] Unimplemented #### Bits 7:1 - RFOVIF[7:1] Receive FIFO Overflow Interrupt Pending bits | Value | Description | |-------|--------------------------| | 1 | Interrupt is pending | | 0 | Interrupt is not pending | Controller Area Network Flexible Data-Rate (... ## 11.2.34 CAN Receive Overflow Interrupt Status Register High Name: C1RXOVIFH<sup>(1)</sup> Offset: 0x6EA #### Note: 1. C1RXOVIFH: FIFO: RFOVIFx (flag needs to be cleared in the FIFO register). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | |--------|---------------|----|----|----|----|----|---|---|--|--|--|--|--| | | RFOVIF[31:24] | | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | RFOVIF[23:16] | | | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Bits 15:0 - RFOVIF[31:16] Unimplemented Controller Area Network Flexible Data-Rate (... ## 11.2.35 CAN Transmit Attempt Interrupt Status Register Low Name: C1TXATIFL<sup>(1)</sup> Offset: 0x6EC #### Notes: 1. C1TXATIFL: FIFO: TFATIFx (flag needs to be cleared in the FIFO register). 2. TFATIF0 is for the Transmit Queue. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|--------------|----|----|----|----|----|---|---|--|--|--| | | TFATIF[15:8] | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TFATIF[7:0] | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 - TFATIF[15:8] Unimplemented Bits 7:0 – TFATIF[7:0] Transmit FIFO/TXQ Attempt Interrupt Pending bits<sup>(2)</sup> | Value | Description | |-------|--------------------------| | 1 | Interrupt is pending | | 0 | Interrupt is not pending | Controller Area Network Flexible Data-Rate (... ## 11.2.36 CAN Transmit Attempt Interrupt Status Register High Name: C1TXATIFH<sup>(1)</sup> Offset: 0x6EE Note: 1. C1TXATIFH: FIFO: TFATIFx (flag needs to be cleared in the FIFO register). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|---------------|----|----|----|----|----|---|---|--| | | TFATIF[31:24] | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TFATIF[23:16] | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - TFATIF[31:16] Unimplemented Controller Area Network Flexible Data-Rate (... #### 11.2.37 CAN Transmit Request Register Low Name: C1TXREQL Offset: 0x6F0 Legend: S = Settable bit; HC = Hardware Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-----------------|------|------|------|------|------|------|------|--| | | TXREQ[15:8] | | | | | | | | | | Access | S/HC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TXREQ[7:1] TXRE | | | | | | | | | | Access | S/HC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:8 - TXREQ[15:8] Unimplemented #### Bits 7:1 - TXREQ[7:1] Message Send Request bits 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. This bit can NOT be used for aborting a transmission. TXEN = 0 (object configured as a receive object): This bit has no effect. #### Bit 0 - TXREQ0 Transmit Queue Message Send Request bit 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. This bit can NOT be used for aborting a transmission. # Controller Area Network Flexible Data-Rate (... ## 11.2.38 CAN Transmit Request Register High Name: C1TXREQH Offset: 0x6F2 Legend: S = Settable bit; HC = Hardware Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|--------------|------|------|------|------|------|------|------|--| | | TXREQ[31:24] | | | | | | | | | | Access | S/HC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TXREQ[23:17] | | | | | | | | | | Access | S/HC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:8 - TXREQ[31:24] Unimplemented Bits 7:1 - TXREQ[23:17] Unimplemented Bit 0 - TXREQ[16] Unimplemented # Controller Area Network Flexible Data-Rate (... ## 11.2.39 CAN Bus Diagnostics Register 0 Low Name: C1BDIAG0L Offset: 0x6F8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|---------------|-----|-----|-----|-----|-----|-----|-----|--| | | NTERRCNT[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | NRERRCNT[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:8 - NTERRCNT[7:0] Nominal Bit Rate Transmit Error Counter bits Bits 7:0 - NRERRCNT[7:0] Nominal Bit Rate Receive Error Counter bits Controller Area Network Flexible Data-Rate (... # 11.2.40 CAN Bus Diagnostics Register 0 High Name: C1BDIAG0H Offset: 0x6FA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------------|-----|-----|-----|-----|-----|-----|-----| | | DTERRCNT[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DRERRCNT[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:8 - DTERRCNT[7:0] Data Bit Rate Transmit Error Counter bits Bits 7:0 - DRERRCNT[7:0] Data Bit Rate Receive Error Counter bits Controller Area Network Flexible Data-Rate (... # 11.2.41 CAN Bus Diagnostics Register 1 Low Name: C1BDIAG1L Offset: 0x6FC | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------------|-----|-----|-----|-----|-----|-----|-----| | | EFMSGCNT[15:8] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | EFMSGCNT[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - EFMSGCNT[15:0] Error-Free Message Counter bits #### 11.2.42 CAN Bus Diagnostics Register 1 High Name: C1BDIAG1H Offset: 0x6FE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|-----|---------|----------|----------|---------|----------|----------| | | DLCMM | ESI | DCRCERR | DSTUFERR | DFORMERR | | DBIT1ERR | DBIT0ERR | | Access | R/W | R/W | R/W | R/W | R/W | - | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXBOERR | | NCRCERR | NSTUFERR | NFORMERR | NACKERR | NBIT1ERR | NBIT0ERR | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - DLCMM DLC Mismatch bit During a transmission or reception, the specified DLC is larger than the PLSIZE[2:0] of the FIFO element. Bit 14 - ESI ESI Flag of a Received CAN FD Message Set bit Bit 13 - DCRCERR Same as for nominal bit rate Bit 12 - DSTUFERR Same as for nominal bit rate Bit 11 - DFORMERR Same as for nominal bit rate Bit 9 - DBIT1ERR Same as for nominal bit rate Bit 8 - DBIT0ERR Same as for nominal bit rate Bit 7 - TXBOERR Device Went to Bus Off bit (and auto-recovered) #### Bit 5 - NCRCERR Received Message with CRC Incorrect Checksum bit The 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. #### Bit 4 - NSTUFERR Received Message with Illegal Sequence bit More than five equal bits in a sequence have occurred in a part of a received message where this is not allowed. #### Bit 3 - NFORMERR Received Frame Fixed Format bit A fixed format part of a received frame has the wrong format. #### Bit 2 - NACKERR Transmitted Message Not Acknowledged bit Transmitted message was not Acknowledged. #### Bit 1 - NBIT1ERR Transmitted Message Recessive Level bit During the 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. ### Bit 0 - NBIT0ERR Transmitted Message Dominant Level bit During the transmission of a message (or Acknowledge bit, active error flag or overload flag), the device wanted to send a dominant level (data or identifier bit of 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). © 2021 Microchip Technology Inc. Datasheet 70005452B-page 471 Controller Area Network Flexible Data-Rate (... # 11.2.43 CAN Message Memory Base Address Register Low Name: C1FIFOBAL Offset: 0x70C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------------------|-----|-----|-------|---------|-----|---------|-----| | | | | | FIFOB | A[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FIFOBA[7:2] FIFOBA[1:0] | | | | | | BA[1:0] | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Bits 15:8 – FIFOBA[15:8]** Message Memory Base Address bits Defines the base address for the transmit event FIFO followed by the message objects. Bits 7:2 - FIFOBA[7:2] Message Memory Base Address bits Bits 1:0 - FIFOBA[1:0] Message Memory Base Address bits Controller Area Network Flexible Data-Rate (... # 11.2.44 CAN Message Memory Base Address Register High Name: C1FIFOBAH Offset: 0x70E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------------------------|-----|-----|--------|----------|-----|----------|-----| | | | | | FIFOBA | \[31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FIFOBA[23:18] FIFOBA[17:16] | | | | | | 4[17:16] | | | Access | R/W | R/W | R/W | R/W | R/W | R/W | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Bits 15:8 – FIFOBA[31:24]** Message Memory Base Address bits Defines the base address for the transmit event FIFO followed by the message objects. Bits 7:2 - FIFOBA[23:18] Message Memory Base Address bits Bits 1:0 - FIFOBA[17:16] Message Memory Base Address bits ### 11.2.45 CAN Transmit Queue Control Register Low Name: C1TXQCONL Offset: 0x710 Legend: HS = Hardware Settable bit; C = Clearable bit #### Bit 10 - FRESET FIFO Reset bit | Value | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------| | 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 | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | Requests sending a message; the bit will automatically clear when all the messages queued in the | | | TXQ 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 bit #### Bit 4 - TXATIE Transmit Attempts Exhausted Interrupt Enable bit | Value | Description | |-------|--------------------| | 1 | Enables interrupt | | 0 | Disables interrupt | # Bit 2 - TXQEIE Transmit Queue Empty Interrupt Enable bit | Value | Description | |-------|-------------------------------------| | 1 | Interrupt is enabled for TXQ empty | | 0 | Interrupt is disabled for TXQ empty | #### Bit 0 - TXQNIE Transmit Queue Not Full Interrupt Enable bit | Value | Description | |-------|----------------------------------------| | 1 | Interrupt is enabled for TXQ not full | | 0 | Interrupt is disabled for TXQ not full | # Controller Area Network Flexible Data-Rate (... ### 11.2.46 CAN Transmit Queue Control Register High Name: C1TXQCONH **Offset:** 0x712 #### Note: 1. These bits can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----------|-----|-----|------------|-----|-----|-----|--|--| | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TXAT[1:0] | | | TXPRI[4:0] | | | | | | | Access | | R/W | | | Reset | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | | ### Bits 15:13 - PLSIZE[2:0] Payload Size bits(1) | | · | |-------|---------------| | Value | Description | | 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 | | | | #### Bits 12:8 - FSIZE[4:0] FIFO Size bits(1) | Value | Description | |-------|--------------------------| | 11111 | FIFO is 32 messages deep | | | | | 00010 | FIFO is 3 messages deep | | 00001 | FIFO is 2 messages deep | | 00000 | FIFO is 1 message deep | #### Bits 6:5 - TXAT[1:0] Retransmission Attempts bits This feature is enabled when RTXAT (C1CONH[0]) is set. | Value | Description | |-------|---------------------------------------------| | 11 | Unlimited number of retransmission attempts | | 10 | Unlimited number of retransmission attempts | | 01 | Three retransmission attempts | | 00 | Disables retransmission attempts | ### Bits 4:0 - TXPRI[4:0] Message Transmit Priority bits | Value | Description | |-------|--------------------------| | 11111 | Highest message priority | | | | | 00000 | Lowest message priority | # Controller Area Network Flexible Data-Rate (... #### 11.2.47 CAN Transmit Queue Status Register Name: C1TXQSTAL Offset: 0x714 #### Notes: - 1. The TXQCI[4:0] bits give a zero-indexed value to the message in the TXQ. If the TXQ is four messages deep (FSIZE[4:0] = 3), TXQCIx will take on a value of 0 to 3, depending on the state of the TXQ. - 2. This bit is updated when a message completes (or aborts) or when the TXQ is reset. #### Legend: HS = Hardware Settable bit; C = Clearable bit # Bits 12:8 - TXQCI[4:0] Transmit Message Queue 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(2) | Value | Description | |-------|--------------------------------| | 1 | Message was aborted | | 0 | Message completed successfully | #### Bit 6 - TXLARB Message Lost Arbitration Status bit | | THE THE MESSAGE LOST MINICIANO DIC | | | | | | | | |-------|---------------------------------------------------|--|--|--|--|--|--|--| | Value | Description | | | | | | | | | 1 | Message lost arbitration while being sent | | | | | | | | | 0 | Message did not lose arbitration while being sent | | | | | | | | #### Bit 5 - TXERR Error Detected During Transmission bit | Value | Description | |-------|------------------------------------------------------------| | 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 | Value | Description | |-------|--------------------------| | 1 | Interrupt is pending | | 0 | Interrupt is not pending | ## Bit 2 - TXQEIF Transmit Queue Empty Interrupt Flag bit | Value | Description | |-------|--------------------------------------------------------------------| | 1 | TXQ is empty | | 0 | TXQ is not empty, at least one message is queued to be transmitted | #### Bit 0 - TXQNIF Transmit Queue Not Full Interrupt Flag bit | Value | Description | |-------|-----------------| | 1 | TXQ is not full | | 0 | TXQ is full | © 2021 Microchip Technology Inc. and its subsidiaries Controller Area Network Flexible Data-Rate (... # 11.2.48 CAN Transmit Queue User Address Register Low Name: C1TXQUAL<sup>(1)</sup> Offset: 0x718 #### Note: 1. This register is not ensured to read correctly in Configuration mode and should only be accessed when the module is not in Configuration mode. #### Legend: x = Bit is unknown | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |-------------|--------|-----------|-------------------|-------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--| | TXQUA[15:8] | | | | | | | | | | R | R | R | R | R | R | R | R | | | X | X | X | X | X | X | X | X | | | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXQUA[7:0] | | | | | | | | | | R | R | R | R | R | R | R | R | | | X | X | X | X | X | X | X | X | | | | R<br>x | R R X 7 6 | R R R X X X 7 6 5 | TXQU. R R R R X X X X 7 6 5 4 TXQU. R R R R | TXQUA[15:8] R R R R R X X X X X 7 6 5 4 3 TXQUA[7:0] R R R R R X Y Y Y Y | TXQUA[15:8] R R R R R R X X X X X X 7 6 5 4 3 2 TXQUA[7:0] R R R R R R R X Y Y Y Y Y | TXQUA[15:8] R R R R R R R R X X X X X X X 7 6 5 4 3 2 1 TXQUA[7:0] R R R R R R R R X Y Y Y Y Y Y Y Y | | #### Bits 15:0 - TXQUA[15:0] TXQ User Address bits A read of this register will return the address where the next message is to be written (TXQ head). Controller Area Network Flexible Data-Rate (... # 11.2.49 CAN Transmit Queue User Address Register High Name: C1TXQUAH<sup>(1)</sup> Offset: 0x71A #### Note: This register is not ensured to read correctly in Configuration mode and should only be accessed when the module is not in Configuration mode. #### Legend: x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------------|----|----|----|----|----|---|---| | | TXQUA[31:24] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXQUA[23:16] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | X | X | X | X | X | X | X | X | #### Bits 15:0 - TXQUA[31:16] TXQ User Address bits A read of this register will return the address where the next message is to be written (TXQ head). #### 11.2.50 CAN FIFO Control Register x Low (x = 1 to 7) Name: C1FIFOCONxL **Offset:** 0x71C, 0x728, 0x734, 0x740, 0x74C, 0x758, 0x764 Note: 1. This bit can only be modified in Configuration mode (OPMOD[2:0] = 100). Legend: S = Settable bit; HC = Hardware Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|-------|--------|--------|--------|----------|----------|----------| | | | | | | | FRESET | TXREQ | UINC | | Access | | | | | | S/HC | R/W/HC | S/HC | | Reset | | | | | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXEN | RTREN | RXTSEN | TXATIE | RXOVIE | TFERFFIE | TFHRFHIE | TFNRFNIE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 10 - FRESET FIFO Reset bit | Value | Description | | | | | |-------|------------------------------------------------------------------------------------------------------|--|--|--|--| | 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 TXEN = 0 (FIFO configured as a receive FIFO): This bit has no effect. TXEN = 1 (FIFO configured as a transmit FIFO): | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 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 | ### 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 | Value | ue Description | | |-------|--------------------------|--| | 1 | Transmits message object | | | 0 | Receives message object | | ### Bit 6 - RTREN Auto-Remote Transmit (RTR) Enable bit | Value | Description | |-------|--------------------------------------------------------------| | 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 Timestamp Enable bit(1) | Value | Description | |-------|------------------------------------------------------| | 1 | Captures timestamp in received message object in RAM | | 0 | Does not capture timestamp | #### Bit 4 - TXATIE Transmit Attempts Exhausted Interrupt Enable bit ### Controller Area Network Flexible Data-Rate (... | Value | Description | |-------|--------------------| | 1 | Enables interrupt | | 0 | Disables interrupt | #### Bit 3 - RXOVIE Overflow Interrupt Enable bit | Value | Description | |-------|------------------------------------------| | 1 | Interrupt is enabled for overflow event | | 0 | Interrupt is disabled for overflow event | #### 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 is enabled for FIFO empty - 0 = Interrupt is disabled for FIFO empty TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Full Interrupt Enable. - 1 = Interrupt is enabled for FIFO full - 0 = Interrupt is 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 is enabled for FIFO half empty - 0 = Interrupt is disabled for FIFO half empty TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Half Full Interrupt Enable. - 1 = Interrupt is enabled for FIFO half full - 0 = Interrupt is 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 is enabled for FIFO not full - 0 = Interrupt is disabled for FIFO not full TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Not Empty Interrupt Enable. - 1 = Interrupt is enabled for FIFO not empty - 0 = Interrupt is disabled for FIFO not empty # 11.2.51 CAN FIFO Control Register x High (x = 1 to 7) Name: C1FIFOCONxH **Offset:** 0x71E, 0x72A, 0x736, 0x742, 0x74C, 0x75A, 0x766 #### Note: 1. These bits can only be modified in Configuration mode (OPMOD[2:0] = 100). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-------------|--------|-----|-----|------------|-----|-----| | | | PLSIZE[2:0] | | | | FSIZE[4:0] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TXA | Γ[1:0] | | | TXPRI[4:0] | | | | Access | | R/W | Reset | | 1 | 1 | 0 | 0 | 0 | 0 | 0 | #### Bits 15:13 - PLSIZE[2:0] Payload Size bits(1) | Value | Description | |-------|---------------| | 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 | #### Bits 12:8 - FSIZE[4:0] FIFO Size bits(1) | Value | Description | |-------|--------------------------| | 11111 | FIFO is 32 messages deep | | | | | 00010 | FIFO is 3 messages deep | | 00001 | FIFO is 2 messages deep | | 00000 | FIFO is 1 message deep | # Bits 6:5 - TXAT[1:0] Retransmission Attempts bits This feature is enabled when RTXAT (C1CONH[0]) is set. | Value | Description | |-------|---------------------------------------------| | 11 | Unlimited number of retransmission attempts | | 10 | Unlimited number of retransmission attempts | | 01 | Three retransmission attempts | | 00 | Disables retransmission attempts | ### Bits 4:0 - TXPRI[4:0] Message Transmit Priority bits | Value | Description | | | |-------|--------------------------|--|--| | 11111 | Highest message priority | | | | | | | | | 00000 | Lowest message priority | | | ## Controller Area Network Flexible Data-Rate (... ## 11.2.52 CAN FIFO Status Register x (x = 1 to 7) Name: C1FIFOSTA **Offset:** 0x720, 0x72C, 0x738, 0x744, 0x750, 0x75C, 0x768 #### Notes: - 1. FIFOCI[4:0] bits give a zero-indexed value to the message in the FIFO. If the FIFO is four messages deep (FSIZE[4:0] = 3), FIFOCIx will take on a value of 0 to 3, depending on the state of the FIFO. - 2. These bits are updated when a message completes (or aborts) or when the FIFO is reset. - This bit is reset on any read of this register or when the TXQ is reset. The bits are cleared when TXREQ is set or using an SPI write. Legend: HS = Hardware Settable bit; C = Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|--------|-------|--------|--------|-------------|----------|----------| | | | | | | | FIFOCI[4:0] | | | | Access | | | | R | R | R | R | R | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXABT | TXLARB | TXERR | TXATIF | RXOVIF | TFERFFIF | TFHRFHIF | TFNRFNIF | | Access | R | R | R | HS/C | HS/C | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 12:8 - FIFOCI[4:0] FIFO Message Index bits(1) 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(3) | Value | Description | |-------|--------------------------------| | 1 | Message was aborted | | 0 | Message completed successfully | #### Bit 6 - TXLARB Message Lost Arbitration Status bit(2) | Value | Description | |-------|---------------------------------------------------| | 1 | Message lost arbitration while being sent | | 0 | Message did not lose arbitration while being sent | #### Bit 5 - TXERR Error Detected During Transmission bit(2) | Value | Description | |-------|------------------------------------------------------------| | 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 = 0 (FIFO configured as a receive buffer): Unused, read as '0'. TXEN = 1 (FIFO configured as a transmit buffer): | Value | Description | |-------|--------------------------| | 1 | Interrupt is pending | | 0 | Interrupt is not pending | #### Bit 3 - RXOVIF Receive FIFO Overflow Interrupt Flag bit TXEN = 1 (FIFO configured as a transmit buffer): Unused, read as '0'. # Controller Area Network Flexible Data-Rate (... TXEN = 0 (FIFO configured as a receive buffer): | Value | Description | |-------|--------------------------------| | 1 | Overflow event has occurred | | 0 | No overflow event has occurred | #### 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 is 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 ≤ half full 0 = FIFO is > half full TXEN = 0 (FIFO configured as a receive FIFO): Receive FIFO Half Full Interrupt Flag. 1 = FIFO is ≥ half full 0 = FIFO is < 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 # Controller Area Network Flexible Data-Rate (... ### 11.2.53 CAN FIFO User Address Register x Low (x = 1 to 7) Name: C1FIFOUAxL<sup>(1)</sup> **Offset:** 0x724, 0x730, 0x73C, 0x748, 0x754, 0x760, 0x76C #### Note: 1. This register is not ensured to read correctly in Configuration mode and should only be accessed when the module is not in Configuration mode. #### Legend: x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-------|---------|----|---|---| | | | | | FIFOU | A[15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | X | X | X | X | X | X | X | X | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FIFOL | JA[7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | × | X | X | X | X | X | X | X | #### Bits 15:0 - FIFOUA[15: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). # Controller Area Network Flexible Data-Rate (... # 11.2.54 CAN FIFO User Address Register x High (x = 1 to 7) Name: C1FIFOUAxH<sup>(1)</sup> **Offset:** 0x726, 0x732, 0x73E, 0x74A, 0x756, 0x762, 0x76E #### Note: 1. This register is not ensured to read correctly in Configuration mode and should only be accessed when the module is not in Configuration mode. #### Legend: x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-------|----------|----|---|---| | | | | | FIFOU | A[31:24] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FIFOU | 4[23:16] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | x | X | X | X | x | X | X | x | Bits 15:0 - FIFOUA[31:16] 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). # Controller Area Network Flexible Data-Rate (... # 11.2.55 CAN Filter Control Register x Low (x = 0 to 3; a = 0, 4, 8, 12; b = 1, 5, 9, 13) Name: C1FLTCONxL **Offset:** 0x770, 0x774, 0x778, 0x77C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|----|-----|-----|-----------|-----|-----| | | FLTENb | | | | | FbBP[4:0] | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FLTENa | | | | | FaBP[4:0] | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - FLTENb Enable Filter b to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | ### Bits 12:8 - FbBP[4:0] Pointer to Object When Filter b Hits bits | DIG 12.0 1 DD1 [4.0 | 1 Touritor to Object When I little britte bite | |---------------------|---------------------------------------------------------------| | Value | Description | | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | • • | | | 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 can't receive messages | ## Bit 7 - FLTENa Enable Filter a to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | # Bits 4:0 - FaBP[4:0] Pointer to Object When Filter a Hits bits | Value | Description | |-------------|---------------------------------------------------------------| | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | • • • | | | 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 can't receive messages | # Controller Area Network Flexible Data-Rate (... # 11.2.56 CAN Filter Control Register x High (x = 0 to 3; c = 2, 6, 10, 14; d = 3, 7, 11, 15) Name: C1FLTCONxH **Offset:** 0x772, 0x776, 0x77A, 0x77E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|----|-----|-----|-----------|-----|-----| | | FLTENd | | | | | FdBP[4:0] | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FLTENc | | | | | FcBP[4:0] | | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - FLTENd Enable Filter d to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | #### Bits 12:8 - FdBP[4:0] Pointer to Object When Filter d Hits bits | Value | Description | |-------------|---------------------------------------------------------------| | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | | | | 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 can't receive messages | ## Bit 7 - FLTENc Enable Filter c to Accept Messages bit | Value | Description | |-------|--------------------| | 1 | Filter is enabled | | 0 | Filter is disabled | ### Bits 4:0 - FcBP[4:0] Pointer to Object When Filter c Hits bits | Value | Description | |--------------|---------------------------------------------------------------| | 11111-11000 | Reserved | | 00111 | Message matching filter is stored in Object 7 | | 00110 | Message matching filter is stored in Object 6 | | <b>4</b> • • | | | 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 can't receive messages | Controller Area Network Flexible Data-Rate (... # 11.2.57 CAN Filter Object Register x Low (x = 0 to 15) Name: C1FLTOBJxL **Offset:** 0x780, 0x788, 0x790, 0x798, 0x7A0, 0x7A8, 0x7B0, 0x7B8, 0x7C0, 0x7C8, 0x7D0, 0x7D8, 0x7E0, 0x7E8, 0x7F0, 0x7F8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|----------|-----|-------|-----|-----------|-----| | | | | EID[4:0] | | | | SID[10:8] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | SID | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:11 - EID[4:0] Extended Identifier Filter bits In DeviceNet<sup>™</sup> mode, these are the filter bits for the first two data bytes. Bits 10:0 - SID[10:0] Standard Identifier Filter bits # Controller Area Network Flexible Data-Rate (... # 11.2.58 CAN Filter Object Register x High (x = 0 to 15) Name: C1FLTOBJxH **Offset:** 0x782, 0x78A, 0x792,0x79A, 0x7A2, 0x7AA, 0x7B2, 0x7BA, 0x7C2, 0x7CA, 0x7D2, 0x7DA, 0x7E2, 0x7EA, 0x7F2, 0x7FA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-------|-------|------|-------|------------|-----|-----| | | | EXIDE | SID11 | | | EID[17:13] | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | EID[ | 12:5] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bit 14 - EXIDE Extended Identifier Enable bit If MIDE = 1: | Value | Description | |-------|----------------------------------------------------------| | 1 | Matches only messages with Extended Identifier addresses | | 0 | Matches only messages with Standard Identifier addresses | #### Bit 13 - SID11 Standard Identifier Filter bit ### Bits 12:0 - EID[17:5] Extended Identifier Filter bits In DeviceNet<sup>™</sup> mode, these are the filter bits for the first two data bytes. # Controller Area Network Flexible Data-Rate (... # 11.2.59 CAN Mask Register x Low (x = 0 to 15) Name: C1MASKxL **Offset:** 0x784, 0x78C, 0x794, 0x79C, 0x7A4, 0x7AC, 0x7B4, 0x7BC, 0x7C4, 0x7CC, 0x7D4, 0x7DC, 0x7E4, 0x7EC, 0x7F4, 0x7FC | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----------|-----|--------|------------|-----|-----| | | | | MEID[4:0] | | | MSID[10:8] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | MSI | 0[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:11 - MEID[4:0] Extended Identifier Mask bits In DeviceNet<sup>™</sup> mode, these are the mask bits for the first two data bytes. Bits 10:0 - MSID[10:0] Standard Identifier Mask bits # Controller Area Network Flexible Data-Rate (... # 11.2.60 CAN Mask Register x High (x = 0 to 15) Name: C1MASKxH **Offset:** 0x786, 0x78E, 0x796, 0x79E, 0x7A6, 0x7AE, 0x7B6, 0x7BE, 0x7C6, 0x7CE, 0x7D6, 0x7DE, 0x7E6, 0x7EE, 0x7F6, 0x7FE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|------|--------|------|--------|-------------|-----|-----| | | | MIDE | MSID11 | | | MEID[17:13] | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | MEID | [12:5] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bit 14 - MIDE Identifier Receive Mode bit | Value | Description | |-------|---------------------------------------------------------------------------------------------------| | 1 | Matches only message types (standard or extended address) that correspond to the EXIDE bit in the | | | filter | | 0 | Matches 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 13 - MSID11 Standard Identifier Mask bit ### Bits 12:0 - MEID[17:5] Extended Identifier Mask bits In DeviceNet<sup>™</sup> mode, these are the mask bits for the first two data bytes. # 12. High-Resolution PWM with Fine Edge Placement **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**High-Resolution PWM with Fine Edge Placement**" (www.microchip.com/DS70005320) in the "dsPIC33/PIC24 Family Reference Manual". The High-Speed PWM (HSPWM) module is a Pulse-Width Modulated (PWM) module to support both motor control and power supply applications. This flexible module provides features to support many types of Motor Control (MC) and Power Control (PC) applications, including: - · AC-to-DC Converters - DC-to-DC Converters - · AC and DC Motors: BLDC, PMSM, ACIM, SRM, etc. - Inverters - Battery Chargers - Digital Lighting - · Power Factor Correction (PFC) #### Table 12-1. PWM Output Availability | Package Type | Total PGx Instances | Dedicated Outputs | Dedicated + PPS Outputs | |--------------|---------------------|-------------------|-------------------------| | 80-pin | 8 | 8 pairs | 8 pairs | | 64-pin | 8 | 8 pairs | 8 pairs | | 48-Pin | 8 | 8 pairs | 8 pairs | #### 12.1 Features - · Operating modes: - Independent Edge mode - Variable Phase PWM mode - Center-Aligned mode - Double-Update Center-Aligned mode - Dual Edge Center-Aligned mode - Dual PWM mode - Output modes: - Complementary - Independent - Push-Pull - · Dead-Time Generator - Leading-Edge Blanking (LEB) - Output Override for Fault Handling - · Flexible Period/Duty Cycle Updating Options - Programmable Control Inputs (PCI) - · Advanced Triggering Options - · Six Combinatorial Logic Outputs - · Six PWM Event Outputs #### 12.2 Architecture Overview The PWM module consists of a common set of controls and features, and multiple instantiations of PWM Generators (PGs). Each PWM Generator can be independently configured or multiple PWM Generators can be used to achieve complex multiphase systems. PWM Generators can also be used to implement sophisticated triggering, protection and logic functions. A high-level block diagram is shown in Figure 12-1. Figure 12-1. PWM High-Level Block Diagram #### 12.3 Lock and Write Restrictions The LOCK bit (PCLKCON[8]) may be set in software to block writes to certain registers. For more information, refer to "High-Resolution PWM with Fine Edge Placement" (www.microchip.com/DS70005320) in the "dsPIC33/PIC24 Family Reference Manual." The following lock/unlock sequence is required to set or clear the LOCK bit. - Write 0x55 to NVMKEY. - 2. Write 0xAA to NVMKEY. - 3. Clear (or set) the LOCK bit (PCLKCON[8]) as a single operation. In general, modifications to configuration controls should not be done while the module is running, as indicated by the ON bit (PGxCONL[15]) being set. #### 12.4 PWM4H/L Output on Peripheral Pin Select All devices support the capability to output PWM4H and PWM4L signals via Peripheral Pin Select (PPS) on to any "RPn" pin. This feature is intended for lower pin count devices that do not have PWM4H/L on dedicated pins. Configuration bit, DUPWM (FDEVOP1[12]), provides the option to disable the fixed pin PWM4L/H functions when using the PPS. Clearing the DUPPWM bit will disable PWM4 function and allow the pin to be used for another purpose. Leaving the DUPPWM set (default) will output PWM4 on both fixed pin and PPS outputs. The output port enable bits, PENH and PENL (PGxIOCONH[3:2]), control output function for both dedicated and PPS pins outputs If PWM4H/L PPS output functions are used on devices that also have fixed PWM4H/L pins, the output signal will be present on both dedicated and "RPn" pins. The output port enable bits, PENH and PENL (PGxIOCONH[3:2]), control both dedicated and PPS pins together; it is not possible to disable the dedicated pins and use only PPS. # **High-Resolution PWM with Fine Edge Placement** Given the natural priority of the "RPn" functions above that of the PWM, it is possible to use the PPS output functions on the dedicated PWM4H/L pins, while the PWM4 signals are routed to other pins via PPS. Any of the peripheral outputs listed in Table 8-6, with the exception of 'Default Port', can be used. Input functions, including the ports and peripherals listed in 8.7 Virtual Connections, cannot be used through the "RPn" function on dedicated PWM4H/L pins when PWM4 is active. # 12.5 PWM Control/Status Registers There are two categories of Special Function Registers (SFRs) used to control the operation of the PWM module: - · Common, shared by all PWM Generators - · PWM Generator-specific An 'x' in the register name denotes an instance of a PWM Generator. A 'y' in the register name denotes an instance of the common function. # 12.6 Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|-----------------------------------------|-------------|-----------------------------------------|-------------------------------------------|-----------------|---------------------------------------|------------------|-----------------------------|------------------------|------------------------------------------|--| | 00000 | DOLKOON | 15:8 | HRRDY | HRERR | | | | | | LOCK | | | 0x0300 | PCLKCON | 7:0 | | | DIVSE | EL[1:0] | | | MCLKS | EL[1:0] | | | 0x0302 | FSCL | 15:8 | | | | FSCL | [15:8] | | | | | | 0x0302 | FSCL | 7:0 | | FSCL[7:0] | | | | | | | | | 0x0304 | FSMINPER | 15:8 | | | | FSMINP | ER[15:8] | | | | | | 0,0004 | TOWNIN LIX | 7:0 | | | | FSMINF | PER[7:0] | | | | | | 0x0306 | MPHASE | 15:8 | | | | MPHAS | | | | | | | UNUUUU | | 7:0 | | MPHASE[7:0] | | | | | | | | | 0x0308 | MDC | 15:8 | | | | MDC | | | | | | | | | 7:0 | | | | MDC | | | | | | | 0x030A | MPER | 15:8 | | | | MPER | 45 54 | | | | | | | Mark amaza | 7:0 | | | | MPE | | | | | | | 0x030C | LFSR | 15:8 | | | | | LFSR[14:8] | | | | | | | | 7:0 | | | 1 | LFSF | R[7:0] | I | 18 | | | | 0x030E | CMBTRIGL | 15:8 | 200000000000000000000000000000000000000 | - Avenue VIII - Marie II | Marine Marine B | Towns thousand | Tracked Williams | Marca de Avertos B | F 60 CONTROL IN | To 1100 1100 1100 1100 1100 1100 1100 11 | | | | | 7:0 | CTA8EN | CTA7EN | CTA6EN | CTA5EN | CTA4EN | CTA3EN | CTA2EN | CTA1EN | | | 0x0310 | <b>CMBTRIGH</b> | 15:8 | OTDOEN | OTDZEN | OTDOEN | OTDEEN | OTDAEN | OTDOEN | OTDOEN | OTDAEN | | | | 100000000000000000000000000000000000000 | 7:0 | CTB8EN | CTB7EN | CTB6EN | CTB5EN | CTB4EN | CTB3EN | CTB2EN | CTB1EN | | | 0x0312 | LOGCONA(2) | 15:8 | 044001 | | 51A[3:0] | EA14.01 | | | 2A[3:0] | • | | | | 2 19 | 7:0 | S1APOL | S2APOL | | FA[1:0] | | 1 | PWMLFAD[2:0] | | | | 0x0314 | LOGCONB(2) | 15:8 | CARROL | S2BPOL | 51B[3:0] | ED[4:0] | | | 2B[3:0]<br>PWMLFBD[2:0 | 1 | | | | | 7:0 | S1BPOL | | | FB[1:0] | | | | l | | | 0x0316 | LOGCONC(2) | 15:8<br>7:0 | CANDOL | | S1y[3:0] | F./[4:0] | | | 32y[3:0] | 1 | | | | | 15:8 | S1yPOL | S2yPOL | | Fy[1:0] | | 1 | PWMLFyD[2:0] | | | | 0x0318 | LOGCOND(2) | 7:0 | CADDOL | S2DPOL | 1D[3:0] | FD[1:0] | | | 2D[3:0] | 1 | | | | | 15:8 | S1DPOL | | 1E[3:0] | רט[ו.ט] | | | PWMLFDD[2:0] | | | | 0x031A | LOGCONE(2) | 7:0 | S1EPOL | S2EPOL | | FE[1:0] | | PWMS2E[3:0]<br>PWMLFED[2:0] | | | | | | | 15:8 | SILFOL | 0.000.000 | 31F[3:0] | 1 L[1.0] | | | 2F[3:0] | l | | | 0x031C | LOGCONF(2) | 7:0 | S1FPOL | S2FPOL | | FF[1:0] | | | PWMLFFD[2:0] | 1 | | | | | 15:8 | EVTAOEN | EVTAPOL | EVTASTRD | EVTASYNC | | | WINET DES.O. | | | | 0x031E | PWMEVTA(5) | 7:0 | LVIAOLIV | | EL[3:0] | LVIAOTIVO | | | EVTAPGS[2:0] | | | | | | 15:8 | EVTBOEN | EVTBPOL | EVTBSTRD | EVTBSYNC | | | | | | | 0x0320 | PWMEVTB(5) | 7:0 | | | SEL[3:0] | | | | EVTBPGS[2:0] | | | | | Start and market than | 15:8 | EVTCOEN | EVTCPOL | EVTCSTRD | EVTCSYNC | | | | | | | 0x0322 | PWMEVTC(5) | 7:0 | | 5-10-00-00-00-00-00-00-00-00-00-00-00-00- | SEL[3:0] | | | | EVTCPGS[2:0] | | | | | | 15:8 | EVTDOEN | EVTDPOL | EVTDSTRD | EVTDSYNC | | | | | | | 0x0324 | PWMEVTD(5) | 7:0 | | EVTDS | SEL[3:0] | S S S S S S S S S S S S S S S S S S S | | | EVTDPGS[2:0] | | | | | | 15:8 | EVTyOEN | EVTyPOL | EVTySTRD | EVTySYNC | | | | | | | 0x0326 | PWMEVTE(5) | 7:0 | CO. 16 - CO. 16 - S. 3 | | EL[3:0] | | | | EVTyPGS[2:0] | | | | 0.0000 | DIAMAEN (TE/E) | 15:8 | EVTFOEN | EVTFPOL | EVTFSTRD | EVTFSYNC | | | | | | | 0x0328 | PWMEVTF(5) | 7:0 | | EVTFS | SEL[3:0] | | | | EVTFPGS[2:0] | | | | 0,0224 | DCOCONI | 15:8 | ON | Reserved | | | | | TRGCNT[2:0] | | | | 0x032A | PG0CONL | 7:0 | HREN | | | CLKS | EL[1:0] | | MODSEL[2:0] | | | | 0x032C | PG0CONH | 15:8 | MDCSEL | MPERSEL | MPHSEL | | MSTEN | | UPMOD[2:0] | | | | UXU32C | -GUCUNH | 7:0 | Reserved | TRGMOD | | | | SOC | S[3:0] | | | | 0x032E | PG0STAT | 15:8 | SEVT | FLTEVT | CLEVT | FFEVT | SACT | FLTACT | CLACT | FFACT | | | UXU3ZE | FOUSTAI | 7:0 | TRSET | TRCLR | CAP | UPDATE | UPDREQ | STEER | CAHALF | TRIG | | | 0x0330 | PG0IOCONL | 15:8 | CLMOD | SWAP | OVRENH | OVRENL | OVRD | AT[1:0] | OSYN | C[1:0] | | | 0,0000 | TOUIOCOINE | 7:0 | FLTD | AT[1:0] | | T[1:0] | FFDA | T[1:0] | DBDA | | | | 0x0332 | PG0IOCONH | 15:8 | | | CAPSRC[2:0] | | | | | DTCMPSEL | | | 0,0002 | TOUCONH | 7:0 | | | PMO | D[1:0] | PENH | PENL | POLH | POLL | | | 0x0334 | PG0EVTL | 15:8 | | | ADTR1PS[4:0] | | | ADTR1EN3 | ADTR1EN2 | ADTR1EN1 | | | 0,0004 | OULVIL | 7:0 | | | | UPDTF | RG[1:0] | 1, | PGTRGSEL[2:0 | - | | | 0x0336 | PG0EVTH | 15:8 | FLTIEN | CLIEN | FFIEN | SIEN | | | IEVTS | EL[1:0] | | | | , 2021, 111 | 7:0 | ADTR2EN3 | ADTR2EN2 | ADTR2EN1 | | , | ADTR10FS[4:0 | )] | | | | conti | nued | | | | | | | | | | |--------|-------------------------------------|-----------|------------------------------|----------|--------------|-----------------|------------------------|--------------|--------------|----------------------------------------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Oliset | Name | | | ۰ | | 4 | | | | <u> </u> | | 0x0338 | PGxyPCIL | 15:8 | TSYNCDIS | 50,410 | TERM[2:0] | | AQPS | Door4 01 | AQSS[2:0] | | | | | 7:0 | SWTERM | PSYNC | PPS | | | PSS[4:0] | | | | 0x033A | <b>PGxyPCIH</b> | 15:8 | BPEN | 0,470.0 | BPSEL[2:0] | | T000 | | ACP[2:0] | | | | | 7:0 | SWPCI | SWPC | IM[1:0] | LATMOD | TQPS | | TQSS[2:0] | | | 0x033C | | | | | | | | | | | | 0.0247 | Reserved | | | | | | | | | | | 0x0347 | | 15:8 | | | | LEB | 15:01 | | | | | 0x0348 | PG1LEBL | 7:0 | | | | LEB | | | | | | | | 15:8 | | | | LED | [7.0] | | PWMPCI[2:0] | | | 0x034A | PG1LEBH | 7:0 | | | | | PHR | PHF | PLR | PLF | | | | 15:8 | | | | PG0PHA | | ЕПЕ | FLK | FLF | | 0x034C | PG0PHASE | 7:0 | | | | PG0PH/ | | | | | | | | 15:8 | | | | | | | | | | 0x034E | PG0DC | 7:0 | | | | PG0D0 | | | | | | | | 15:8 | | | | PGUD | C[7.0] | | | | | 0x0350 | PG0DCA | 7:0 | | | | PG0D0 | 2.4.17.01 | | | | | | | 15:8 | | | | PG0PE | | | | | | 0x0352 | PG0PER | 7:0 | | | | PG0PE | | | | | | | | 15:8 | | | | PG0FRI | | | | | | 0x0354 | PG0TRIGA | 7:0 | | | | PG0TR | | | | | | | | 15:8 | | | | PG0TRI | | | | | | 0x0356 | PG0TRIGB | 7:0 | | | | PG0TR | | | | | | | | 15:8 | | | | | | | | | | 0x0358 | PG0TRIGC | 7:0 | PG0TRIGC[15:8] PG0TRIGC[7:0] | | | | | | | | | | | 15:8 | | | T . | 1 00110 | | [13:8] | | | | 0x035A | PG0DTL | 7:0 | | | | DTL | V - 2 - 1 - 1 - 1 | [13.0] | | | | | | 15:8 | | | 1 | DIL | <u> </u> | [13:8] | | | | 0x035C | PG0DTH | 7:0 | | | | DTH | | [13.0] | | | | | | 15:8 | | | | PG0CA | | | | | | 0x035E | PG0CAP | 7:0 | | | | | AP[7:0] | | | | | | | 15:8 | ON | Reserved | | FGUC | λ-[ <i>1</i> .0] | | TRGCNT[2:0] | | | 0x0360 | PG1CONL | 7:0 | HREN | reserved | | CLKSI | =1 [1:0] | | MODSEL[2:0] | | | | | 15:8 | MDCSEL | MPERSEL | MPHSEL | OLIVOI | MSTEN | | UPMOD[2:0] | | | 0x0362 | PG1CONH | 7:0 | Reserved | TRGMOD | WII FIGEE | | WOTEN | SOC | S[3:0] | | | | | 15:8 | SEVT | FLTEVT | CLEVT | FFEVT | SACT | FLTACT | CLACT | FFACT | | 0x0364 | PG1STAT | 7:0 | TRSET | TRCLR | CAP | UPDATE | UPDREQ | STEER | CAHALF | TRIG | | | | 15:8 | CLMOD | SWAP | OVRENH | OVRENL | Action Charles Artists | AT[1:0] | OSYN | 500001100.0003 | | 0x0366 | PG1IOCONL | 7:0 | | AT[1:0] | CLDA | | | AT[1:0] | DBDA | | | | 1 4000 2 1000 2 10 100 F 10 2 10 AP | 15:8 | , , , , , | | CAPSRC[2:0] | [] | | | | DTCMPSEL | | 0x0368 | PG1IOCONH | 7:0 | | | PMOI | D[1:0] | PENH | PENL | POLH | POLL | | | | 15:8 | | | ADTR1PS[4:0] | | | ADTR1EN3 | ADTR1EN2 | ADTR1EN1 | | 0x036A | PG1EVTL | 7:0 | | | | UPDTF | RG[1:0] | | PGTRGSEL[2:0 | | | 0.555 | <u> </u> | 15:8 | FLTIEN | CLIEN | FFIEN | SIEN | | | IEVTSI | - | | 0x036C | PG1EVTH | 7:0 | ADTR2EN3 | ADTR2EN2 | ADTR2EN1 | recent relative | | ADTR1OFS[4:0 | | ************************************** | | 0x036E | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x037D | | | | | | | | | | | | 0.0275 | DC2L EDI | 15:8 | | | | LEB[ | 15:8] | , | | | | 0x037E | PG2LEBL | 7:0 | | | | LEB | [7:0] | | | | | 0.0200 | DOOL EDIT | 15:8 | | | | | | | PWMPCI[2:0] | | | 0x0380 | PG2LEBH | 7:0 | | | | | PHR | PHF | PLR | PLF | | 0×0202 | DC1DUAGE | 15:8 | | | | PG1PHA | SE[15:8] | | | | | 0x0382 | PG1PHASE | 7:0 | | | | PG1PH/ | ASE[7:0] | | | | | 0v0204 | DC1DC | 15:8 | | | | PG1D | C[15:8] | | | | | 0x0384 | PG1DC | 7:0 | | | | PG1D | C[7:0] | | | | | | | 98721 800 | | | | | | | | | | 0x0386 | PG1DCA | 15:8 | | | | | | | | | | | TO FINAL A | | | | | | | | | | | | |----------|---------------------------|-------------|--------------------|---------------------------|--------------|---------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------------|--|--| | conti | nued | | | | | | | | | | | | | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 0,,0200 | DOADED | 15:8 | | | | PG1PE | R[15:8] | | | | | | | 0x0388 | PG1PER | 7:0 | | | | PG1PE | | | | | | | | 0x038A | PG1TRIGA | 15:8 | | | | PG1TRI | GA[15:8] | | | | | | | 0,000,1 | 1011110/1 | 7:0 | | CLKSEL[1:0] MODSEL[2:0] | | | | | | | | | | 0x038C | PG1TRIGB | 15:8 | | | | | | | | | | | | | W. S. W. W. W. S. C. | 7:0 | | | | | | | | | | | | 0x038E | PG1TRIGC | 15:8 | | | | | | | | | | | | | | 7:0<br>15:8 | | | 1 | PGTIR | | 42.01 | | | | | | 0x0390 | PG1DTL | 7:0 | | | | DTI | | [13:8] | | | | | | | | 15:8 | | | 1 | DIL | | 13.81 | | | | | | 0x0392 | PG1DTH | 7:0 | | | | DTH | | [10.0] | | | | | | | | 15:8 | | | | | | | | | | | | 0x0394 | PG1CAP | 7:0 | | | | | | | | | | | | | the state of the state of | 15.8 | ON | Reserved | | , ,,,,, | . [] | | TRGCNT[2:0] | | | | | 0x0396 | PG2CONL | 7:0 | HREN | | | CLKSI | EL[1:0] | | | | | | | 0,40000 | DOGGOVILL | 15:8 | MDCSEL | MPERSEL | MPHSEL | | | | | | | | | 0x0398 | PG2CONH | 7:0 | Reserved | TRGMOD | | | | SOC | | | | | | 0x039A | PG2STAT | 15:8 | SEVT | FLTEVT | CLEVT | FFEVT | SACT | FLTACT | CLACT | FFACT | | | | UXUS9A | PGZSTAT | 7:0 | TRSET | TRCLR | CAP | UPDATE | UPDREQ | STEER | CAHALF | TRIG | | | | 0x039C | PG2IOCONL | 15:8 | CLMOD | 1.10.00010000 | | | | | | | | | | Охоооо | 1 021000112 | 7:0 | FLTDA | AT[1:0] | | T[1:0] | FFDA | T[1:0] | DBDA | | | | | 0x039E | PG2IOCONH | 15:8 | | | | | | A STATE OF S | | DTCMPSEL | | | | | 1.1 manus managan manus | 7:0 | | | | | PENH | 300 1000 0000 | N SCHOOL STORY | 7250 20000000000000000000000000000000000 | | | | 0x03A0 | PG2EVTL | 15:8 | | | ADTR1PS[4:0] | | 2014.01 | | | | | | | | | 7:0 | FITIEN | CLIEN | FFIFN | | RG[1:0] | | | | | | | 0x03A2 | PG2EVTH | 15:8<br>7:0 | FLTIEN<br>ADTR2EN3 | ADTR2EN2 | ADTR2EN1 | SIEN | | NDTD4OF0(4:0 | | | | | | 0x03A4 | | 7.0 | ADTRZENS | ADTRZENZ | ADTRZENT | | <i>,</i> | ADTRIOFS[4.0 | ' <u> </u> | | | | | 0,000,44 | Reserved | | | | | | | | | | | | | 0x03B3 | | | | | | | | | | | | | | 00004 | DOM EDI | 15:8 | | | 1 | LEB[ | 15:8] | t . | | | | | | 0x03B4 | PG3LEBL | 7:0 | | | | LEB | [7:0] | | | | | | | 0x03B6 | PG3LEBH | 15:8 | | | | | | | PWMPCI[2:0] | | | | | UXUUUU | COLLBIT | 7:0 | | | | | PHR | PHF | PLR | PLF | | | | 0x03B8 | PG2PHASE | 15:8 | | | | PG2PHA | | | | | | | | | N.S.W. S. H.C.S.W. | 7:0 | | | | | ASE[7:0] | | | | | | | 0x03BA | PG2DC | 15:8 | | | | PG2D | | | | | | | | | | 7:0 | | | | PG2D | U[1.0] | | | | | | | 0x03BC | PG2DCA | 15:8<br>7:0 | | | | DC3D( | CA[7:0] | | | | | | | 12 222 | | 15:8 | | | | | R[15:8] | | | | | | | 0x03BE | PG2PER | 7:0 | | | | | ER[7:0] | | | | | | | | | 15:8 | | | | | GA[15:8] | | | | | | | 0x03C0 | PG2TRIGA | 7:0 | | | | | IGA[7:0] | | | | | | | 00000 | DOOTDIOD | 15:8 | | | | | GB[15:8] | | | | | | | 0x03C2 | PG2TRIGB | 7:0 | | | | PG2TR | IGB[7:0] | | | | | | | 0x03C4 | PG2TRIGC | 15:8 | | | | PG2TRI | GC[15:8] | | | | | | | 0,0004 | 1 02111100 | 7:0 | | | | PG2TR | IGC[7:0] | | | | | | | 0x03C6 | PG2DTL | 15:8 | | | | | DTL | [13:8] | | | | | | UNUUUU | TOZDIL | 7:0 | | | | | | | | | | | | 0x03C8 | PG2DTH | 15:8 | | | | | | | | | | | | | | | 7:0 DTH[7:0] | | | | | | | | | | | 0x03CA | PG2CAP | | 15:8 PG2CAP[15:8] | | | | | | | | | | | | a contract state | 7:0 | ON | Desamo | | PG2C/ | AP[7:0] | | TDOONTO | | | | | 0x03CC | PG3CONL | 15:8 | ON<br>HREN | Reserved | | OL KO | =1 [4·0] | | TRGCNT[2:0] | | | | | | | 7:0<br>15:8 | MDCSEL | MPERSEL | MPHSEL | CLKSI | EL[1:0]<br>MSTEN | | MODSEL[2:0]<br>UPMOD[2:0] | | | | | 0x03CE | PG3CONH | 7:0 | Reserved | TRGMOD | IVITTIOEL | | INIOTEIN | SOC | S[3:0] | | | | | | | 7.0 | Neserveu | TROMOD | | | | 300 | O[0.0] | | | | | conti | nued | | | | | | | | | | |------------------|-----------------------------|-------------|--------------|----------|--------------|--------|----------------------|--------------|--------------|----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Pro Maria California (1900) | 15:8 | SEVT | FLTEVT | CLEVT | FFEVT | SACT | FLTACT | CLACT | FFACT | | 0x03D0 | PG3STAT | 7:0 | TRSET | TRCLR | CAP | UPDATE | UPDREQ | STEER | CAHALF | TRIG | | 002D0 | DOMOGONI | 15:8 | CLMOD | SWAP | OVRENH | OVRENL | OVRD | AT[1:0] | OSYN | IC[1:0] | | 0x03D2 | PG3IOCONL | 7:0 | FLTD | AT[1:0] | CLDA | T[1:0] | FFDA | T[1:0] | DBDA | T[1:0] | | 0x03D4 | PG4CONH | 15:8 | MDCSEL | MPERSEL | MPHSEL | | MSTEN | | UPMOD[2:0] | | | 0X03D4 | PG4CONH | 7:0 | Reserved | TRGMOD | | | | soc | S[3:0] | | | 0x03D4 | PG3IOCONH | 15:8 | | | CAPSRC[2:0] | | | | | DTCMPSEL | | OXOOD 1 | 1 0010001111 | 7:0 | | | | D[1:0] | PENH | PENL | POLH | POLL | | 0x03D6 | PG3EVTL | 15:8 | | | ADTR1PS[4:0] | | | ADTR1EN3 | ADTR1EN2 | ADTR1EN1 | | | | 7:0 | | | | | RG[1:0] | | PGTRGSEL[2:0 | - | | 0x03D8 | PG3EVTH | 15:8 | FLTIEN | CLIEN | FFIEN | SIEN | | | IEVTS | EL[1:0] | | 0.0004 | | 7:0 | ADTR2EN3 | ADTR2EN2 | ADTR2EN1 | | | ADTR10FS[4:0 | )] | | | 0x03DA | Decembed | | | | | | | | | | | <br>0x03E9 | Reserved | | | | | | | | | | | UXUSES | | 15:8 | | | | I FRI | [15:8] | | | | | 0x03EA | PG4LEBL | 7:0 | | | | | [7:0] | | | | | | NEWSON WAS THE | 15:8 | | | | | , | | PWMPCI[2:0] | | | 0x03EC | PG4LEBH | 7:0 | | | | | PHR | PHF | PLR | PLF | | | | 15:8 | | | 1 | PG3PHA | ASE[15:8] | | | | | 0x03EE | PG3PHASE | 7:0 | | | | PG3PH | ASE[7:0] | | | | | 0,0250 | DOSDO | 15:8 | | | | PG3D | C[15:8] | | | | | 0x03F0 | PG3DC | 7:0 | | | | PG3D | C[7:0] | | | | | 0x03F2 | PG3DCA | 15:8 | | | | | | | | | | UXUSFZ | PGSDCA | 7:0 | PG3DCA[7:0] | | | | | | | | | 0x03F4 | PG3PER | 15:8 | PG3PER[15:8] | | | | | | | | | OXOOI 4 | T GOT ETC | 7:0 | PG3PER[7:0] | | | | | | | | | 0x03F6 | PG3TRIGA | 15:8 | | | | | GA[15:8] | | | | | 0.000.0 | | 7:0 | | | | | IGA[7:0] | | | | | 0x03F8 | PG3TRIGB | 15:8 | | | | | GB[15:8] | | | | | | | 7:0 | | | | | IGB[7:0] | | | | | 0x03FA | PG3TRIGC | 15:8<br>7:0 | | | | | GC[15:8]<br>IGC[7:0] | | | | | | | 15:8 | | | | PGSTR | DTL[ | 12.01 | | | | 0x03FC | PG3DTL | 7:0 | | | | DTI | .[7:0] | 13.0] | | | | | | 15:8 | | | | | | [13:8] | | | | 0x03FE | PG3DTH | 7:0 | | | | DTH | 1[7:0] | | | | | | | 15:8 | | | | | P[15:8] | | | | | 0x0400 | PG3CAP | 7:0 | | | | | AP[7:0] | | | | | 0x0402 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x041F | | | | | | | | | | | | 0x0420 | PG5LEBL | 15:8 | | | | | [15:8] | | | | | | | 7:0 | | | | LEB | [7:0] | | DIA # | | | 0x0422 | PG5LEBH | 15:8 | | | | | 5115 | 5115 | PWMPCI[2:0] | 5. 5 | | | Current of GRANTE V | 7:0 | | | | | PHR | PHF | PLR | PLF | | 0x0424 | Reserved | | | | | | | | | | | 0x0455 | Neserveu | | | | | | | | | | | | Time in the second | 15:8 | | | | LEBI | [15:8] | | | | | 0x0456 | PG6LEBL | 7:0 | LEB[7:0] | | | | | | | | | 0,0450 | DOOLED!! | 15:8 | | | | | | | PWMPCI[2:0] | | | 0x0458 | PG6LEBH | 7:0 | | | | | PHR | PHF | PLR | PLF | | 0x045A | | | | | | | | | | | | | Reserved | | | | | | | | | | | | | | | | | | | | | | | 0x048B | | | | | | | | | | | | 0x048B<br>0x048C | PG7LEBL | 15:8<br>7:0 | | | | | [15:8]<br>[7:0] | | | | | continued | | | | | | | | | | | |----------------|----------|----------|---|---|---|------|-------|-----|-------------|-----| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x048E | PG7LEBH | 15:8 | | | | | | | PWMPCI[2:0] | | | UXU46E PG/LEBH | PG/LEBH | 7:0 | | | | | PHR | PHF | PLR | PLF | | 0x0490 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x04C1 | | | | | | | | | | | | 0x04C2 | PG8LEBL | 15:8 | | | | LEB[ | 15:8] | | | | | 0X0462 | PGOLEBL | 7:0 | | | | LEB | [7:0] | | | | | 0x04C4 | PG8LEBH | 15:8 | | | | | | | PWMPCI[2:0] | | | 0X04C4 | PGOLEBH | 7:0 | | | | | PHR | PHF | PLR | PLF | # **High-Resolution PWM with Fine Edge Placement** # 12.6.1 PWM Clock Control Register Name: PCLKCON Offset: 0x300 #### Notes: - 1. A device-specific unlock sequence must be performed before this bit can be cleared. - 2. Changing the MCLKSEL[1:0] bits while ON (PGxCONL[15]) = 1 is not recommended. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|-------|---------|----|----|-------|----------| | | HRRDY | HRERR | | | | | | LOCK | | Access | R/W | R/W | | | | | | R/W | | Reset | 0 | 0 | | | | | | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DIVSE | EL[1:0] | | | MCLKS | SEL[1:0] | | Access | | | R/W | R/W | | | R/W | R/W | | Reset | | | 0 | 0 | | | 0 | 0 | #### Bit 15 - HRRDY High-Resolution Ready bit | Value | Description | |-------|--------------------------------------------| | 1 | The high-resolution circuitry is ready | | 0 | The high-resolution circuitry is not ready | #### Bit 14 - HRERR High-Resolution Error bit | Valu | Description | |------|-----------------------------------------------------------------------------| | 1 | An error has occurred; PWM signals will have limited resolution | | 0 | No error has occurred; PWM signals will have full resolution when HRRDY = 1 | # Bit 8 - LOCK Lock bit(1) | Value | Description | |-------|-------------------------------------------------| | 1 | Write-protected registers and bits are locked | | 0 | Write-protected registers and bits are unlocked | ### Bits 5:4 - DIVSEL[1:0] PWM Clock Divider Selection bits | Value | Description | |-------|----------------------| | 11 | Divide ratio is 1:16 | | 10 | Divide ratio is 1:8 | | 01 | Divide ratio is 1:4 | | 00 | Divide ratio is 1:2 | # Bits 1:0 - MCLKSEL[1:0] PWM Master Clock Selection bits<sup>(2)</sup> | Value | Description | |-------|--------------------------------------------------------| | 11 | AF <sub>PLLO</sub> – Auxiliary PLL post-divider output | | 10 | F <sub>PLLO</sub> – Primary PLL post-divider output | | 01 | AF <sub>VCO</sub> /2 – Auxiliary VCO/2 | | 00 | Fosc | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 500 # **High-Resolution PWM with Fine Edge Placement** # 12.6.2 Frequency Scale Register Name: FSCL Offset: 0x302 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|-----|-----|-----|-----|-----|-----|-----| | | FSCL[15:8] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FSCL[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - FSCL[15:0] Frequency Scale Register bits The value in this register is added to the frequency scaling accumulator at each pwm\_master\_clk. When the accumulated value exceeds the value of FSMINPER, a clock pulse is produced. # **High-Resolution PWM with Fine Edge Placement** # 12.6.3 Frequency Scaling Minimum Period Register Name: FSMINPER Offset: 0x304 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--| | | FSMINPER[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | FSMINPER[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - FSMINPER[15:0] Frequency Scaling Minimum Period Register bits This register holds the minimum clock period (maximum clock frequency) that can be produced by the frequency scaling circuit. # High-Resolution PWM with Fine Edge Placement # 12.6.4 Master Phase Register Name: MPHASE Offset: 0x306 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|--------------|-----|-----|-----|-----|-----|-----|-----|--| | | MPHASE[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | MPHASE[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - MPHASE[15:0] Main Phase Register bits # High-Resolution PWM with Fine Edge Placement # 12.6.5 Master Duty Cycle Register Name: MDC Offset: 0x308 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-----------|-----|-----|-----|-----|-----|-----|-----|--| | | MDC[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | MDC[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - MDC[15:0] Main Duty Cycle Register bits # **High-Resolution PWM with Fine Edge Placement** ## 12.6.6 Master Period Register Name: MPER Offset: 0x30A #### Note: 1. Period values less than $0 \times 0 0 10$ should not be selected. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----|------------|-----|-----|--------|-----|-----|-----|--|--|--| | | | MPER[15:8] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | MPE | R[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:0 - MPER[15:0] Main Period Register bits<sup>(1)</sup> This register holds the period value that can be shared by multiple PWM Generators. ## **High-Resolution PWM with Fine Edge Placement** #### 12.6.7 Combinational Trigger Register Low Name: CMBTRIGL Offset: 0x30E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|----|----|----|----|----|----|---|---| | | | | | | | | | | | | | | | * | * | | | | Access Reset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | CTA8EN | CTA7EN | CTA6EN | CTA5EN | CTA4EN | CTA3EN | CTA2EN | CTA1EN | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 7 - CTA8EN Enable Trigger Output from PWM Generator #8 as Source for Comb. Trigger A bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | 0 | Disabled | #### Bit 6 - CTA7EN Enable Trigger Output from PWM Generator #7 as Source for Comb. Trigger A bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | 0 | Disabled | #### Bit 5 - CTA6EN Enable Trigger Output from PWM Generator #6 as Source for Comb. Trigger A bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | 0 | Disabled | ### Bit 4 - CTA5EN Enable Trigger Output from PWM Generator #5 as Source for Comb. Trigger A bit | Value | Description | | |-------|-------------------------------------------------------------------------------------|--| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | | 0 | Disabled | | #### Bit 3 - CTA4EN Enable Trigger Output from PWM Generator #4 as Source for Comb. Trigger A bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | 0 | Disabled | #### Bit 2 - CTA3EN Enable Trigger Output from PWM Generator #3 as Source for Comb. Trigger A bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | 0 | Disabled | ### Bit 1 - CTA2EN Enable Trigger Output from PWM Generator #2 as Source for Comb. Trigger A bit | 100 | Value | Description | |-----|-------|-------------------------------------------------------------------------------------| | | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | | 0 | Disabled | ### Bit 0 - CTA1EN Enable Trigger Output from PWM Generator #1 as Source for Comb. Trigger A bit | Value | Description | | |-------|-------------------------------------------------------------------------------------|--| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger A signal | | | 0 | Disabled | | ## **High-Resolution PWM with Fine Edge Placement** #### 12.6.8 Combinational Trigger Register High Name: CMBTRIGH Offset: 0x310 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|----|----|----|---|---| | | | | | | | | | | | Access | | | | > | ~ | > | | | Access | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | CTB8EN | CTB7EN | CTB6EN | CTB5EN | CTB4EN | CTB3EN | CTB2EN | CTB1EN | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 7 - CTB8EN Enable Trigger Output from PWM Generator #8 as Source for Comb. Trigger B bit | 1 | /alue | Description | |---|-------|-------------------------------------------------------------------------------------| | | L | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | ( | ) | Disabled | ### Bit 6 - CTB7EN Enable Trigger Output from PWM Generator #7 as Source for Comb. Trigger B bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | 0 | Disabled | #### Bit 5 - CTB6EN Enable Trigger Output from PWM Generator #6 as Source for Comb. Trigger B bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | 0 | Disabled | ## Bit 4 - CTB5EN Enable Trigger Output from PWM Generator #5 as Source for Comb. Trigger B bit | Value | Description | | |-------|-------------------------------------------------------------------------------------|--| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | | 0 | Disabled | | #### Bit 3 - CTB4EN Enable Trigger Output from PWM Generator #4 as Source for Comb. Trigger B bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | 0 | Disabled | #### Bit 2 - CTB3EN Enable Trigger Output from PWM Generator #3 as Source for Comb. Trigger B bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | 0 | Disabled | ### Bit 1 - CTB2EN Enable Trigger Output from PWM Generator #2 as Source for Comb. Trigger B bit | | Crazer Ingger Cupat rom 1 VIII Constant III de Course les Comb. Higger Bat. | |-------|-------------------------------------------------------------------------------------| | Value | e Description | | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | 0 | Disabled | ### Bit 0 - CTB1EN Enable Trigger Output from PWM Generator #1 as Source for Comb. Trigger B bit | Value | Description | | |-------|-------------------------------------------------------------------------------------|--| | 1 | Enables specified trigger signal to be OR'd into the Combinatorial Trigger B signal | | | 0 | Disabled | | ## 12.6.9 Combinatorial PWM Logic Control Register y Name: LOGCONy<sup>(2)</sup> **Offset:** 0x0312, 0x0314, 0x0316, 0x0318, 0x031A, 0x031C #### Notes: 1. Logic function input will be connected to '0' if the PWM channel is not present. 2. 'y' denotes a common instance (A-F). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|--------|-------------|------|----------|-----|-------------|--------------|-----|--| | | | PWMS1y[3:0] | | | | PWMS2y[3:0] | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | S1yPOL | S2yPOL | PWML | .Fy[1:0] | | | PWMLFyD[2:0] | | | | Access | R/W | R/W | R/W | R/W | | R/W | R/W | R/W | | | Reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | Bits 15:12 - PWMS1y[3:0] Combinatorial PWM Logic Source #1 Selection bits(1) | Value | Description | |-------|-------------| | 1111 | PWM8L | | 1110 | PWM8H | | 1101 | PWM7L | | 1100 | PWM7H | | 1011 | PWM6L | | 1010 | PWM6H | | 1001 | PWM5L | | 1000 | PWM5H | | 0111 | PWM4L | | 0110 | PWM4H | | 0101 | PWM3L | | 0100 | PWM3H | | 0011 | PWM2L | | 0010 | PWM2H | | 0001 | PWM1L | | 0000 | PWM1H | Bits 11:8 - PWMS2y[3:0] Combinatorial PWM Logic Source #2 Selection bits(1) | Value | Description | |-------|-------------| | 1111 | PWM8L | | 1110 | PWM8H | | 1101 | PWM7L | | 1100 | PWM7H | | 1011 | PWM6L | | 1010 | PWM6H | | 1001 | PWM5L | | 1000 | PWM5H | | 0111 | PWM4L | | 0110 | PWM4H | | 0101 | PWM3L | | 0100 | PWM3H | | 0011 | PWM2L | | 0010 | PWM2H | | 0001 | PWM1L | | 0000 | PWM1H | # **High-Resolution PWM with Fine Edge Placement** #### Bit 7 - S1yPOL Combinatorial PWM Logic Source #1 Polarity bit | Value | Description | |-------|-------------------------| | 1 | Input is inverted | | 0 | Input is positive logic | #### Bit 6 - S2yPOL Combinatorial PWM Logic Source #2 Polarity bit | Value | Description | | | | |-------|-------------------------|--|--|--| | 1 | Input is inverted | | | | | 0 | Input is positive logic | | | | #### Bits 5:4 - PWMLFy[1:0] Combinatorial PWM Logic Function Selection bits | Value | Description | |-------|---------------------| | 11 | Reserved | | 10 | PWMS1 ^ PWMS2 (XOR) | | 01 | PWMS1 & PWMS2 (AND) | | 00 | PWMS1 PWMS2 (OR) | ### Bits 2:0 - PWMLFyD[2:0] Combinatorial PWM Logic Destination Selection bits | Value | Description | |-------|-------------------------------------------------------------| | 111 | Logic function is assigned to the PWM8H or PWM8L pin | | 110 | Logic function is assigned to the PWM7H or PWM7L pin | | 101 | Logic function is assigned to the PWM6H or PWM6L pin | | 100 | Logic function is assigned to the PWM5H or PWM5Lpin | | 011 | Logic function is assigned to the PWM4H or PWM4Lpin | | 010 | Logic function is assigned to the PWM3H or PWM3Lpin | | 001 | Logic function is assigned to the PWM2H or PWM2Lpin | | 000 | No assignment, combinatorial PWM logic function is disabled | #### 12.6.10 PWM Event Output Control Register y Name: PWMEVTy<sup>(5)</sup> **Offset:** 0x031E, 0x0320, 0x0322, 0x0324, 0x0326, 0x0328 #### Notes: - The event signal is stretched using the peripheral clock because different PGs may be operating from different clock sources. The leading edge of the event pulse is produced in the clock domain of the PWM Generator. The trailing edge of the stretched event pulse is produced in the peripheral clock domain. - 2. No event will be produced if the selected PWM Generator is not present. - 3. This is the PWM Generator output signal prior to Output mode logic and any output override logic. - 4. This signal should be the PGx clk domain signal prior to any synchronization into the system clock domain. - 5. 'y' denotes a common instance (A-F). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------------|---------|----------|----------|--------------|-----|-----|-----| | | EVTyOEN | EVTyPOL | EVTySTRD | EVTySYNC | | | | | | Access | R/W | R/W | R/W | R/W | | | | | | Reset | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | EVTySEL[3:0] | | | | EVTyPGS[2:0] | | | | | Access | R/W | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | #### Bit 15 - EVTyOEN PWM Event Output Enable bit | Value | e Description | |-------|----------------------------------------------| | 1 | Event output signal is output on PWMEVTy pin | | 0 | Event output signal is internal only | #### Bit 14 - EVTyPOL PWM Event Output Polarity bit | Value | Description | |-------|------------------------------------| | 1 | Event output signal is active-low | | 0 | Event output signal is active-high | #### Bit 13 - EVTvSTRD PWM Event Output Stretch Disable bit | Value | Description | |-------|-----------------------------------------------------------------------------------| | 1 | Event output signal pulse width is not stretched | | 0 | Event output signal is stretched to eight PWM clock cycles minimum <sup>(1)</sup> | ## Bit 12 - EVTySYNC PWM Event Output Sync bit Event output signal pulse will be two system clocks when this bit is set and EVTySTRD = 1. | Value | Description | | | |-------|---------------------------------------------------------|--|--| | 1 | Event output signal is synchronized to the system clock | | | | 0 | Event output is not synchronized to the system clock | | | ### Bits 7:4 - EVTySEL[3:0] PWM Event Selection bits | Value | Description | |-----------|------------------------------------------------------------------------| | 1111 | High-resolution error event signal | | 1110-1010 | Reserved | | 1001 | ADC Trigger 2 signal | | 1000 | ADC Trigger 1 signal | | 0111 | STEER signal (available in Push-Pull Output modes only) <sup>(4)</sup> | | 0110 | CAHALF signal (available in Center-Aligned modes only) <sup>(4)</sup> | | 0101 | PCI Fault active output signal | | 0100 | PCI current-limit active output signal | | 0011 | PCI feed-forward active output signal | # **High-Resolution PWM with Fine Edge Placement** | Value | Description | |-------|----------------------------------------------| | 0010 | PCI Sync active output signal | | 0001 | PWM Generator output signal <sup>(3)</sup> | | 0000 | Source is selected by the PGTRGSEL[2:0] bits | ## Bits 2:0 - EVTyPGS[2:0] PWM Event Source Selection bits<sup>(2)</sup> | Value | Description | |-------|-----------------| | 111 | PWM Generator 8 | | 110 | PWM Generator 7 | | | | | 000 | PWM Generator 1 | # **High-Resolution PWM with Fine Edge Placement** ## 12.6.11 Linear Feedback Shift Register Name: LFSR Offset: 0x30C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|------------|-----|-----|-----| | | | | | | LFSR[14:8] | | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | LFSF | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Bits 14:0 – LFSR[14:0]** Linear Feedback Shift Register bits A read of this register will provide a 15-bit pseudorandom value. #### 12.6.12 PWM Generator x Control Register Low Name: PGxCONL **Offset:** 0x032A, 0x0360, 0x0396, 0x3CC #### Note: The PWM Generator time base operates from the frequency scaling circuit clock, effectively scaling the duty cycle and period of the PWM Generator output. #### Legend: r = Reserved bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|----------|----|------|---------|-----|-------------|-----| | | ON | Reserved | | | | | TRGCNT[2:0] | | | Access | R/W | r | | | | R/W | R/W | R/W | | Reset | 0 | 0 | | | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | HREN | | | CLKS | EL[1:0] | | MODSEL[2:0] | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - ON Enable bit | Value | Description | |-------|------------------------------| | 1 | PWM Generator is enabled | | 0 | PWM Generator is not enabled | ## Bit 14 - Reserved Maintain as '0' #### Bits 10:8 - TRGCNT[2:0] Trigger Count Select bits | Value | Description | |-------|---------------------------------------------------------| | 111 | PWM Generator produces eight PWM cycles after triggered | | 110 | PWM Generator produces seven PWM cycles after triggered | | 101 | PWM Generator produces six PWM cycles after triggered | | 100 | PWM Generator produces five PWM cycles after triggered | | 011 | PWM Generator produces four PWM cycles after triggered | | 010 | PWM Generator produces three PWM cycles after triggered | | 001 | PWM Generator produces two PWM cycles after triggered | | 000 | PWM Generator produces one PWM cycle after triggered | ### Bit 7 - HREN PWM Generator x High-Resolution Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | PWM Generator x operates in High-Resolution mode | | 0 | PWM Generator x operates in Standard Resolution mode | #### Bits 4:3 - CLKSEL[1:0] Clock Selection bits | Value | Description | |-------|----------------------------------------------------------------------------------------| | 11 | PWM Generator uses Host clock scaled by frequency scaling circuit <sup>(1)</sup> | | 10 | PWM Generator uses Host clock divided by clock divider circuit <sup>(1)</sup> | | 01 | PWM Generator uses Host clock selected by the MCLKSEL[1:0] (PCLKCON[1:0]) control bits | | 00 | No clock selected, PWM Generator is in lowest power state (default) | #### Bits 2:0 - MODSEL[2:0] Mode Selection bits | Value | Description | |-------|-------------------------------------------------------------------------------| | 111 | Dual Edge Center-Aligned PWM mode (interrupt/register update twice per cycle) | | 110 | Dual Edge Center-Aligned PWM mode (interrupt/register update once per cycle) | | 101 | Double-Update Center-Aligned PWM mode | | 100 | Center-Aligned PWM mode | # **High-Resolution PWM with Fine Edge Placement** | Value | Description | |-------|----------------------------------------| | 011 | Reserved | | 010 | Independent Edge PWM mode, dual output | | 001 | Variable Phase PWM mode | | 000 | Independent Edge PWM mode | ### 12.6.13 PWM Generator x Control Register High Name: PGxCONH **Offset:** 0x32C, 0x362, 0x398, 0x3CE, 0x3D4 #### Notes: - The PCI selected Sync signal is always available to be OR'd with the selected SOC signal per the SOCS[3:0] bits if the PCI Sync function is enabled. - The source selected by the SOCS[3:0] bits MUST operate from the same clock source as the local PWM Generator. If not, the source must be routed through the PCI Sync logic so the trigger signal may be synchronized to the PWM Generator clock domain. - 3. PWM Generators are grouped into groups of four: PG1-PG4 and PG5-PG8, if available. Any generator within a group of four may be used to trigger another generator within the same group. #### Legend: r = Reserved bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|---------|--------|----|-------|-----|------------|-----| | | MDCSEL | MPERSEL | MPHSEL | | MSTEN | | UPMOD[2:0] | | | Access | R/W | R/W | R/W | | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | TRGMOD | | | | SOC | S[3:0] | | | Access | r | R/W | | , | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | | | 0 | 0 | 0 | 0 | #### Bit 15 - MDCSEL Main Duty Cycle Register Select bit | Value | Description | |-------|------------------------------------------------------| | 1 | PWM Generator uses the MDC register instead of PGxDC | | 0 | PWM Generator uses the PGxDC register | ### Bit 14 - MPERSEL Main Period Register Select bit | Value | Description | | | | |-------|--------------------------------------------------------|--|--|--| | 1 | PWM Generator uses the MPER register instead of PGxPER | | | | | 0 | PWM Generator uses the PGxPER register | | | | #### Bit 13 - MPHSEL Main Phase Register Select bit | Value | Description | | | | |-------|------------------------------------------------------------|--|--|--| | 1 | PWM Generator uses the MPHASE register instead of PGxPHASE | | | | | 0 | PWM Generator uses the PGxPHASE register | | | | #### Bit 11 - MSTEN Main Update Enable bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | PWM Generator broadcasts software set/clear of the UPDATE status bit and EOC signal to other PWM | | | Generators | | 0 | PWM Generator does not broadcast the UPDATE status bit state or EOC signal | #### Bits 10:8 - UPMOD[2:0] PWM Buffer Update Mode Selection bits #### Bit 7 - Reserved Maintain as '0' #### Bit 6 - TRGMOD PWM Generator Trigger Mode Selection bit | DIL 0 - IT | ROMOD FWIN Generator inigger mode Selection bit | |------------|-------------------------------------------------| | Value | Description | | 1 | PWM Generator operates in Retriggerable mode | | 0 | PWM Generator operates in Single Trigger mode | ### Bits 3:0 - SOCS[3:0] Start-of-Cycle Selection bits(1,2,3) # **High-Resolution PWM with Fine Edge Placement** | Value | Description | |-----------|-----------------------------------------------------------------------------| | 1111 | TRIG bit or PCI Sync function only (no hardware trigger source is selected) | | 1110-0101 | Reserved | | 0100 | PWM4(8) PG1 or PG5 trigger output selected by PGTRGSEL[2:0] (PGxEVT[2:0]) | | 0011 | PWM3(7) PG1 or PG5 trigger output selected by PGTRGSEL[2:0] (PGxEVT[2:0]) | | 0010 | PWM2(6) PG1 or PG5 trigger output selected by PGTRGSEL[2:0] (PGxEVT[2:0]) | | 0001 | PWM1(5) PG1 or PG5 trigger output selected by PGTRGSEL[2:0] (PGxEVT[2:0]) | | 0000 | Local EOC – PWM Generator is self-triggered | #### 12.6.14 PWM Generator x Status Register Name: PGxSTAT **Offset:** 0x32E, 0x364, 0x39A, 0x3D0 #### Note: 1. User software may write a '1' to CAP as a request to initiate a software capture. The CAP status bit will be set when the capture event has occurred. No further captures will occur until CAP is cleared by software. Legend: C = Clearable bit; HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|--------|--------|--------|--------|--------|--------|-------| | | SEVT | FLTEVT | CLEVT | FFEVT | SACT | FLTACT | CLACT | FFACT | | Access | HS/C | HS/C | HS/C | HS/C | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TRSET | TRCLR | CAP | UPDATE | UPDREQ | STEER | CAHALF | TRIG | | Access | W | W | R/W/HS | R | W | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - SEVT PCI Sync Event bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------| | 1 | A PCI Sync event has occurred (rising edge on PCI Sync output or PCI Sync output is high when | | | module is enabled) | | 0 | No PCI Sync event has occurred | #### Bit 14 - FLTEVT PCI Fault Active Status bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------------| | 1 | A Fault event has occurred (rising edge on PCI Fault output or PCI Fault output is high when module is | | | enabled) | | 0 | No Fault event has occurred | #### Bit 13 - CLEVT PCI Current Limit Status bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 1 | A PCI current limit event has occurred (rising edge on PCI current-limit output or PCI current-limit | | | output is high when module is enabled) | | 0 | No PCI current limit event has occurred | ### Bit 12 - FFEVT PCI Feed-Forward Active Status bit | Value | Description | | | | |-------|---------------------------------------------------------------------------------------------------|--|--|--| | 1 | A PCI feed-forward event has occurred (rising edge on PCI feed-forward output or PCI feed-forward | | | | | | output is high when module is enabled) | | | | | 0 | No PCI feed-forward event has occurred | | | | ### Bit 11 - SACT PCI Sync Status bit | Value | Description | |-------|-----------------------------| | value | Description | | 1 | PCI Sync output is active | | 0 | PCI Sync output is inactive | #### Bit 10 - FLTACT PCI Fault Active Status bit | Value | Description | |-------|------------------------------| | 1 | PCI Fault output is active | | 0 | PCI Fault output is inactive | #### Bit 9 - CLACT PCI Current Limit Status bit ## **High-Resolution PWM with Fine Edge Placement** | Value | Description | |-------|--------------------------------------| | 1 | PCI current limit output is active | | 0 | PCI current limit output is inactive | #### Bit 8 - FFACT PCI Feed-Forward Active Status bit | Value | Description | |-------|-------------------------------------| | 1 | PCI feed-forward output is active | | 0 | PCI feed-forward output is inactive | #### Bit 7 - TRSET PWM Generator Software Trigger Set bit User software writes a '1' to this bit location to trigger a PWM Generator cycle. The bit location always reads as '0'. The TRIG bit will indicate '1' when the PWM Generator is triggered. #### Bit 6 - TRCLR PWM Generator Software Trigger Clear bit User software writes a '1' to this bit location to stop a PWM Generator cycle. The bit location always reads as '0'. The TRIG bit will indicate '0' when the PWM Generator is not triggered. #### Bit 5 - CAP Capture Status bit(1) | Value | Description | |-------|-----------------------------------------------------------| | 1 | PWM Generator time base value has been captured in PGxCAP | | 0 | No capture has occurred | #### Bit 4 - UPDATE PWM Data Register Update Status/Control bit | Value | Description | |-------|----------------------------------------------------------------------------| | 1 | PWM Data register update is pending – user Data registers are not writable | | 0 | No PWM Data register update is pending | #### Bit 3 - UPDREQ PWM Data Register Update Request bit User software writes a '1' to this bit location to request a PWM Data register update. The bit location always reads as '0'. The UPDATE status bit will indicate '1' when an update is pending. #### Bit 2 - STEER Output Steering Status bit (Push-Pull Output mode only) | Value | Description | |-------|-------------------------------------------------| | 1 | PWM Generator is in 2nd cycle of Push-Pull mode | | 0 | PWM Generator is in 1st cycle of Push-Pull mode | #### Bit 1 - CAHALF Half Cycle Status bit (Center-Aligned modes only) | Value | Description | |-------|-------------------------------------------------| | 1 | PWM Generator is in 2nd half of time base cycle | | 0 | PWM Generator is in 1st half of time base cycle | ### Bit 0 - TRIG PWM Trigger Status bit | Value | Description | |-------|---------------------------------------------------------| | 1 | PWM Generator is triggered and PWM cycle is in progress | | 0 | No PWM cycle is in progress | ### 12.6.15 PWM Generator x I/O Control Register Low Name: PGxIOCONL Offset: 0x330, 0x366, 0x39C, 0x3D2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|------|------------|--------|-------------|-----|------------|-----| | | CLMOD | SWAP | OVRENH | OVRENL | OVRDAT[1:0] | | OSYNC[1:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FLTDAT[1:0] | | CLDAT[1:0] | | FFDAT[1:0] | | DBDAT[1:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - CLMOD Current Limit Mode Select bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------------| | 1 | If PCI current limit is active, then the PWMxH and PWMxL output signals are inverted (bit flipping), and | | | the CLDAT[1:0] bits are not used | | 0 | If PCI current limit is active, then the CLDAT[1:0] bits define the PWM output levels | #### Bit 14 - SWAP Swap PWM Signals to PWMxH and PWMxL Device Pins bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------| | 1 | The PWMxH signal is connected to the PWMxL pin and the PWMxL signal is connected to the PWMxH | | | pin | | 0 | PWMxH/L signals are mapped to their respective pins | #### Bit 13 - OVRENH User Override Enable for PWMxH Pin bit | Value | Description | |-------|---------------------------------------------------| | 1 | OVRDAT1 provides data for output on the PWMxH pin | | 0 | PWM Generator provides data for the PWMxH pin | #### Bit 12 - OVRENL User Override Enable for PWMxL Pin bit | Value | Description | |-------|---------------------------------------------------| | 1 | OVRDAT0 provides data for output on the PWMxL pin | | 0 | PWM Generator provides data for the PWMxL pin | #### Bits 11:10 - OVRDAT[1:0] Data for PWMxH/PWMxL Pins if Override is Enabled bits If OVERENH = 1, then OVRDAT1 provides data for PWMxH. If OVERENL = 1, then OVRDAT0 provides data for PWMxL. #### Bits 9:8 - OSYNC[1:0] User Output Override Synchronization Control bits | Value | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------| | 11 | Reserved | | 10 | User output overrides via the OVRENH/L and OVRDAT[1:0] bits occur when specified by the UPDMOD[2:0] bits in the PGxCONH register | | 01 | User output overrides via the OVRENH/L and OVRDAT[1:0] bits occur immediately (as soon as possible) | | 00 | User output overrides via the OVRENH/L and OVRDAT[1:0] bits are synchronized to the local PWM time base (next Start-of-Cycle) | #### Bits 7:6 - FLTDAT[1:0] Data for PWMxH/PWMxL Pins if Fault Event is Active bits If Fault is active, then FLTDAT1 provides data for PWMxH. If Fault is active, then FLTDAT0 provides data for PWMxL. 70005452B-page 520 # **High-Resolution PWM with Fine Edge Placement** **Bits 5:4 – CLDAT[1:0]** Data for PWMxH/PWMxL Pins if Current Limit Event is Active bits If current limit is active, then CLDAT1 provides data for PWMxH. If current limit is active, then CLDAT0 provides data for PWMxL. **Bits 3:2 – FFDAT[1:0]** Data for PWMxH/PWMxL Pins if Feed-Forward Event is Active bits If feed-forward is active, then FFDAT1 provides data for PWMxH. If feed-forward is active, then FFDAT0 provides data for PWMxL. **Bits 1:0 – DBDAT[1:0]** Data for PWMxH/PWMxL Pins if Debug Mode is Active and PTFRZ = 1 bits If Debug mode is active and PTFRZ = 1, then DBDAT1 provides data for PWMxH. If Debug mode is active and PTFRZ = 1, then DBDAT0 provides data for PWMxL. #### 12.6.16 PWM Generator x I/O Control Register High Name: PGxIOCONH **Offset:** 0x332, 0x368, 0x39E, 0x3D4 #### Note: 1. A capture may be initiated in software at any time by writing a '1' to CAP (PGxSTAT[5]). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-------------|-----------|-----|------|------|------|----------| | | | CAPSRC[2:0] | | | | | | DTCMPSEL | | Access | | R/W | R/W | R/W | | | | R/W | | Reset | | 0 | 0 | 0 | | | | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PMOD[1:0] | | PENH | PENL | POLH | POLL | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 14:12 - CAPSRC[2:0] Time Base Capture Source Selection bits(1) | Value | Description | | | | | | |-------|---------------------------------------------------------------------------|--|--|--|--|--| | 111 | Reserved | | | | | | | 110 | Reserved | | | | | | | 101 | eserved | | | | | | | 100 | Capture time base value at assertion of selected PCI Fault signal | | | | | | | 011 | Capture time base value at assertion of selected PCI current limit signal | | | | | | | 010 | Capture time base value at assertion of selected PCI feed-forward signal | | | | | | | 001 | Capture time base value at assertion of selected PCI Sync signal | | | | | | | 000 | No hardware source selected for time base capture – software only | | | | | | | | | | | | | | #### Bit 8 - DTCMPSEL Dead-Time Compensation Select bit | Value | Description | | |--------------------------------------------------------|----------------------------------------------------------------------|--| | 1 | Dead-time compensation is controlled by PCI feed-forward limit logic | | | Dead-time compensation is controlled by PCI Sync logic | | | #### Bits 5:4 - PMOD[1:0] PWM Generator Output Mode Selection bits | Value | Description | | |-------|-----------------------------------------------------|--| | 11 | Reserved | | | 10 | PWM Generator outputs operate in Push-Pull mode | | | 01 | PWM Generator outputs operate in Independent mode | | | 00 | PWM Generator outputs operate in Complementary mode | | #### Bit 3 - PENH PWMxH Output Port Enable bit | Value | Description | | | |-------|-----------------------------------------------------|--|--| | 1 | PWM Generator controls the PWMxH output pin | | | | 0 | PWM Generator does not control the PWMxH output pin | | | #### Bit 2 - PENL PWMxL Output Port Enable bit | Value | Description | | | |-------|-----------------------------------------------------|--|--| | 1 | PWM Generator controls the PWMxL output pin | | | | 0 | PWM Generator does not control the PWMxL output pin | | | ### Bit 1 - POLH PWMxH Output Polarity bit | Value | Description | | | |-------|---------------------------|--|--| | 1 | Output pin is active-low | | | | 0 | Output pin is active-high | | | # High-Resolution PWM with Fine Edge Placement | Bit 0 – POLL PWMxL Output Polarity bit | | | |----------------------------------------|---------------------------|--| | Value | Description | | | 1 | Output pin is active-low | | | 0 | Output pin is active-high | | #### 12.6.17 PWM Generator x Event Register Low Name: PGxEVTL **Offset:** 0x334, 0x36A, 0x3A0, 0x3D6 #### Note: 1. These events are derived from the internal PWM Generator time base comparison events. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|--------------|------|---------|----------|---------------|----------| | | | | ADTR1PS[4:0] | | | ADTR1EN3 | ADTR1EN2 | ADTR1EN1 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | UPDT | RG[1:0] | | PGTRGSEL[2:0] | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | #### Bits 15:11 - ADTR1PS[4:0] ADC Trigger 1 Postscaler Selection bits | Value | Description | |-------|-------------| | 11111 | 1:32 | | | | | 00010 | 1:3 | | 00001 | 1:2 | | 00000 | 1:1 | ### Bit 10 - ADTR1EN3 ADC Trigger 1 Source is PGxTRIGC Compare Event Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | PGxTRIGC register compare event is enabled as trigger source for ADC Trigger 1 | | 0 | PGxTRIGC register compare event is disabled as trigger source for ADC Trigger 1 | #### Bit 9 - ADTR1EN2 ADC Trigger 1 Source is PGxTRIGB Compare Event Enable bit | Value | Description | | | | |-------|---------------------------------------------------------------------------------|--|--|--| | 1 | PGxTRIGB register compare event is enabled as trigger source for ADC Trigger 1 | | | | | 0 | PGxTRIGB register compare event is disabled as trigger source for ADC Trigger 1 | | | | #### Bit 8 - ADTR1EN1 ADC Trigger 1 Source is PGxTRIGA Compare Event Enable bit | ١ | <b>Value</b> | Description | | | |-------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------|--|--| | [ | 1 | PGxTRIGA register compare event is enabled as trigger source for ADC Trigger 1 | | | | 0 PGxTRIGA register compare event is disabled as trigger source for ADC | | PGxTRIGA register compare event is disabled as trigger source for ADC Trigger 1 | | | ## Bits 4:3 - UPDTRG[1:0] Update Trigger Select bits | Value | Description | |-------|--------------------------------------------------------------------| | 11 | A write of the PGxTRIGA register automatically sets the UPDATE bit | | 10 | A write of the PGxPHASE register automatically sets the UPDATE bit | | 01 | A write of the PGxDC register automatically sets the UPDATE bit | | 00 | User must set the UPDATE bit (PGxSTAT[4]) manually | ## Bits 2:0 – PGTRGSEL[2:0] PWM Generator Trigger Output Selection bits<sup>(1)</sup> | Value | Description | |-------|-----------------------------------------------------| | 111 | Reserved | | 110 | Reserved | | 101 | Reserved | | 100 | Reserved | | 011 | PGxTRIGC compare event is the PWM Generator trigger | | 010 | PGxTRIGB compare event is the PWM Generator trigger | # **High-Resolution PWM with Fine Edge Placement** | Value | Description | |-------|-----------------------------------------------------| | 001 | PGxTRIGA compare event is the PWM Generator trigger | | 000 | EOC event is the PWM Generator trigger | #### 12.6.18 PWM Generator x Event Register High Name: PGxEVTH **Offset:** 0x336,0x36C, 0x3A2, 0x3D8 #### Notes: - 1. An interrupt is only generated on the rising edge of the PCI Fault active signal. - 2. An interrupt is only generated on the rising edge of the PCI current limit active signal. - 3. An interrupt is only generated on the rising edge of the PCI feed-forward active signal. - 4. An interrupt is only generated on the rising edge of the PCI Sync active signal. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|----------|----------|------|-----|---------------|-------|---------| | | FLTIEN | CLIEN | FFIEN | SIEN | | | IEVTS | EL[1:0] | | Access | R/W | R/W | R/W | R/W | | | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ADTR2EN3 | ADTR2EN2 | ADTR2EN1 | | | ADTR1OFS[4:0] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - FLTIEN PCI Fault Interrupt Enable bit(1) | Value | Description | |-------|-----------------------------| | 1 | Fault interrupt is enabled | | 0 | Fault interrupt is disabled | #### Bit 14 - CLIEN PCI Current-Limit Interrupt Enable bit(2) | Value | Description | |-------|-------------------------------------| | 1 | Current limit interrupt is enabled | | 0 | Current limit interrupt is disabled | #### Bit 13 - FFIEN PCI Feed-Forward Interrupt Enable bit (3) | Value | Description | |-------|------------------------------------| | 1 | Feed-forward interrupt is enabled | | 0 | Feed-forward interrupt is disabled | #### Bit 12 - SIEN PCI Sync Interrupt Enable bit(4) | Value | Description | |-------|----------------------------| | 1 | Sync interrupt is enabled | | 0 | Sync interrupt is disabled | #### Bits 9:8 - IEVTSEL[1:0] Interrupt Event Selection bits | Value | Description | |-------|----------------------------------------------------------------------------------------------| | 11 | Time base interrupts are disabled (Sync, Fault, current limit and feed-forward events can be | | | independently enabled) | | 10 | Interrupts CPU at ADC Trigger 1 event | | 01 | Interrupts CPU at TRIGA compare event | | 00 | Interrupts CPU at EOC | #### Bit 7 - ADTR2EN3 ADC Trigger 2 Source is PGxTRIGC Compare Event Enable bit | | The The The Tingger 2 course for extra co compare 2 to the Enable by | | | | | |-------|---------------------------------------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | PGxTRIGC register compare event is enabled as trigger source for ADC Trigger 2 | | | | | | 0 | PGxTRIGC register compare event is disabled as trigger source for ADC Trigger 2 | | | | | ### Bit 6 - ADTR2EN2 ADC Trigger 2 Source is PGxTRIGB Compare Event Enable bit # High-Resolution PWM with Fine Edge Placement | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | PGxTRIGB register compare event is enabled as trigger source for ADC Trigger 2 | | 0 | PGxTRIGB register compare event is disabled as trigger source for ADC Trigger 2 | ## Bit 5 - ADTR2EN1 ADC Trigger 2 Source is PGxTRIGA Compare Event Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | PGxTRIGA register compare event is enabled as trigger source for ADC Trigger 2 | | 0 | PGxTRIGA register compare event is disabled as trigger source for ADC Trigger 2 | #### Bits 4:0 - ADTR1OFS[4:0] ADC Trigger 1 Offset Selection bits | Value | Description | |-------|-----------------------------| | 11111 | Offset by 31 trigger events | | | | | 00010 | Offset by 2 trigger events | | 00001 | Offset by 1 trigger event | | 00000 | No offset | ## 12.6.19 PWM Generator xy PCI Register Low (x = PWM Generator #; y = F, CL, FF OR S) **PGxyPCIL** Offset: 0x338 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|------------------|-----|---------------------|-----|-----------|-----|-----| | | TSYNCDIS | YNCDIS TERM[2:0] | | TERM[2:0] AQPS AQSS | | AQSS[2:0] | :0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SWTERM | PSYNC | PPS | | | PSS[4:0] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - TSYNCDIS Termination Synchronization Disable bit | Value | Description | |-------|-----------------------------------------------| | 1 | Termination of latched PCI occurs immediately | | 0 | Termination of latched PCI occurs at PWM EOC | #### Bits 14:12 - TERM[2:0] Termination Event Selection bits | | - Little Live Live Live Live Live Live Live Liv | |-------|--------------------------------------------------------------------------------| | Value | Description | | 111 | Selects PCI Source #9 | | 110 | Selects PCI Source #8 | | 101 | Selects PCI Source #1 (PWM Generator output selected by the PWMPCI[2:0] bits) | | 100 | PGxTRIGC trigger event | | 011 | PGxTRIGB trigger event | | 010 | PGxTRIGA trigger event | | 001 | Auto-Terminate: Terminates when PCI source transitions from active to inactive | | 000 | Manual Terminate: Terminates on a write of '1' to the SWTERM bit location | | | | #### Bit 11 - AQPS Acceptance Qualifier Polarity Select bit | Value | Description | |-------|--------------| | 1 | Inverted | | 0 | Not inverted | ### Bits 10:8 - AQSS[2:0] Acceptance Qualifier Source Selection bits | Value | Description | |-------|-------------------------------------------------------------------------------| | 111 | SWPCI control bit only (qualifier forced to '0') | | 110 | Selects PCI Source #9 | | 101 | Selects PCI Source #8 | | 100 | Selects PCI Source #1 (PWM Generator output selected by the PWMPCI[2:0] bits) | | 011 | PWM Generator is triggered | | 010 | LEB is active | | 001 | Duty cycle is active (base PWM Generator signal) | | 000 | No acceptance qualifier is used (qualifier forced to '1') | #### Bit 7 - SWTERM PCI Software Termination bit A write of '1' to this location will produce a termination event. This bit location always reads as '0'. #### Bit 6 - PSYNC PCI Synchronization Control bit | Value Description | | | | | | |-------------------|-------------------------------------------|--|--|--|--| | 1 | PCI source is synchronized to PWM EOC | | | | | | 0 | PCI source is not synchronized to PWM EOC | | | | | Datasheet 70005452B-page 527 © 2021 Microchip Technology Inc. # **High-Resolution PWM with Fine Edge Placement** | Bit 5 – PPS PCI Polarity Select bit | | | | |-------------------------------------|--------------|--|--| | Value | Description | | | | 1 | Inverted | | | | 0 | Not inverted | | | ## Bits 4:0 - PSS[4:0] PCI Source Selection bits | Value | Description | |-------|-------------------------------------------------------| | 11111 | CLC1 | | 11110 | Reserved | | 11101 | Comparator 3 output | | 11100 | Comparator 2 output | | 11011 | Comparator 1 output | | 11010 | PWM Event D | | 11001 | PWM Event C | | 11000 | PWM Event B | | 10111 | PWM Event A | | 10110 | Device pin, PCI[22] | | 10101 | Device pin, PCI[21] | | 10100 | Device pin, PCI[20] | | 10011 | Device pin, PCI[19] | | 10010 | RPn input, PCI18R | | 10001 | RPn input, PCI17R | | 10000 | RPn input, PCI16R | | 01111 | RPn input, PCI15R | | 01110 | RPn input, PCI14R | | 01101 | RPn input, PCI13R | | 01100 | RPn input, PCI12R | | 01011 | RPn input, PCI11R | | 01010 | RPn input, PCI10R | | 01001 | RPn input, PCI9R | | 01000 | RPn input, PCI8R | | 00111 | Reserved | | 00110 | Reserved | | 00101 | Reserved | | 00100 | Reserved | | 00011 | Internally connected to Combo Trigger B | | 00010 | Internally connected to Combo Trigger A | | 00001 | Internally connected to the output of PWMPCI[2:0] MUX | | 00000 | Tied to '0' | ## 12.6.20 PWM Generator xy PCI Register High (x = PWM Generator #; y = F, CL, FF OR S) Name: PGxyPCIH Offset: 0x33A #### Note: 1. Selects '0' if selected PWM Generator is not present. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|------|------------|--------|------|-----|-----------|-----| | | BPEN | | BPSEL[2:0] | | | | ACP[2:0] | | | Access | R/W | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SWPCI | SWPC | IM[1:0] | LATMOD | TQPS | | TQSS[2:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - BPEN PCI Bypass Enable bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | PCI function is enabled and local PCI logic is bypassed; PWM Generator will be controlled by PCI | | | function in the PWM Generator selected by the BPSEL[2:0] bits | | 0 | PCI function is not bypassed | #### Bits 14:12 - BPSEL[2:0] PCI Bypass Source Selection bits<sup>(1)</sup> | Value | Description | |-------|---------------------------------------------------------------------| | 111 | PCI control is sourced from PWM Generator 8 PCI logic when BPEN = 1 | | 110 | PCI control is sourced from PWM Generator 7 PCI logic when BPEN = 1 | | 101 | PCI control is sourced from PWM Generator 6 PCI logic when BPEN = 1 | | 100 | PCI control is sourced from PWM Generator 5 PCI logic when BPEN = 1 | | 011 | PCI control is sourced from PWM Generator 4 PCI logic when BPEN = 1 | | 010 | PCI control is sourced from PWM Generator 3 PCI logic when BPEN = 1 | | 001 | PCI control is sourced from PWM Generator 2 PCI logic when BPEN = 1 | | 000 | PCI control is sourced from PWM Generator 1 PCI logic when BPEN = 1 | #### Bits 10:8 - ACP[2:0] PCI Acceptance Criteria Selection bits | Value | Description | |-------|---------------------| | 111 | Reserved | | 110 | Reserved | | 101 | Latched any edge | | 100 | Latched rising edge | | 011 | Latched | | 010 | Any edge | | 001 | Rising edge | | 000 | Level-sensitive | #### Bit 7 - SWPCI Software PCI Control bit | Value | Description | |-------|-----------------------------------------------------------------------| | 1 | Drives a '1' to PCI logic assigned to by the SWPCIM[1:0] control bits | | 0 | Drives a '0' to PCI logic assigned to by the SWPCIM[1:0] control bits | #### Bits 6:5 - SWPCIM[1:0] Software PCI Control Mode bits | Value | Description | |-------|------------------------------------------------------| | 11 | Reserved | | 10 | SWPCI bit is assigned to termination qualifier logic | | 01 | SWPCI bit is assigned to acceptance qualifier logic | # High-Resolution PWM with Fine Edge Placement | Value | Description | |-------|-----------------------------------------------| | 00 | SWPCI bit is assigned to PCI acceptance logic | ### Bit 4 - LATMOD PCI SR Latch Mode bit | Value | Description | |-------|--------------------------------------------------------| | 1 | SR latch is Reset-dominant in Latched Acceptance modes | | 0 | SR latch is set-dominant in Latched Acceptance modes | ### Bit 3 - TQPS Termination Qualifier Polarity Select bit | Value | Description | |-------|--------------| | 1 | Inverted | | 0 | Not inverted | ### Bits 2:0 - TQSS[2:0] Termination Qualifier Source Selection bits | Value | Description | |-------|-------------------------------------------------------------------------------| | 111 | SWPCI control bit only (qualifier forced to '0') | | 110 | Selects PCI Source #9 | | 101 | Selects PCI Source #8 | | 100 | Selects PCI Source #1 (PWM Generator output selected by the PWMPCI[2:0] bits) | | 011 | PWM Generator is triggered | | 010 | LEB is active | | 001 | Duty cycle is active (base PWM Generator signal) | | 000 | No termination qualifier used (qualifier forced to '1') | ## **High-Resolution PWM with Fine Edge Placement** ## 12.6.21 PWM Generator x Leading-Edge Blanking Register Low Name: PGxLEBL **Offset:** 0x348, 0x37E, 0x3B4, 0x3EA, 0x420, 0x456, 0x48C, 0x4C2 #### Note: 1. Bits[2:0] are read-only and always remain as '0'. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|------|-------|----|---|---| | | | | | LEB[ | 15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | LEB | [7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 – LEB[15:0] Leading-Edge Blanking Period bits<sup>(1)</sup> Leading-Edge Blanking period. The three LSbs of the blanking time are not used, providing a blanking resolution of eight PGx\_clks. The minimum blanking period is eight PGx\_clks which occurs when LEB[15:3] = 0. #### 12.6.22 PWM Generator x Leading-Edge Blanking Register High Name: PGxLEBH Offset: 0x34A, 0x380, 0x3B6, 0x3EC, 0x422, 0x458, 0x48E, 0x4C4 #### Note: 1. The selected PWM Generator source does not affect the LEB counter. This source can be optionally used as a PCI input, PCI qualifier, PCI terminator or PCI terminator qualifier. #### Bits 10:8 - PWMPCI[2:0] PWM Source for PCI Selection bits(1) | Value | Description | |-------|--------------------------------------------------------| | 111 | PWM Generator #8 output is made available to PCI logic | | 110 | PWM Generator #7 output is made available to PCI logic | | 101 | PWM Generator #6 output is made available to PCI logic | | 100 | PWM Generator #5 output is made available to PCI logic | | 011 | PWM Generator #4 output is made available to PCI logic | | 010 | PWM Generator #3 output is made available to PCI logic | | 001 | PWM Generator #2 output is made available to PCI logic | | 000 | PWM Generator #1 output is made available to PCI logic | #### Bit 3 - PHR PWMxH Rising bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Rising edge of PWMxH will trigger the LEB duration counter | | 0 | LEB ignores the rising edge of PWMxH | #### Bit 2 - PHF PWMxH Falling bit | Value | Description | |-------|-------------------------------------------------------------| | 1 | Falling edge of PWMxH will trigger the LEB duration counter | | 0 | LEB ignores the falling edge of PWMxH | #### Bit 1 - PLR PWMxL Rising bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Rising edge of PWMxL will trigger the LEB duration counter | | 0 | LEB ignores the rising edge of PWMxL | #### Bit 0 - PLF PWMxL Falling bit | Valu | Description | | |------|-------------------------------------------------------------|--| | 1 | Falling edge of PWMxL will trigger the LEB duration counter | | | 0 | LEB ignores the falling edge of PWMxL | | # High-Resolution PWM with Fine Edge Placement ## 12.6.23 PWM Generator x Phase Register Name: PGxPHASE **Offset:** 0x34C, 0x382, 0x3B8, 0x3EE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PGxPHASE[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PGxPHASE[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - PGxPHASE[15:0] PWM Generator x Phase Register bits # High-Resolution PWM with Fine Edge Placement ## 12.6.24 PWM Generator x Duty Cycle Register Name: PGxDC **Offset:** 0x34E, 0x384, 0x3BA, 0x3F0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PGxDC[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PGxDC[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - PGxDC[15:0] PWM Generator x Duty Cycle Register bits ### 12.6.25 PWM Generator x Duty Cycle Adjustment Register Name: PGxDCA Offset: 0x350, 0x386, 0x3BC, 0x3F2 Bits 7:0 – PGxDCA[7:0] PWM Generator x Duty Cycle Adjustment Value bits Depending on the state of the selected PCI source, the PGxDCA value will be added to the value in the PGxDC register to create the effective duty cycle. When the PCI source is active, PGxDCA is added. When the PCI source is inactive, no adjustment is made. Duty cycle adjustment is disabled when PGxDCA[7:0] = 0. The PCI source is selected using the DTCMPSEL bit. # **High-Resolution PWM with Fine Edge Placement** ## 12.6.26 PWM Generator x Period Register Name: PGxPER **Offset:** 0x352, 0x388, 0x3BE, 0x3F4 #### Note: 1. Period values less than $0 \times 0 \times 0 \times 10^{\circ}$ should not be selected. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|--------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PGxPER[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Γ | PGxPER[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 – PGxPER[15:0] PWM Generator x Period Register bits<sup>(1)</sup> # High-Resolution PWM with Fine Edge Placement ## 12.6.27 PWM Generator x Trigger A Register Name: PGxTRIGA **Offset:** 0x354, 0x38A, 0x3C0, 0x3F6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PGxTRIGA[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PGxTRIGA[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - PGxTRIGA[15:0] PWM Generator x Trigger A Register bits # High-Resolution PWM with Fine Edge Placement ## 12.6.28 PWM Generator x Trigger B Register Name: PGxTRIGB **Offset:** 0x356, 0x38C, 0x3C2, 0x3F8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PGxTRIGB[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PGxTRIGB[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - PGxTRIGB[15:0] PWM Generator x Trigger B Register bits # High-Resolution PWM with Fine Edge Placement ## 12.6.29 PWM Generator x Trigger C Register Name: PGxTRIGC **Offset:** 0x358, 0x38E, 0x3C4, 0x3FA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PGxTRIGC[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PGxTRIGC[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - PGxTRIGC[15:0] PWM Generator x Trigger C Register bits ## 12.6.30 PWM Generator x Dead-Time Register Low Name: PGxDTL Offset: 0x35A, 0x390, 0x3C6, 0x3FC Note: 1. DTL[13:11] bits are not available when HREN (PGxCONL[7]) = 0. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----|-----|-----|-----------|-----|-----|-----|-----|--|--| | | | | | DTL[13:8] | | | | | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | DTL[7:0] | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 13:0 - DTL[13:0] PWMxL Dead-Time Delay bits<sup>(1)</sup> # High-Resolution PWM with Fine Edge Placement # 12.6.31 PWM Generator x Dead-Time Register High Name: PGxDTH **Offset:** 0x35C, 0x392, 0x3C8, 0x3FE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-----|-------|-------|-----|-----| | | | | | | DTH | 13:8] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DTH | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 13:0 - DTH[13:0] PWMxH Dead-Time Delay bits # **High-Resolution PWM with Fine Edge Placement** # 12.6.32 PWM Generator x Capture Register Name: PGxCAP **Offset:** 0x35E, 0x394, 0x3CA, 0x400 #### Note: 1. PGxCAP[1:0] will read as '00' in Standard Resolution mode. PGxCAP[4:0] will read as '00000' in High-Resolution mode. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-------|---------|----|---|---| | | | | | PGxCA | P[15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PGxCA | AP[7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - PGxCAP[15:0] PGx Time Base Capture bits<sup>(1)</sup> # 13. High-Speed, 12-Bit Analog-to-Digital Converter #### Notes: - This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "12-Bit High-Speed, Multiple SARs A/D Converter (ADC)" (www.microchip.com/DS70005213) in the "dsPIC33/ PIC24 Family Reference Manual". - Some registers and associated bits described in this section may not be available on all devices due to the number of implemented ADC channels. Refer to dsPIC33CK512MP608 Product Families for ADC channel availability on device variants. dsPIC33CK512MP608 devices have a high-speed, 12-bit Analog-to-Digital Converter (ADC) that features a low conversion latency, high resolution and oversampling capabilities to improve performance in AC/DC and DC/DC power converters. The devices implement the ADC with three SAR cores, four dedicated and one shared. The number of available channels and negative inputs is dependent on package size, as shown in the table below. Table 13-1. ADC External Input Availability | Package Type | External Inputs | Negative Inputs | |--------------|----------------------|-----------------| | 80-Pin | AN0-AN23, AN26, AN27 | ANNO-ANN4 | | 64-Pin | AN0-AN19, AN26, AN27 | ANN0-ANN2, ANN4 | | 48-Pin | AN0-AN18, AN26, AN27 | ANNO-ANN2, ANN4 | ### 13.1 ADC Features Overview The high-speed, 12-bit multiple SARs Analog-to-Digital Converter (ADC) includes the following features: - · One Shared (common) Core - · User-Configurable Resolution of Up to 12 Bits - Up to 3.25 Msps Conversion Rate per Channel at 12-Bit Resolution - · Low Latency Conversion - Up to 28 Analog Input Channels with a Separate 16-Bit Conversion Result Register for each Input Channel - · Conversion Result can be Formatted as Unsigned or Signed Data, on a per Channel Basis, for All Channels - · Channel Scan Capability - Multiple Conversion Trigger Options, Including: - PWM triggers from CPU core - SCCP modules triggers - CLC modules triggers - External pin trigger event (ADTRG31) - Software trigger - Four Integrated Digital Comparators with Dedicated Interrupts: - Multiple comparison options - Assignable to specific analog inputs - · Four Oversampling Filters with Dedicated Interrupts: - Provide increased resolution - Assignable to a specific analog input Simplified block diagrams of the 12-bit ADC are shown in Figure 13-1 and Figure 13-2. The analog inputs (channels) are connected through multiplexers and switches to the Sample-and-Hold (S&H) circuit of the ADC core. The core uses the channel information (the output format, the Measurement mode and the input number) to process the analog sample. When conversion is complete, the result is stored in the result buffer for the specific analog input, and passed to the digital filter and digital comparator if they were configured to use data from this particular channel. If multiple ADC inputs request conversion on the shared core, the module will convert them in a sequential manner, starting with the lowest order input. The ADC provides each analog input the ability to specify its own trigger source. This capability allows the ADC to sample and convert analog inputs that are associated with PWM Generators operating on independent time bases. Figure 13-1. ADC Module Block Diagram ## Notes: - 1. Band Gap Reference (V<sub>BG</sub>) is an internal analog input and is not available on device pins. - 2. Your particular device may have a different number of dedicated cores; see the device-specific data sheet, pinout figures or Table 1-1. Figure 13-2. Shared Core Block Diagram #### Note: 1. Check the device pinout diagram to verify if the pin is available on the specific device. # 13.2 Temperature Sensor The ADC channel, AN24, is connected to a forward-biased diode. It can be used to measure die temperature. This diode provides an output with a temperature coefficient of approximately -1.5 mV/C that can be monitored by the ADC. To get the exact gain and offset numbers, two-point temperature calibration is recommended. # 13.3 Analog-to-Digital Converter Resources Many useful resources are provided on the main product page of the Microchip website for the devices listed in this data sheet. This product page contains the latest updates and additional information. #### 13.3.1 Differential-Mode ANNx negative external inputs are used for Differential-mode as shown in Figure 13-2. To enable Differential-mode, the DIFF bit (in the ADMODxL or ADMODxH register) is set for the corresponding channel. ## 13.3.2 Key Resources - "12-Bit High-Speed, Multiple SARs A/D Converter (ADC)" - (www.microchip.com/DS70005213) in the "dsPIC33/PIC24 Family Reference Manual" - · Code Samples - Application Notes - Software Libraries - Webinars - · All Related "dsPIC33/PIC24 Family Reference Manual" Sections - · Development Tools # 13.4 ADC Control Registers | Modeling | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------------------------|----------|-----------------|-----------------------------------------|---------|---------|----------|----------|--------------|---------|--| | 15.8 | | 1-7-2000 | 15:8 | ADON | | ADSIDL | | | | | | | | Mode | 0x0B00 | ADCON1L | 7:0 | | | | | | | | | | | FORM | | i graditimi | 15:8 | | | | | | | | | | | Decoration De | 0x0B02 | ADCON1H | 7:0 | FORM | SHRRI | ES[1:0] | | | | | | | | 16.6 | 00004 | ADCONOL | 15:8 | REFCIE | REFERCIE | | EIEN | PTGEN | | SHREISEL[2:0 | ] | | | Decided ACCON21 | UXUBU4 | ADCONZL | 7:0 | | - | | | | | | | | | Note | OVODOG | ADCONOLI | 15:8 | REFRDY | REFERR | | | | | SHRSA | MC[9:8] | | | ADCONSI | UXUBUU | ADCONZH | 7:0 | | | | SHRSA | MC[7:0] | | | | | | March Mar | 0~000 | ADCONSI | 15:8 | | REFSEL[2:0] | | SUSPEND | SUSPCIE | SUSPRDY | SHRSAMP | CNVRTCH | | | ADCONSIDED ADC | UXUBUU | ADCONSE | 7:0 | SWLCTRG | SWCTRG | | | CNVCH | SEL[5:0] | | | | | 15.8 CEN | OVODOA | VDCON3H | 15:8 | CLKS | EL[1:0] | | | CLKD | IV[5:0] | | | | | MORBITE MORB | UXUBUA | ADCONSH | 7:0 | SHREN | | | | C3EN | C2EN | C1EN | C0EN | | | 15.8 | OVOROC | ADCONAL | 15:8 | | | | | | Reserv | /ed[3:0] | | | | ADDITION Fig. Caches C | OXOBOC | ADOON4L | 7:0 | | | | | SAMC3EN | SAMC2EN | SAMC1EN | SAMC0EN | | | 15.8 | OVORNE | ADCONAL | 15:8 | | | | | | | | | | | ADMODIL To DIFF3 SIGN3 DIFF2 SIGN2 DIFF1 SIGN1 DIFF0 SIGN1 | OXODOL | ADCOIVALL | 7:0 | C3CF | IS[1:0] | C2CH | HS[1:0] | C1CF | IS[1:0] | C0CF | IS[1:0] | | | No | 0v0B10 | ADMODOL | 15:8 | DIFF7 | 100000000000000000000000000000000000000 | | SIGN6 | DIFF5 | | DIFF4 | SIGN4 | | | ADMODITED Total Diff-11 SigN11 Diff-10 SigN10 Diff-9 SigN9 Diff-8 SigN8 | OXOD TO | ADMODUL | 7:0 | DIFF3 | | DIFF2 | SIGN2 | DIFF1 | SIGN1 | | | | | 15.8 DIFF21 SIGN12 DIFF22 SIGN22 DIFF22 SIGN22 DIFF24 SIGN14 | 0x0B12 | ADMODOH | | DIFF15 | SIGN15 | DIFF14 | SIGN14 | DIFF13 | SIGN13 | DIFF12 | SIGN12 | | | ADMODIT ADMODIT 7.0 DIFF10 SIGN10 DIFF18 SIGN18 DIFF17 SIGN17 DIFF16 SIGN16 | OXOBIZ | ADMODUT | 7:0 | 500 100 11 1510 | | DIFF10 | SIGN10 | DIFF9 | SIGN9 | | SIGN8 | | | No. | 0x0B14 | ADMOD1I | | | SIGN23 | | | | SIGN21 | | SIGN20 | | | No. | OXOBIT | ADIVIOD IL | | DIFF19 | SIGN19 | DIFF18 | SIGN18 | DIFF17 | SIGN17 | DIFF16 | SIGN16 | | | No | 0x0B16 | ADMOD1H | | | | | | | | | | | | Normal | 0,00010 | 7.5 | 7:0 | DIFF27 | SIGN27 | DIFF26 | SIGN26 | DIFF25 | SIGN25 | DIFF24 | SIGN24 | | | 0x0B1F 15.8 IE[15.8] 0x0B22 ADIEH(1) 15.8 IE[27.0] 0x0B22 ADIEH(1) 15.8 IE[27.24] 0x0B24 Reserved IE[23.16] IE[27.24] 0x0B30 ADSTATL(1) 7.0 AN[15.0]RDY 0x0B32 ADSTATL(1) 15.8 AN[27.24]RDY 0x0B34 Reserved AN[27.24]RDY 0x0B37 Reserved AN[27.24]RDY 0x0B37 ADCMP0ENL(1) 15.8 CMPEN[27.24] 0x0B3A ADCMP0ENL(1) 15.8 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 15.8 CMPEN[27:24] 0x0B3C ADCMP0EN 15.8 CMPEN[27:24] 0x0B3E ADCMP0H 15.8 CMPEN[7:0] 0x0B3E ADCMP0H 15.8 CMPEN[7:0] 0x0B40 ADCMP1ENL(1) 15.8 CMPEN[7:0] 0x0B42 ADCMP1ENL(1) 15.8 CMPEN[7:0] 0x0B44 ADCMP1ENL(1) 15.8 CMPEN[27:0] 0x0B44 ADCMP1EN | 0x0B18 | | | | | | | | | | | | | DX0B20 | | Reserved | | | | | | | | | | | | ADEL(1) 7:0 IE[7:0] OX0B22 | 0x0B1F | | | | | | | | | | | | | DX0B22 ADIEH(1) 15:8 | 0x0B20 | ADIEL(1) | | | | | | | | | | | | 0x0B22 ADIEH(1) 7:0 IE[23:16] 0x0B24 Reserved AN[15:0]RDY 0x0B30 ADSTATL(1) 15:8 AN[15:0]RDY 0x0B32 ADSTATH(1) 15:8 AN[27:24]RDY 0x0B34 T:0 AN[23:16]RDY 0x0B37 CMPEN[15:8] CMPEN[7:0] 0x0B38 ADCMP0ENL(1) 7:0 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPLO[15:8] 0x0B3E ADCMP0LO 15:8 CMPHI[15:8] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1ENL(1) 7:0 CMPEN[7:0] 0x0B44 ADCMP1H(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1LO 15:8 CMPEN[23:16] 0x0B44 ADCMP1LO 15:8 CMPEN[23:16] | | 2,11-22-0.1-11 | | | | | IEĮ | 7:0] | ıFro | 7.041 | | | | 0x0824<br>Reserved 15.8 AN[15.0]RDY 0x0830<br>0x0832 ADSTATL(1)<br>ADSTATH(1) 15.8<br>7.0 AN[25.0]RDY 0x0834<br><br>0x0837 Reserved AN[27.24]RDY 0x0834<br><br>0x0838 Reserved ADCMPOENL(1)<br>7.0 15.8<br>CMPEN[7:0] 0x083A<br>ADCMPOENH(1)<br>7:0 15.8<br>CMPEN[27:24] CMPEN[27:24] 0x083C<br>ADCMPOLO 15.8<br>ADCMPOLO CMPLO[7:0]<br>T5.8<br>T7.0 CMPLO[7:0]<br>CMPHI[7:0] 0x0840<br>ADCMP1ENL(1) 15.8<br>T7.0<br>ADCMP1ENL(1) CMPEN[27:24]<br>T5.8<br>T7.0<br>CMPEN[7:0] CMPEN[27:24]<br>CMPEN[27:24] 0x0844<br>ADCMP1ENL(1) 15.8<br>T7.0<br>CMPEN[27:24] CMPEN[27:24]<br>T7.0<br>CMPEN[23:16] 0x0844<br>ADCMP1ENL(1) 15.8<br>T7.0<br>CMPEN[23:16] CMPEN[27:24]<br>T7.0<br>CMPEN[23:16] | 0x0B22 | ADIEH(1) | | | | | | | | | | | | Normal N | 00004 | | 7:0 | | | | IE[2 | 3:16] | | | | | | 0x0B2F 15:8 AN[15:0]RDY 0x0B30 ADSTATL(1) 15:8 AN[15:0]RDY 0x0B32 ADSTATH(1) 15:8 AN[27:24]RDY 0x0B34 Reserved AN[27:24]RDY 0x0B37 ADCMPOENL(1) 15:8 CMPEN[15:8] 0x0B38 ADCMPOENL(1) 15:8 CMPEN[7:0] 0x0B3A ADCMPOENH(1) 7:0 CMPEN[27:24] 0x0B3C ADCMPOLO 15:8 CMPLO[15:8] 0x0B3E ADCMPOLO 15:8 CMPLO[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1ENL(1) 15:8 CMPEN[27:24] 0x0B45 ADCMP1ENL(1) 15:8 CMPEN[27:24] 0x0B45 ADCMP1ENL(1) 15:8 CMPEN[27:24] | UXUB24 | Bosoniod | | | | | | | | | | | | 0x0B30 ADSTATL(1) 15:8 AN[15:0]RDY 0x0B32 ADSTATH(1) 15:8 AN[27:24]RDY 0x0B34 Reserved AN[23:16]RDY 0x0B37 Feserved CMPEN[15:8] 0x0B38 ADCMP0ENL(1) 15:8 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 7:0 CMPEN[23:16] 0x0B3C ADCMP0LO 15:8 CMPL0[15:8] 0x0B3E ADCMP0H 15:8 CMPL0[15:8] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1ENL(1) 15:8 CMPEN[23:16] 0x0B44 ADCMP1ENL(1) 15:8 CMPEN[23:16] 0x0B44 ADCMP1ENL(1) 15:8 CMPEN[23:16] | <br>0v0B2E | iteserveu | | | | | | | | | | | | ADSTATL(1) 7:0 AN[15:0]RDY 0x0B32 ADSTATH(1) 15:8 AN[27:24]RDY 0x0B34 Reserved AN[23:16]RDY 0x0B37 CMPEN[15:8] CMPEN[15:8] 0x0B38 ADCMP0ENL(1) 15:8 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPLO[7:0] 0x0B3E ADCMP0H 15:8 CMPHI[15:8] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1O 15:8 CMPEN[27:24] 0x0B44 ADCMP1O 15:8 CMPEN[23:16] 0x0B45 ADCMP1O 15:8 CMPEN[23:16] 0x0B44 ADCMP1O 15:8 CMPLO[15:8] | UXUDZI | | 15:8 | | | | ΔΝΙ15 | ·OIRDY | | | | | | 0x0B32 ADSTATH(1) 15:8 AN[27:24]RDY 0x0B34<br><br>0x0B37 Reserved ADCMP0ENL(1) 15:8 CMPEN[15:8] 0x0B38 ADCMP0ENL(1) 15:8 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPLO[15:8] 0x0B3E ADCMP0HI 15:8 CMPLO[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[15:8] 0x0B42 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1LO 15:8 CMPEN[23:16] 0x0B44 ADCMP1LO 15:8 CMPLO[15:8] | 0x0B30 | ADSTATL(1) | | | | | | | | | | | | 0x0832 ADSTATH(1) 7:0 AN[23:16]RDY 0x0834 Reserved CMPEN[15:8] 0x0838 ADCMP0ENL(1) 15:8 CMPEN[7:0] 0x083A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x083C ADCMP0LO 15:8 CMPLO[15:8] 0x083E ADCMP0HI 15:8 CMPLO[7:0] 0x0840 ADCMP1ENL(1) 15:8 CMPEN[15:8] 0x0842 ADCMP1ENH(1) 15:8 CMPEN[27:24] 0x0844 ADCMP1I O 15:8 CMPEN[23:16] 0x0844 ADCMP1I O 15:8 CMPLO[15:8] | | | | | | | 74410 | .ojrto i | ANI27 | 241RDY | | | | 0x0B34 Reserved CMPEN[15:8] 0x0B38 ADCMP0ENL(1) 7:0 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 7:0 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPL0[15:8] 0x0B3C ADCMP0LO 7:0 CMPL0[7:0] 0x0B3E ADCMP0HI 7:0 CMPHI[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[15:8] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[27:24] 0x0B44 ADCMP1LO 15:8 CMPEN[23:16] 0x0B44 ADCMP1LO 15:8 CMPL0[15:8] | 0x0B32 | ADSTATH(1) | | | | | ANI23 | 161RDY | 7111/27 | - 1,112 i | | | | Reserved CMPEN[15:8] 0x0B38 ADCMP0ENL(1) 15:8 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[23:16] 0x0B3C ADCMP0LO 15:8 CMPLO[15:8] 0x0B3E ADCMP0H 15:8 CMPHI[15:8] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1I O 15:8 CMPEN[23:16] 0x0B44 ADCMP1I O 15:8 CMPLO[15:8] | 0x0B34 | | | | | | 7[25. | , opine | | | | | | 0x0B37 ADCMP0ENL(1) 15:8 CMPEN[15:8] 0x0B38 ADCMP0ENL(1) 15:8 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPLO[15:8] 0x0B3E ADCMP0H 15:8 CMPLO[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[15:8] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1LO 15:8 CMPEN[27:24] 0x0B44 ADCMP1LO 15:8 CMPLO[15:8] | | Reserved | | | | | | | | | | | | OXOB38 ADCMPOENL(1) 7:0 CMPEN[7:0] 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPLO[15:8] 0x0B3E ADCMP0LO 7:0 CMPLO[7:0] 0x0B3E ADCMP0HI 15:8 CMPHI[15:8] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[27:24] 0x0B44 ADCMP1LO 15:8 CMPLO[15:8] | | | | | | | | | | | | | | 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPLO[15:8] 0x0B3E ADCMP0H 15:8 CMPLO[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPHI[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1LO 15:8 CMPEN[27:24] 0x0B44 ADCMP1LO 15:8 CMPLO[15:8] | 0.0000 | 4 D 04 4 D 0 E 1 1 / 4 V | 15:8 | | 1 | 1 | CMPE | N[15:8] | | 16 | | | | 0x0B3A ADCMP0ENH(1) 15:8 CMPEN[27:24] 0x0B3C ADCMP0LO 15:8 CMPL0[15:8] 0x0B3E ADCMP0H 15:8 CMPL0[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPHI[15:8] 0x0B42 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1LO 15:8 CMPEN[27:24] 0x0B44 ADCMP1LO 15:8 CMPL0[15:8] | 0x0B38 | ADCMP0ENL(1) | 7:0 | | | | CMPE | EN[7:0] | | | | | | 0x0B3C ADCMP0LO 15:8 CMPL0[15:8] 0x0B3E ADCMP0HI 15:8 CMPL0[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPHI[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1ENH(1) 15:8 CMPEN[27:24] 0x0B44 ADCMP1I O 15:8 CMPL0[15:8] | 0.0004 | A D CAMPOEN WAY | 15:8 | | | | | | CMPE | N[27:24] | | | | 0X0B3C ADCMP0LO 7:0 CMPLO[7:0] 0X0B3E ADCMP0HI 15:8 CMPHI[15:8] 0X0B40 ADCMP1ENL(1) 15:8 CMPEN[15:8] 0X0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0X0B44 ADCMP1ENH(1) 15:8 CMPEN[23:16] 0X0B44 ADCMP1I O 15:8 CMPLO[15:8] | 0X0B3A | ADCMP0ENH(1) | 7:0 | | | | CMPE | N[23:16] | | | | | | 0x0B3E ADCMP0HI 15:8 CMPLIG[7:0] 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0x0B44 ADCMP1ENH(1) 15:8 CMPEN[27:24] 0x0B44 ADCMP1I O 15:8 CMPLO[15:8] | 0.0000 | A D CMADOL C | 15:8 | | | | CMPL | O[15:8] | | | | | | 0X0B3E ADCMP0HI 7:0 CMPHI[7:0] 0X0B40 ADCMP1ENL(1) 15:8 CMPEN[15:8] 0X0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0X0B42 ADCMP1ENH(1) 7:0 CMPEN[23:16] 0X0B44 ADCMP1LO 15:8 CMPLO[15:8] | OXOB3C | ADCMPOLO | 7:0 | | | | CMPL | _O[7:0] | | | | | | 0x0B40 ADCMP1ENL(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[7:0] 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[27:24] 0x0B44 ADCMP1I O 15:8 CMPLO[15:8] | 0,000 | ADCMEDIU | 15:8 | | | | CMPH | HI[15:8] | | | | | | 0x0B40 ADCMP1ENL(1) 7:0 CMPEN[7:0] 0x0B42 ADCMP1ENH(1) 7:0 CMPEN[27:24] 7:0 CMPEN[27:24] 7:0 CMPEN[23:16] 0x0B44 ADCMP1LO 15:8 CMPLO[15:8] | 0X0B3E | ADCMPOHI | 7:0 | | | | CMPI | HI[7:0] | | | | | | 0x0B42 ADCMP1ENH(1) 15:8 CMPEN[27:24] 0x0B44 ADCMP1 O 15:8 CMPL0[15:8] | 0.00.40 | ADOMD4ENI (4) | 15:8 | | | | CMPE | N[15:8] | | | | | | 0X0B42 ADCMP1ENH(1) 7:0 CMPEN[23:16] 0x0B44 ADCMP1LO 15:8 CMPLO[15:8] | UXUB4U | ADCIVIPTENL(1) | 7:0 | | | | СМРЕ | EN[7:0] | | | | | | 7:0 CMPEN[23:16] 0x0B44 ADCMP11 0 15:8 CMPL0[15:8] | 0,000.40 | ADCMD4ENUMAN | 15:8 | | | | | | CMPE | N[27:24] | | | | OVOR44 ADCMP110 | UXUB42 | ADCINIPTENH(1) | 7:0 | | | | CMPE | N[23:16] | | | | | | VAUD44 ALCOVE II V | 0v0044 | ADCMP4LO | 15:8 | | | | CMPL | O[15:8] | | | | | | 7:0 CMPLO[7:0] | UXUB44 | ADOMPTEO | 7:0 | | | | CMPL | .O[7:0] | | | | | | | inal | | | | | | | |---------------------------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------|--------|-----------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | cont | | | | | | | | | Offset | Name | Bit Pos. | 7 | 6 5 | 4 3 | 2 1 | 0 | | 0x0B46 | ADCMP1HI | 15:8 | | | CMPHI[15:8] | | | | | | 7:0 | | | CMPHI[7:0] | | | | 0x0B48 | ADCMP2ENL(1) | 15:8 | | | CMPEN[15:8] | | | | | | 7:0<br>15:8 | | | CMPEN[7:0] | CMPEN[27:24] | | | 0x0B4A | ADCMP2ENH(1) | 7:0 | | | CMPEN[23:16] | CIVIPEIN[21.24] | | | | | 15:8 | | | CMPLO[15:8] | | | | 0x0B4C | ADCMP2LO | 7:0 | | | CMPLO[7:0] | | | | | 10.000000000000000000000000000000000000 | 15:8 | | | CMPHI[15:8] | | | | 0x0B4E | ADCMP2HI | 7:0 | | | CMPHI[7:0] | | | | 00050 | ADOMPOENI (4) | 15:8 | | | CMPEN[15:8] | | | | 0x0B50 | ADCMP3ENL(1) | 7:0 | | | CMPEN[7:0] | | | | 0x0B52 | ADCMP3ENH(1) | 15:8 | | | | CMPEN[27:24] | | | UXUBJZ | ADCIMPSEINH(1) | 7:0 | | | CMPEN[23:16] | | | | 0x0B54 | ADCMP3LO | 15:8 | | | CMPLO[15:8] | | | | OXOBO I | ADOMI SES | 7:0 | | | CMPLO[7:0] | | | | 0x0B56 | ADCMP3HI | 15:8 | | | CMPHI[15:8] | | | | 100 | 7.000,111 | 7:0 | | | CMPHI[7:0] | | | | 0x0B58 | | | | | | | | | <br>0x0B67 | Reserved | | | | | | | | UXUDU1 | | 15:8 | | | FLDATA[15:8] | | | | 0x0B68 | ADFL0DAT | 7:0 | | | FLDATA[7:0] | | | | | | 15:8 | FLEN | MODE[1:0] | OVRSAM[2: | 0] IE | RDY | | 0x0B6A | ADFLXCON | 7:0 | , LLIV | MOBE[1.0] | O VI TO TIME 2. | FLCHSEL[4:0] | TID! | | | CAR SURCESSES | 15:8 | | | FLDATA[15:8] | | | | 0x0B6C | ADFL1DAT | 7:0 | | | FLDATA[7:0] | | | | 0x0B6E | | | | | | | | | | Reserved | | | | | | | | 0x0B6F | | | | | | | | | 0x0B70 | ADFL2DAT | 15:8 | | | FLDATA[15:8] | | | | | | 7:0 | 1 | | FLDATA[7:0] | 1 | 1 | | 0x0B72 | December | | | | | | | | <br>0x0B73 | Reserved | | | | | | | | 0,0073 | | 15:8 | | | FLDATA[15:8] | | | | 0x0B74 | ADFL3DAT | 7:0 | | | FLDATA[7:0] | | | | 0x0B76 | | | | | , | | | | | Reserved | | | | | | | | 0x0B7F | | | | | | | | | 0x0B80 | ADTRIG0L | 15:8 | | | | TRGSRC1[4:0] | | | OVODOO | ADTRIGUE | 7:0 | | | | TRGSRC0[4:0] | | | | | | | | | TRGSRC3[4:0] | | | 0x0B82 ADTRIG0H | | 15:8 | | | | | | | 0x0B82 | ADTRIG0H | 7:0 | | | | TRGSRC2[4:0] | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 7:0<br>15:8 | | | | TRGSRC5[4:0] | | | | ADTRIG0H ADTRIG1L | 7:0<br>15:8<br>7:0 | | | | TRGSRC5[4:0]<br>TRGSRC4[4:0] | | | 0x0B84 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 7:0<br>15:8<br>7:0<br>15:8 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] | | | 0x0B84 | ADTRIG1L | 7:0<br>15:8<br>7:0<br>15:8<br>7:0 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] | | | 0x0B84<br>0x0B86 | ADTRIG1L | 7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] | | | 0x0B84<br>0x0B86 | ADTRIG1L ADTRIG1H | 7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] TRGSRC8[4:0] | | | 0x0B84<br>0x0B86<br>0x0B88 | ADTRIG1L ADTRIG1H | 7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] TRGSRC8[4:0] TRGSRC8[4:0] | | | 0x0B84<br>0x0B86<br>0x0B88 | ADTRIG1L ADTRIG1H ADTRIG2L | 7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] TRGSRC8[4:0] TRGSRC8[4:0] TRGSRC11[4:0] TRGSRC10[4:0] | | | 0x0B84<br>0x0B86<br>0x0B88<br>0x0B8A | ADTRIG1L ADTRIG1H ADTRIG2L | 7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] TRGSRC8[4:0] TRGSRC8[4:0] TRGSRC11[4:0] TRGSRC10[4:0] TRGSRC10[4:0] | | | 0x0B84 0x0B86 0x0B88 0x0B8A 0x0B8C | ADTRIG1L ADTRIG1H ADTRIG2L ADTRIG2H | 7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] TRGSRC8[4:0] TRGSRC8[4:0] TRGSRC11[4:0] TRGSRC10[4:0] TRGSRC10[4:0] TRGSRC12[4:0] | | | 0x0B84 0x0B86 0x0B88 0x0B8A 0x0B8C | ADTRIG1L ADTRIG1H ADTRIG2L ADTRIG2H | 7:0 15:8 7:0 15:8 7:0 15:8 7:0 15:8 7:0 15:8 7:0 15:8 7:0 15:8 7:0 15:8 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] TRGSRC8[4:0] TRGSRC8[4:0] TRGSRC11[4:0] TRGSRC10[4:0] TRGSRC10[4:0] TRGSRC12[4:0] TRGSRC12[4:0] TRGSRC15[4:0] | | | 0x0B82 0x0B84 0x0B86 0x0B88 0x0B8A 0x0B8C 0x0B8E 0x0B90 | ADTRIG1L ADTRIG1H ADTRIG2L ADTRIG2H ADTRIG3L | 7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0<br>15:8<br>7:0 | | | | TRGSRC5[4:0] TRGSRC4[4:0] TRGSRC7[4:0] TRGSRC6[4:0] TRGSRC9[4:0] TRGSRC8[4:0] TRGSRC8[4:0] TRGSRC11[4:0] TRGSRC10[4:0] TRGSRC10[4:0] TRGSRC12[4:0] | | | conti | | | | - | | | | | | | |------------|--------------------------|-------------|-----------------------------------------|----|--------------|--------------------------------|-------------------------|-----------------------------------------|--------------|------------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0B92 | ADTRIG4H | 15:8<br>7:0 | | | | | | TRGSRC19[4:0]<br>TRGSRC18[4:0] | | | | 0x0B94 | ADTRIG5L | 15:8<br>7:0 | | | | TRGSRC21[4:0]<br>TRGSRC20[4:0] | | | | | | 0x0B96<br> | Reserved | | | | | | | | | | | 0x0B9F | | | | | | | | | | | | 0x0BA0 | ADCMP0CON | 15:8<br>7:0 | CMPEN | IE | STAT | BTWN | HIHI | CHNL[4:0]<br>HILO | LOHI | LOLO | | 0x0BA2<br> | Reserved | | | | | | | | | | | 0x0BA3 | | | | | | | | | | | | 0x0BA4 | ADCMP1CON | 15:8<br>7:0 | CMPEN | IE | STAT | BTWN | HIHI | CHNL[4:0]<br>HILO | LOHI | LOLO | | 0x0BA6<br> | Reserved | | | | | | | | | | | 0x0BA7 | | 45.0 | | | | | | 011111111111111111111111111111111111111 | | | | 0x0BA8 | ADCMP2CON | 15:8<br>7:0 | CMPEN | IE | STAT | BTWN | HIHI | CHNL[4:0]<br>HILO | LOHI | LOLO | | 0x0BAA<br> | Reserved | | 150000000000000000000000000000000000000 | | 3.9720-00-00 | 7 VA - GK (8550) KG | 5 88750 | 10.1110.00 | Sarvaga (Na) | S 1000 JAN | | 0x0BAB | | 45.0 | | | | | | 011111111111111111111111111111111111111 | | | | 0x0BAC | ADCMP3CON | 15:8<br>7:0 | CMPEN | IE | STAT | BTWN | HIHI | CHNL[4:0]<br>HILO | LOHI | LOLO | | 0x0BAE<br> | Reserved | | | | | | | | | | | 0x0BCF | | 15:8 | | | | LVLEN | JI(15:01 | | | | | 0x0BD0 | ADLVLTRGL | 7:0 | | | | LVLE | | | | | | 0x0BD2 | ADLVLTRGH | 15:8<br>7:0 | | | | LVLEN | [23:16] | LVLEN[ | 27:24] | | | 0x0BD4 | ADCORE0L | 15:8<br>7:0 | | | | SAM | C(7:0) | | SAM | C[9:8] | | 0x0BD6 | ADCORE0H | 15:8 | | | | 071111 | EISEL[2:0] | | RES | B[1:0] | | 0,,0000 | ADCOREAL | 7:0<br>15:8 | | | | | ADCS[6:0] | | SAM | C[9:8] | | 0x0BD8 | ADCORE1L | 7:0 | | | | SAM | | | | | | 0x0BDA | ADCORE1H | 15:8<br>7:0 | | | | | EISEL[2:0]<br>ADCS[6:0] | | RES | S[1:0] | | 0x0BDC | ADCORE2L | 15:8 | | | | CANA | | | SAM | C[9:8] | | | No. of the second second | 7:0<br>15:8 | | | | SAM | C[7:0]<br>EISEL[2:0] | | RES | S[1:0] | | 0x0BDE | ADCORE2H | 7:0 | | | | | ADCS[6:0] | | | | | 0x0BE0 | ADCORE3L | 15:8<br>7:0 | | | | SAM | C[7:0] | | SAM | C[9:8] | | 0x0BE2 | ADCORE3H | 15:8<br>7:0 | | | | | EISEL[2:0]<br>ADCS[6:0] | | RES | [1:0] | | 0x0BE4 | | 7.0 | | | | | , 12 3 0 [0.0] | | | | | 0x0BEF | Reserved | | | | | | | | | | | 0x0BF0 | ADEIEL | 15:8<br>7:0 | | | | EIEN | [15:8]<br>I[7:0] | | | | | 0x0BF2 | ADEIEH | 15:8 | | | | | | EIEN[2 | 27:24] | | | 0x0BF4 | n suspension | 7:0 | | | | EIEN[ | 23:16] | | | | | <br>0x0BF7 | Reserved | | | | | | | | | | | 0x0BF8 | ADEISTATL | 15:8 | | | | | T[15:8] | | | | | UNUDF0 | ADEIGIAIL | 7:0 | | | | EISTA | AT[7:0] | | | | | conti | nued | | | | | | | | | | |--------|-----------------------------------------|-------------|--------|---|---|-------|-------------------------|-------|----------|-------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0BFA | ADEISTATH | 15:8 | | | | | | EISTA | Γ[27:24] | | | | ADEIGIAITI | 7:0 | | | | EISTA | T[23:16] | | | | | 0x0BFC | Reserved | | | | | | | | | | | 0x0BFF | Reserved | | | | | | | | | | | | | 15:8 | SHRRDY | | | | C3RDY | C2RDY | C1RDY | CORDY | | 0x0C00 | ADCON5L | 7:0 | SHRPWR | | | | C3PWR | C2PWR | C1PWR | C0PWR | | 0x0C02 | ADCON5H | 15:8 | | | | | | | IME[3:0] | | | | 7.555.16.1 | 7:0 | SHRCIE | | | | C3CIE | C2CIE | C1CIE | COCIE | | 0x0C04 | Reserved | | | | | | | | | | | 0x0C0B | Reserved | | | | | | | | | | | | 40001150 | 15:8 | | | | ADCBL | JF0[15:8] | | | | | 0x0C0C | ADCBUF0 | 7:0 | | | | ADCBU | JF0[7:0] | | | | | 0x0C0E | ADCBUF1 | 15:8 | | | | | JF1[15:8] | | | | | CAUCUL | ADODOI I | 7:0 | | | | | JF1[7:0] | | | | | 0x0C10 | ADCBUF2 | 15:8 | | | | | JF2[15:8] | | | | | | ADOBOLZ | 7:0 | | | | | JF2[7:0] | | | | | 0x0C12 | ADCBUF3 | 15:8 | | | | | IF3[15:8] | | | | | | | 7:0 | | | | | JF3[7:0] | | | | | 0x0C14 | ADCBUF4 | 15:8<br>7:0 | | | | | JF4[15:8]<br>JF4[7:0] | | | | | | | 15:8 | | | | | JF4[7.0]<br>JF5[15:8] | | | | | 0x0C16 | ADCBUF5 | 7:0 | | | | | JF5[7:0] | | | | | | ADCBUF6 | 15:8 | | | | | JF6[15:8] | | | | | 0x0C18 | | 7:0 | | | | | JF6[7:0] | | | | | | | 15:8 | | | | | JF7[15:8] | | | | | 0x0C1A | ADCBUF7 | 7:0 | | | | ADCBU | JF7[7:0] | | | | | 0x0C1C | ADCBUF8 | 15:8 | | | | ADCBU | JF8[15:8] | | | | | UXUCTC | ADCBUF6 | 7.0 | | | | | JF8[7.0] | | | | | 0x0C1E | ADCBUF9 | 15:8 | | | | | IF9[15:8] | | | | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 7:0 | | | | | JF9[7:0] | | | | | 0x0C20 | ADCBUF10 | 15:8 | | | | | F10[15:8] | | | | | | reactive via | 7:0 | | | | | JF10[7:0] | | | | | 0x0C22 | ADCBUF11 | 15:8<br>7:0 | | | | | F11[15:8]<br>JF11[7:0] | | | | | | | 15:8 | | | | | F12[15:8] | | | | | 0x0C24 | ADCBUF12 | 7:0 | | | | | JF12[7:0] | | | | | | | 15:8 | | | | | F13[15:8] | | | | | 0x0C26 | ADCBUF13 | 7:0 | | | | | IF13[7:0] | | | | | 0,000 | ADODUE14 | 15:8 | | | | | F14[15:8] | | | | | 0x0C28 | ADCBUF14 | 7:0 | | | | | JF14[7:0] | | | | | 0x0C2A | ADCBUF15 | 15:8 | | | | ADCBU | F15[15:8] | | | | | DAUUZA | ADODOFIO | 7:0 | | | | | JF15[7:0] | | | | | 0x0C2C | ADCBUF16 | 15:8 | | | | | F16[15:8] | | | | | | | 7:0 | | | | | JF16[7:0] | | | | | 0x0C2E | ADCBUF17 | 15:8 | | | | | F17[15:8] | | | | | | | 7:0<br>15:8 | | | | | JF17[7:0]<br>F18[15:8] | | | | | 0x0C30 | ADCBUF18 | 7:0 | | | | | F 16[13.6]<br>JF18[7:0] | | | | | | | 15:8 | | | | | F19[15:8] | | | | | 0x0C32 | ADCBUF19 | 7:0 | | | | | JF19[7:0] | | | | | | | 15:8 | | | | | F20[15:8] | | | | | 0x0C34 | ADCBUF20 | 7:0 | | | | | JF20[7:0] | | | | | 0,0000 | ADODUEOA | 15:8 | | | | | F21[15:8] | | | | | 0x0C36 | ADCBUF21 | 7:0 | | | | | JF21[7:0] | | | | # High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.1 ADC Control Register 1 Low Name: ADCON1L Offset: 0xB00 #### Note: 1. Set the ADON bit only after the ADC module has been configured. Changing ADC Configuration bits when ADON = 1 will result in unpredictable behavior. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|----|--------|----|----|----|---|---| | | ADON | | ADSIDL | | | | | | | Access | R/W | | R/W | | | | | | | Reset | 0 | | 0 | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset # Bit 15 - ADON ADC Enable bit(1) | Value | Description | |-------|-----------------------| | 1 | ADC module is enabled | | 0 | ADC module is off | ### Bit 13 - ADSIDL ADC Stop in Idle Mode bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation in Idle mode | High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.2 ADC Control Register 1 High Name: ADCON1H Offset: 0xB02 ### Bit 7 - FORM Fractional Data Output Format bit | Value | Description | |-------|-------------| | 1 | Fractional | | 0 | Integer | # Bits 6:5 - SHRRES[1:0] Shared ADC Core Resolution Selection bits | Value | Description | |-------|-------------------| | 11 | 12-bit resolution | | 10 | 10-bit resolution | | 01 | 8-bit resolution | | 00 | 6-bit resolution | # High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.3 ADC Control Register 2 Low Name: ADCON2L Offset: 0xB04 #### Note: 1. For the 6-bit shared ADC core resolution (SHRRES[1:0] = 00), the SHREISEL[2:0] settings, from '100' to '111', are not valid and should not be used. For the 8-bit shared ADC core resolution (SHRRES[1:0] = 01), the SHREISEL[2:0] settings, '110' and '111', are not valid and should not be used. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----------|-----|------|--------------|-----|---------------|-----| | | REFCIE | REFERCIE | | EIEN | PTGEN | | SHREISEL[2:0] | | | Access | R/W | R/W | | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | SHRADCS[6:0] | | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - REFCIE Band Gap and Reference Voltage Ready Common Interrupt Enable bit | Value | Description | |-------|--------------------------------------------------------------------| | 1 | Common interrupt will be generated when the band gap becomes ready | | 0 | Common interrupt is disabled for the band gap ready event | #### Bit 14 - REFERCIE Band Gap or Reference Voltage Error Common Interrupt Enable bit | Value | Description | |-------|-------------------------------------------------------------------------------------------| | 1 | Common interrupt will be generated when a band gap or reference voltage error is detected | | 0 | Common interrupt is disabled for the band gap and reference voltage error event | ## Bit 12 - EIEN Early Interrupts Enable bit | Value | Description | |-------|--------------------------------------------------------------------------------------------| | 1 | Early interrupt feature is enabled for input channel interrupts (when EISTATx flag is set) | | 0 | Individual interrupts are generated when conversion is done (when ANxRDY flag is set) | ### Bit 11 - PTGEN External Conversion Request Interface bit Setting this bit will enable the PTG to request conversion of an ADC input. ### Bits 10:8 - SHREISEL[2:0] Shared Core Early Interrupt Time Selection bits<sup>(1)</sup> | Value | Description | |-------|-----------------------------------------------------------------------------------------------------------------| | 111 | Early interrupt is set, interrupt is generated eight T <sub>ADCORE</sub> clocks prior to when data are ready | | 110 | Early interrupt is set, interrupt is generated seven T <sub>ADCORE</sub> clocks prior to when data are ready | | 101 | Early interrupt is set, interrupt is generated six T <sub>ADCORE</sub> clocks prior to when data are ready | | 100 | Early interrupt is set, interrupt is generated five T <sub>ADCORE</sub> clocks prior to when the data are ready | | 011 | Early interrupt is set, interrupt is generated four T <sub>ADCORE</sub> clocks prior to when data are ready | | 010 | Early interrupt is set, interrupt is generated three T <sub>ADCORE</sub> clocks prior to when data are ready | | 001 | Early interrupt is set, interrupt is generated two T <sub>ADCORE</sub> clocks prior to when data are ready | | 000 | Early interrupt is set, interrupt is generated one T <sub>ADCORE</sub> clock prior to when data are ready | #### Bits 6:0 - SHRADCS[6:0] Shared ADC Core Input Clock Divider bits These bits determine the number of T<sub>CORESRC</sub> (Source Clock Periods) for one shared T<sub>ADCORE</sub> (Core Clock Period). | | OUNEONO / ADOUNE ( / | |---------|--------------------------| | Value | Description | | 1111111 | 254 Source Clock Periods | | | | | 0000011 | 6 Source Clock Periods | | 0000010 | 4 Source Clock Periods | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 552 | Value | Description | |---------|------------------------| | 0000001 | 2 Source Clock Periods | | 0000000 | 2 Source Clock Periods | # 13.4.4 ADC Control Register 2 High Name: ADCON2H Offset: 0xB06 Legend: HSC = Hardware Settable/Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|-----|-------|---------|-----|-------|---------| | | REFRDY | REFERR | | | | | SHRSA | MC[9:8] | | Access | HSC/R | HSC/R | | | | | R/W | R/W | | Reset | 0 | 0 | | | | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | SHRSA | MC[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - REFRDY Band Gap and Reference Voltage Ready Flag bit | Value | Description | |-------|-----------------------| | 1 | Band gap is ready | | 0 | Band gap is not ready | ### Bit 14 - REFERR Band Gap or Reference Voltage Error Flag bit | Value | Description | |-------|------------------------------------------------------------------| | 1 | Band gap was removed after the ADC module was enabled (ADON = 1) | | 0 | No band gap error was detected | #### Bits 9:0 - SHRSAMC[9:0] Shared ADC Core Sample Time Selection bits These bits specify the number of shared ADC Core Clock Periods ( $T_{ADCORE}$ ) for the shared ADC core sample time (Sample Time = (SHRSAMC[9:0] + 2) \* $T_{ADCORE}$ ). | (Sumple Time (Strike, integrit) | 'ADCORE/ | |---------------------------------|--------------------------| | Value | Description | | 111111111 | 1025 T <sub>ADCORE</sub> | | | | | 000000001 | 3 T <sub>ADCORE</sub> | | 000000000 | 2 T <sub>ADCORE</sub> | ### 13.4.5 ADC Control Register 3 Low Name: ADCON3L Offset: 0xB08 Legend: HSC = Hardware Settable/Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------------------------|-------|-----|---------|---------|----------|---------|---------| | | REFSEL[2:0] | | | SUSPEND | SUSPCIE | SUSPRDY | SHRSAMP | CNVRTCH | | Access | R/W | R/W | R/W | R/W | R/W | HSC/R | R/W | HSC/R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SWLCTRG SWCTRG CNVCHSEL[5:0] | | | | | SEL[5:0] | | | | Access | R/W | HSC/R | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bits 15:13 - REFSEL[2:0] ADC Reference Voltage Selection bits | Value | V <sub>REFH</sub> | V <sub>REFL</sub> | |---------|-------------------|-------------------| | 001-111 | Unimplemen | ited: Do not use | | 000 | $AV_DD$ | AV <sub>SS</sub> | #### Bit 12 - SUSPEND All ADC Core Triggers Disable bit | Value | Description | |-------|------------------------------------------------------| | 1 | All new trigger events for the ADC core are disabled | | 0 | The ADC core can be triggered | ## Bit 11 - SUSPCIE Suspend All ADC Cores Common Interrupt Enable bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------| | 1 | Common interrupt will be generated when ADC core triggers are suspended (SUSPEND bit = 1) and | | | all previous conversions are finished (SUSPRDY bit becomes set) | | 0 | Common interrupt is not generated for suspend ADC cores event | #### Bit 10 - SUSPRDY ADC Core Suspended Flag bit | Value | Description | |-------|--------------------------------------------------------------------------------| | 1 | The ADC core is suspended (SUSPEND bit = 1) and has no conversions in progress | | 0 | The ADC core has previous conversions in progress | ### Bit 9 - SHRSAMP Shared ADC Core Sampling Direct Control bit This bit should be used with the individual channel conversion trigger controlled by the CNVRTCH bit. It connects an analog input, specified by the CNVCHSEL[5:0] bits, to the shared ADC core and allows extending the sampling time. This bit is not controlled by hardware and must be cleared before the conversion starts (setting CNVRTCH to '1'). | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Shared ADC core samples an analog input specified by the CNVCHSEL[5:0] bits | | 0 | Sampling is controlled by the shared ADC core hardware | ## Bit 8 - CNVRTCH Software Individual Channel Conversion Trigger bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 1 | Single trigger is generated for an analog input specified by the CNVCHSEL[5:0] bits; when the bit is | | | set, it is automatically cleared by hardware on the next instruction cycle | | 0 | Next individual channel conversion trigger can be generated | # Bit 7 - SWLCTRG Software Level-Sensitive Common Trigger bit # High-Speed, 12-Bit Analog-to-Digital Convert... | Value | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Triggers are continuously generated for all channels with the software; level-sensitive common trigger selected as a source in the ADTRIGNL and ADTRIGXH registers | | 0 | No software, level-sensitive common triggers are generated | # Bit 6 - SWCTRG Software Common Trigger bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------------| | 1 | Single trigger is generated for all channels with the software; common trigger selected as a source in | | | the ADTRIGnL and ADTRIGxH registers; when the bit is set, it is automatically cleared by hardware on | | | the next instruction cycle | | 0 | Ready to generate the next software common trigger | **Bits 5:0 – CNVCHSEL[5:0]** Channel No. Selection for Software Individual Channel Conv. Trigger bits These bits define a channel to be converted when the CNVRTCH bit is set. # High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.6 ADC Control Register 3 High Name: ADCON3H Offset: 0xB0A #### Notes: - 1. The ADC input clock frequency, selected by the CLKSEL[1:0] bits, must not exceed AD67. - 2. The ADC clock frequency, after the first divider selected by the CLKDIV[5:0] bits, must not exceed AD67. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-------------|-----|-----|-------------|------|------|------|------|--| | | CLKSEL[1:0] | | | CLKDIV[5:0] | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | SHREN | | | | C3EN | C2EN | C1EN | C0EN | | | Access | R/W | | | | R/W | R/W | R/W | R/W | | | Reset | 0 | | | | 0 | 0 | 0 | 0 | | #### Bits 15:14 - CLKSEL[1:0] ADC Module Clock Source Selection bits(1) | Value | Description | |-------|-----------------------------------| | 11 | F <sub>VCO</sub> /4 | | 10 | AF <sub>VCODIV</sub> | | 01 | Fosc | | 00 | F <sub>P</sub> (Peripheral Clock) | # Bits 13:8 - CLKDIV[5:0] ADC Module Clock Source Divider bits(2) The divider forms a $T_{CORESRC}$ clock used by all ADC cores (shared and dedicated), from the $T_{SRC}$ ADC module clock source, selected by the CLKSEL[1:0] bits. Then, each ADC core individually divides the $T_{CORESRC}$ clock to get a core-specific $T_{ADCORE}$ clock using the ADCS[6:0] bits in the ADCORExH register or the SHRADCS[6:0] bits in the ADCON2L register. | Value | Description | |--------|-------------------------| | 111111 | 64 Source Clock Periods | | | | | 000011 | 4 Source Clock Periods | | 000010 | 3 Source Clock Periods | | 000001 | 2 Source Clock Periods | | 000000 | 1 Source Clock Period | ### Bit 7 - SHREN Shared ADC Core Enable bit | Dit i | TREET CHARGO ADO COTO ENABIO BIL | |-------|----------------------------------| | Value | Description | | 1 | Shared ADC core is enabled | | 0 | Shared ADC core is disabled | ## Bit 3 - C3EN Dedicated ADC Core 3 Enable bit | Value | Description | |-------|----------------------------------| | 1 | Dedicated ADC Core 3 is enabled | | 0 | Dedicated ADC Core 3 is disabled | ## Bit 2 - C2EN Dedicated ADC Core 2 Enable bit | Value | Description | |-------|----------------------------------| | 1 | Dedicated ADC Core 2 is enabled | | 0 | Dedicated ADC Core 2 is disabled | ### Bit 1 - C1EN Dedicated ADC Core 1 Enable bit High-Speed, 12-Bit Analog-to-Digital Convert... | Value | Description | |-------|----------------------------------| | 1 | Dedicated ADC Core 1 is enabled | | 0 | Dedicated ADC Core 1 is disabled | # Bit 0 - C0EN Dedicated ADC Core 0 Enable bit | Value | Description | |-------|----------------------------------| | 1 | Dedicated ADC Core 0 is enabled | | 0 | Dedicated ADC Core 0 is disabled | # High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.7 ADC Control Register 4 Low Name: ADCON4L Offset: 0xB0C Legend: r = Reserved bit Bits 11:8 - Reserved[3:0] Must be written as '0' ### Bit 3 - SAMC3EN Dedicated ADC Core 3 Conversion Delay Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | After trigger, the conversion will be delayed and the ADC core will continue sampling during the time specified by the SAMC[9:0] bits in the ADCORE2L register | | 0 | After trigger, the sampling will be stopped immediately and the conversion will be started on the next core clock cycle | # Bit 2 - SAMC2EN Dedicated ADC Core 2 Conversion Delay Enable bit | Value | Description | |-------|-------------------------------------------------------------------------------------------------------------------------| | 1 | After trigger, the conversion will be delayed and the ADC core will continue sampling during the time | | | specified by the SAMC[9:0] bits in the ADCORE2L register | | 0 | After trigger, the sampling will be stopped immediately and the conversion will be started on the next core clock cycle | #### Bit 1 - SAMC1EN Dedicated ADC Core 1 Conversion Delay Enable bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------------| | 1 | After trigger, the conversion will be delayed and the ADC core will continue sampling during the time | | | specified by the SAMC[9:0] bits in the ADCORE1L register | | 0 | After trigger, the sampling will be stopped immediately and the conversion will be started on the next | | | core clock cycle | # Bit 0 - SAMC0EN Dedicated ADC Core 0 Conversion Delay Enable bit | Value | Description | |-------|-------------------------------------------------------------------------------------------------------------------------| | 1 | After trigger, the conversion will be delayed and the ADC core will continue sampling during the time | | | specified by the SAMC[9:0] bits in the ADCORE0L register | | 0 | After trigger, the sampling will be stopped immediately and the conversion will be started on the next core clock cycle | R/W 0 R/W 0 # 13.4.8 ADC Control Register 4 High Name: ADCON4H Offset: 0xB0E R/W R/W Access Reset R/W Bits 7:6 - C3CHS[1:0] Dedicated ADC Core 3 Input Channel Selection bits R/W | Value | Description | |-------|-------------| | 11 | ANC3 | | 10 | ANB3 | | 01 | ANA3 | | 00 | AN3 | R/W 0 ### Bits 5:4 - C2CHS[1:0] Dedicated ADC Core 2 Input Channel Selection bits | Value | Description | |-------|-------------| | 11 | ANC2 | | 10 | ANB2 | | 01 | ANA2 | | 00 | AN2 | # Bits 3:2 - C1CHS[1:0] Dedicated ADC Core 1 Input Channel Selection bits | Value | Description | |-------|-------------| | 11 | ANC1 | | 10 | ANB1 | | 01 | ANA1 | | 00 | AN1 | # Bits 1:0 - C0CHS[1:0] Dedicated ADC Core 0 Input Channel Selection bits | Value | Description | |-------|-------------| | 11 | ANC0 | | 10 | ANB0 | | 01 | ANA0 | | 00 | AN0 | R/W # High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.9 ADC Input Mode Control Register 0 Low Name: ADMOD0L Offset: 0xB10 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | DIFF7 | SIGN7 | DIFF6 | SIGN6 | DIFF5 | SIGN5 | DIFF4 | SIGN4 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DIFF3 | SIGN3 | DIFF2 | SIGN2 | DIFF1 | SIGN1 | DIFF0 | SIGN0 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - DIFF7 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 14 - SIGN7 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | #### Bit 13 - DIFF6 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | # Bit 12 - SIGN6 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | #### Bit 11 - DIFF5 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 10 - SIGN5 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | # Bit 9 - DIFF4 Differential-Mode for Corresponding Analog Inputs bits | DIC DI | 114 Billiotettia Mede for corresponding / Indies bits | |--------|-------------------------------------------------------| | Value | Description | | 1 | Channel is differential | | 0 | Channel is single-ended | ## Bit 8 - SIGN4 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | © 2021 Microchip Technology Inc. and its subsidiaries # High-Speed, 12-Bit Analog-to-Digital Convert... | Bit 7 - DIFF3 | Differential-Mode for | Corresponding Analog | Inputs bits | |---------------|-----------------------|----------------------|-------------| |---------------|-----------------------|----------------------|-------------| | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 6 - SIGN3 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | #### Bit 5 - DIFF2 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ### Bit 4 - SIGN2 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | ### Bit 3 – DIFF1 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | # Bit 2 - SIGN1 Output Data Sign for Corresponding Analog Input bit | Value | Description | | | | | |-------|----------------------------------|--|--|--|--| | 1 | Channel output data are signed | | | | | | 0 | Channel output data are unsigned | | | | | ## Bit 1 - DIFF0 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ## Bit 0 - SIGNO Output Data Sign for Corresponding Analog Input bit | Value | Description | | | | | |-------|----------------------------------|--|--|--|--| | 1 | Channel output data are signed | | | | | | 0 | Channel output data are unsigned | | | | | © 2021 Microchip Technology Inc. and its subsidiaries # High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.10 ADC Input Mode Control Register 0 High Name: ADMOD0H Offset: 0xB12 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | DIFF15 | SIGN15 | DIFF14 | SIGN14 | DIFF13 | SIGN13 | DIFF12 | SIGN12 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DIFF11 | SIGN11 | DIFF10 | SIGN10 | DIFF9 | SIGN9 | DIFF8 | SIGN8 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - DIFF15 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 14 - SIGN15 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | ## Bit 13 - DIFF14 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | # Bit 12 - SIGN14 Output Data Sign for Corresponding Analog Input bit | | | | | <br> | | |-------|----------------|--------------|--------|------|--| | Value | Description | | | | | | 1 | Channel output | data are sig | gned | | | | 0 | Channel output | data are un | signed | | | #### Bit 11 - DIFF13 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ### Bit 10 - SIGN13 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | # Bit 9 - DIFF12 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 8 - SIGN12 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | Datasheet 70005452B-page 563 © 2021 Microchip Technology Inc. # High-Speed, 12-Bit Analog-to-Digital Convert... | Bit 7 - DIFF11 | Differential-Mode for | Corresponding A | Analog Inputs bits | |----------------|-----------------------|-----------------|--------------------| |----------------|-----------------------|-----------------|--------------------| | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 6 - SIGN11 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | #### Bit 5 - DIFF10 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ### Bit 4 - SIGN10 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | ### Bit 3 – DIFF9 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | # Bit 2 - SIGN9 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | ## Bit 1 - DIFF8 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ## Bit 0 - SIGN8 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | © 2021 Microchip Technology Inc. and its subsidiaries # High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.11 ADC Input Mode Control Register 1 Low Name: ADMOD1L Offset: 0xB14 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | DIFF23 | SIGN23 | DIFF22 | SIGN22 | DIFF21 | SIGN21 | DIFF20 | SIGN20 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DIFF19 | SIGN19 | DIFF18 | SIGN18 | DIFF17 | SIGN17 | DIFF16 | SIGN16 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - DIFF23 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 14 - SIGN23 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | ## Bit 13 - DIFF22 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | # Bit 12 - SIGN22 Output Data Sign for Corresponding Analog Input bit | | | | | <br> | | |-------|----------------|--------------|--------|------|--| | Value | Description | | | | | | 1 | Channel output | data are sig | gned | | | | 0 | Channel output | data are un | signed | | | #### Bit 11 - DIFF21 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ### Bit 10 - SIGN21 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | ### Bit 9 - DIFF20 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 8 - SIGN20 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | 70005452B-page 565 Datasheet © 2021 Microchip Technology Inc. # High-Speed, 12-Bit Analog-to-Digital Convert... #### Bit 7 - DIFF19 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 6 - SIGN19 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | #### Bit 5 - DIFF18 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ### Bit 4 - SIGN18 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | #### Bit 3 - DIFF17 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | # Bit 2 - SIGN17 Output Data Sign for Corresponding Analog Input bit | Value | Description | | | |-------|----------------------------------|--|--| | 1 | Channel output data are signed | | | | 0 | Channel output data are unsigned | | | ## Bit 1 - DIFF16 Differential-Mode for Corresponding Analog Inputs bits | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ## Bit 0 - SIGN16 Output Data Sign for Corresponding Analog Input bit | Value | Description | |-------|----------------------------------| | 1 | Channel output data are signed | | 0 | Channel output data are unsigned | © 2021 Microchip Technology Inc. and its subsidiaries # High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.12 ADC Input Mode Control Register 1 High Name: ADMOD1H Offset: 0xB16 Reset | DIL | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DIFF27 | SIGN27 | DIFF26 | SIGN26 | DIFF25 | SIGN25 | DIFF24 | SIGN24 | | Access | R/W ### Bit 7 - DIFF27 Differential-Mode for Corresponding Analog Inputs bit | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ### Bit 6 - SIGN27 Output Data Sign for Corresponding Analog Inputs bit | Value | Description | |-------|---------------------------------| | 1 | Channel output data is signed | | 0 | Channel output data is unsigned | #### Bit 5 - DIFF26 Differential-Mode for Corresponding Analog Inputs bit | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | # Bit 4 – SIGN26 Output Data Sign for Corresponding Analog Inputs bit | Value | Description | |-------|---------------------------------| | 1 | Channel output data is signed | | 0 | Channel output data is unsigned | #### Bit 3 - DIFF25 Differential-Mode for Corresponding Analog Inputs bit | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | #### Bit 2 - SIGN25 Output Data Sign for Corresponding Analog Inputs bit | Value | Description | |-------|---------------------------------| | 1 | Channel output data is signed | | 0 | Channel output data is unsigned | ### Bit 1 - DIFF24 Differential-Mode for Corresponding Analog Inputs bit | Value | Description | |-------|-------------------------| | 1 | Channel is differential | | 0 | Channel is single-ended | ## Bit 0 - SIGN24 Output Data Sign for Corresponding Analog Inputs bit | Value | Description | |-------|---------------------------------| | 1 | Channel output data is signed | | 0 | Channel output data is unsigned | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 567 High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.13 ADC Interrupt Enable Register Low Name: ADIEL<sup>(1)</sup> Offset: 0xB20 ### Note: Bit availability is dependent on the number of supported ADC channels. Refer to dsPIC33CK512MP608 Product Families for ADC channel availability on package variants. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|-----|-----|-----|-----|-----|-----|-----| | | IE[15:8] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | IE[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - IE[15:0] Common Interrupt Enable bits | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Common and individual interrupts are enabled for the corresponding channel | | 0 | Common and individual interrupts are disabled for the corresponding channel | High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.14 ADC Interrupt Enable Register High Name: ADIEH<sup>(1)</sup> Offset: 0xB22 #### Note: Bit availability is dependent on the number of supported ADC channels. Refer to dsPIC33CK512MP608 Product Families for ADC channel availability on package variants. Bits 11:0 - IE[27:16] Common Interrupt Enable bits | | • • | |-------|-----------------------------------------------------------------------------| | Value | Description | | 1 | Common and individual interrupts are enabled for the corresponding channel | | 0 | Common and individual interrupts are disabled for the corresponding channel | High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.15 ADC Data Ready Status Register Low Name: ADSTATL<sup>(1)</sup> Offset: 0xB30 #### Note: Bit availability is dependent on the number of supported ADC channels. Refer to dsPIC33CK512MP608 Product Families for ADC channel availability on package variants. Legend: HSC = Hardware Settable/Clearable bit Bits 15:0 - AN[15:0]RDY Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | | |-------|--------------------------------------------------------------------------|--| | 1 | Channel conversion result is ready in the corresponding ADCBUFx register | | | 0 | Channel conversion result is not ready | | High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.16 ADC Data Ready Status Register High ADSTATH(1) Offset: 0xB32 #### Note: Bit availability is dependent on the number of supported ADC channels. Refer to dsPIC33CK512MP608 Product Families for ADC channel availability on package variants. Legend: HSC = Hardware Settable/Clearable bit Bits 11:8 - AN[27:24]RDY Common Interrupt Enable for Corresponding Analog Input bits | Value | Description | |-------|--------------------------------------------------------------------------| | 1 | Channel conversion result is ready in the corresponding ADCBUFx register | | 0 | Channel conversion result is not ready | Bits 7:0 - AN[23:16]RDY Common Interrupt Enable for Corresponding Analog Input bits | Value | Description | |-------|--------------------------------------------------------------------------| | 1 | Channel conversion result is ready in the corresponding ADCBUFx register | | 0 | Channel conversion result is not ready | High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.17 ADC Digital Comparator x Channel Enable Register Low (x = 0, 1, 2, 3) Name: ADCMPxENL<sup>(1)</sup> **Offset:** 0xB38, 0xB40, 0xB48, 0xB50 #### Note: Bit availability is dependent on the number of supported ADC channels. Refer to dsPIC33CK512MP608 Product Families for ADC channel availability on package variants. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|-----|-----|-----|-----|-----|-----|-----| | | CMPEN[15:8] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CMPEN[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - CMPEN[15:0] Comparator Enable for Corresponding Input Channel bits | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | Conversion result for corresponding channel is used by the comparator | | 0 | Conversion result for corresponding channel is not used by the comparator | High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.18 ADC Digital Comparator x Channel Enable Register High (x = 0, 1, 2, 3) Name: ADCMPxENH<sup>(1)</sup> **Offset:** 0xB3A, 0xB42, 0xB4A, 0xB52 #### Note: Bit availability is dependent on the number of supported ADC channels. Refer to dsPIC33CK512MP608 Product Families for ADC channel availability on package variants. Bits 11:0 - CMPEN[27:16] Comparator Enable for Corresponding Input Channel bits | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | Conversion result for corresponding channel is used by the comparator | | 0 | Conversion result for corresponding channel is not used by the comparator | High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.19 ADC Comparator x Threshold Low Register Name: **ADCMPxLO** Offset: 0xB3C, 0xB44, 0xB4C, 0xB54 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|-----|-----|-----|-----|-----|-----|-----| | | CMPLO[15:8] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CMPLO[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - CMPLO[15:0] ADC Comparator Lower Threshold bitsThe register stores the 16-bit low digital comparison values for use by the digital comparators. **Datasheet** 70005452B-page 574 High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.20 ADC Comparator x Threshold High Register Name: ADCMPxHI **Offset:** 0xB3E, 0xB46, 0xB4E, 0xB56 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-------------|-----|-----|-----|-----|-----|-----|-----|--|--|--|--| | | CMPHI[15:8] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | CMPHI[7:0] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | **Bits 15:0 – CMPHI[15:0]** ADC Comparator Upper Threshold bitsThe register stores the 16-bit upper digital comparison values for use by the digital comparators. **Datasheet** High-Speed, 12-Bit Analog-to-Digital Convert... # 13.4.21 Oversampling Filter (x = 0, 1, 2, 3) Output Register Name: ADFLxDAT **Offset:** 0xB68, 0xB6C, 0xB70, 0xB74 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|--------------|-----|-----|-----|-----|-----|-----|-----|--|--|--|--| | | FLDATA[15:8] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | FLDATA[7:0] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - FLDATA[15:0] 16-Bit Output Data from Oversampling Filters bits ## High-Speed, 12-Bit Analog-to-Digital Convert... #### 13.4.22 ADC Digital Filter x Control Register (x = 0, 1, 2, 3) Name: ADFLxCON Offset: 0xB6A Legend: HSC = Hardware Settable/Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|-----|-----------|-----|-------------|--------------|-----|-------| | | FLEN | MOD | MODE[1:0] | | OVRSAM[2:0] | | | RDY | | Access | R/W HSC/R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | FLCHSEL[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - FLEN Filter Enable bit | Value | Description | |-------|-----------------------------------------------| | 1 | Filter is enabled | | 0 | Filter is disabled and the RDY bit is cleared | #### Bits 14:13 - MODE[1:0] Filter Mode bits | | Description | |-------|-------------------| | Value | Description | | 11 | Averaging mode | | 10 | Reserved | | 01 | Reserved | | 00 | Oversampling mode | # **Bits 12:10 – OVRSAM[2:0]** Filter Averaging/Oversampling Ratio bits If MODE[1:0] = 00: - 111 = 128x (16-bit result in the ADFLxDAT register is in 12.4 format) - 110 = 32x (15-bit result in the ADFLxDAT register is in 12.3 format) - 101 = 8x (14-bit result in the ADFLxDAT register is in 12.2 format) - 100 = 2x (13-bit result in the ADFLxDAT register is in 12.1 format) - 011 = 256x (16-bit result in the ADFLxDAT register is in 12.4 format) - 010 = 64x (15-bit result in the ADFLxDAT register is in 12.3 format) - 001 = 16x (14-bit result in the ADFLxDAT register is in 12.2 format) - 000 = 4x (13-bit result in the ADFLxDAT register is in 12.1 format) #### If MODE[1:0] = 11 (12-bit result in the ADFLxDAT register in all instances): - 111 = 256x - 110 = 128x - 101 = 64x - 100 **= 32x** - 011 = 16x - 010 = 8x - 001 = 4x - 000 = 2x ### Bit 9 - IE Filter Common ADC Interrupt Enable bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Common ADC interrupt will be generated when the filter result will be ready | | 0 | Common ADC interrupt will not be generated for the filter | #### Bit 8 - RDY Oversampling Filter Data Ready Flag bit This bit is cleared by hardware when the result is read from the ADFLxDAT register. High-Speed, 12-Bit Analog-to-Digital Convert... | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1 | Data in the ADFLxDAT register are ready | | 0 | The ADFLxDAT register has been read and new data in the ADFLxDAT register are not ready | ### Bits 4:0 - FLCHSEL[4:0] Oversampling Filter Input Channel Selection bits | Value | Description | |-------------|---------------------------| | 11111-11100 | Reserved | | 11011 | AN27 | | 11010 | AN26 | | 11001 | Band Gap, 1.2V (AN25) | | 11000 | Temperature Sensor (AN24) | | 10111 | AN23 | | | | | 00010 | AN2 | | 00001 | AN1 | | 00000 | AN0 | ## High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.23 ADC Channel Trigger 0 Selection Register Low Name: ADTRIGOL Offset: 0xB80 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|--------------|-----|-----| | | | | | | | TRGSRC1[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC0[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC1[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | 11111 ADTRG31 (PPS input) 11110 PTG 11101 CLC2 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01001 PWM3 Trigger 1 01001 PWM2 Trigger 2 00110 PWM2 Trigger 1 00110 PWM1 Trigger 2 00110 PWM1 Trigger 1 00100 PWM1 Trigger 1 | | urce Selection for Corresponding Analog Inputs bits | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------------| | 11110 PTG 11101 CLC2 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10100 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10010 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01100 SCCP1 trigger 01101 SCCP1 trigger 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 1 00110 PWM2 Trigger 1 00110 PWM2 Trigger 1 00110 PWM1 Trigger 1 00100 PWM1 Trigger 1 00100 PWM1 Trigger 1 | Value | Description | | 11101 | 11111 | ADTRG31 (PPS input) | | 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10000 Reserved 01111 SCCP4 trigger 01110 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01000 PWM3 Trigger 1 00101 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00110 PWM1 Trigger 2 00110 PWM1 Trigger 1 00100 PWM1 Trigger 1 | 11110 | PTG | | 11011-11000 Reserved 10111 SCCP4 output compare trigger 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10101 Reserved 10011 Reserved 10010 CLC3 10000 Reserved 01111 SCCP4 trigger 01110 SCCP3 trigger 01101 SCCP2 trigger 01101 SCCP1 trigger 01101 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 2 00110 PWM2 Trigger 2 00110 PWM1 Trigger 2 00110 PWM1 Trigger 2 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00100 | 11101 | CLC2 | | 10111 SCCP4 output compare trigger | 11100 | CLC1 | | 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01001 SCCP1 trigger 01010 PWM4 Trigger 2 01001 PWM3 Trigger 1 00101 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 11011-11000 | Reserved | | 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01011 PWM4 Trigger 2 01000 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 1 00100 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 10111 | SCCP4 output compare trigger | | 10100 SCCP1 output compare trigger 10011 Reserved 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 1 00111 PWM2 Trigger 1 00110 PWM2 Trigger 1 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 | 10110 | | | 10011 Reserved 10001 CLC4 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 10101 | SCCP2 output compare trigger | | 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 1 00111 PWM2 Trigger 1 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 | 10100 | SCCP1 output compare trigger | | 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 1 00111 PWM2 Trigger 1 00100 PWM1 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 10011 | Reserved | | 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM1 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 10010 | CLC4 | | 01111 SCCP4 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 2 0111 PWM2 Trigger 1 00111 PWM2 Trigger 2 00110 PWM1 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 10001 | CLC3 | | 01110 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 10000 | Reserved | | 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01111 | SCCP4 trigger | | 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01110 | SCCP3 trigger | | 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01101 | SCCP2 trigger | | 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01100 | SCCP1 trigger | | 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01011 | PWM4 Trigger 2 | | 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01010 | PWM4 Trigger 1 | | 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01001 | PWM3 Trigger 2 | | 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 01000 | PWM3 Trigger 1 | | 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 | 00111 | PWM2 Trigger 2 | | 00100 PWM1 Trigger 1 | 00110 | PWM2 Trigger 1 | | | 00101 | PWM1 Trigger 2 | | 00011 Reserved | 00100 | PWM1 Trigger 1 | | 1,000,100 | 00011 | Reserved | | 00010 Level software trigger | 00010 | Level software trigger | | 00001 Common software trigger | 00001 | Common software trigger | | No trigger is enabled | 00000 | No trigger is enabled | Bits 4:0 - TRGSRC0[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | Value | Description | |-------|------------------------------| | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.24 ADC Channel Trigger 0 Selection Register High Name: ADTRIG0H Offset: 0xB82 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|--------------|-----|-----| | | | | | | | TRGSRC3[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC2[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC3[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | Bits 4:0 - TRGSRC2[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | Value | Description | |-------|------------------------------| | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ## High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.25 ADC Channel Trigger 1 Selection Register Low Name: ADTRIG1L Offset: 0xB84 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|--------------|-----|-----| | | | | | | | TRGSRC5[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC4[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC5[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | | r Source Selection for Corresponding Analog Inputs bits | |-------------|---------------------------------------------------------| | Value | Description | | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | Bits 4:0 - TRGSRC4[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.26 ADC Channel Trigger 1 Selection Register High Name: ADTRIG1H Offset: 0xB86 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|--------------|-----|-----| | | | | | | | TRGSRC7[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC6[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC7[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | | Source Selection for Corresponding Analog Inputs bits | |-------------|-------------------------------------------------------| | Value | Description | | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | Bits 4:0 - TRGSRC6[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.27 ADC Channel Trigger 2 Selection Register Low Name: ADTRIG2L Offset: 0xB88 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|--------------|-----|-----| | | | | | | | TRGSRC9[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC8[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC9[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | | | | Bits 4:0 - TRGSRC8[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.28 ADC Channel Trigger 2 Selection Register High Name: ADTRIG2H Offset: 0xB8A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----|----|----|-----|-----|---------------|-----|-----|--| | | | | | | | TRGSRC11[4:0] | | | | | Access | | , | | R/W | R/W | R/W | R/W | R/W | | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | TRGSRC10[4:0] | | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | Bits 12:8 - TRGSRC11[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | ADTRG31 (PPS input) | Value | Description | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------| | 11110 PTG 11101 CLC2 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10100 SCCP3 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 1111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP4 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 2 01000 PWM3 Trigger 1 00011 PWM2 Trigger 1 00110 PWM2 Trigger 2 00110 PWM1 Trigger 2 00110 PWM1 Trigger 1 00010 PWM1 Trigger 1 00010 Level software trigger 00011 Level software trigger | | | | 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10011 Reserved 10000 Reserved 01111 SCCP4 trigger 01110 SCCP3 trigger 01101 SCCP2 trigger 01101 SCCP1 trigger 01010 PWM4 Trigger 1 01010 PWM3 Trigger 2 01000 PWM3 Trigger 2 00111 PWM2 Trigger 1 00110 PWM1 Trigger 1 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00011 Common software trigger | 11110 | | | 11011-11000 Reserved 10111 SCCP4 output compare trigger 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01010 PWM4 Trigger 2 01010 PWM3 Trigger 1 00101 PWM2 Trigger 1 00110 PWM2 Trigger 1 00100 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 11101 | CLC2 | | 10111 SCCP4 output compare trigger 10101 SCCP3 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01010 PWM4 Trigger 2 01001 PWM4 Trigger 1 01001 PWM3 Trigger 2 00101 PWM2 Trigger 2 00110 PWM2 Trigger 1 00110 PWM1 Trigger 2 00100 PWM1 Trigger 1 00101 Reserved 00010 Level software trigger 00011 Common software trigger | 11100 | CLC1 | | 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10000 Reserved 01111 SCCP4 trigger 01110 SCCP3 trigger 01101 SCCP2 trigger 01101 SCCP1 trigger 01010 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 00101 PWM2 Trigger 1 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00010 Common software trigger | 11011-11000 | Reserved | | 10101 SCCP2 output compare trigger 10010 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 2 00110 PWM1 Trigger 2 00110 PWM1 Trigger 1 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 10111 | SCCP4 output compare trigger | | 10100 SCCP1 output compare trigger 10011 Reserved 10000 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01000 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 1 0011 PWM2 Trigger 2 00110 PWM1 Trigger 2 00100 PWM1 Trigger 1 00010 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 10110 | | | 10011 Reserved 10000 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01000 PWM3 Trigger 1 01001 PWM3 Trigger 2 01010 PWM2 Trigger 1 00111 PWM2 Trigger 2 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 Reserved 00010 Level software trigger 00001 Common software trigger | 10101 | SCCP2 output compare trigger | | 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01011 PWM4 Trigger 2 01000 PWM3 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 Level software trigger 00010 Common software trigger | 10100 | SCCP1 output compare trigger | | 100001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 10011 | Reserved | | 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 10010 | CLC4 | | 01111 SCCP4 trigger 01101 SCCP3 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 PWM1 Trigger 1 00010 Level software trigger 00001 Common software trigger | 10001 | CLC3 | | 01110 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01000 PWM2 Trigger 1 00111 PWM2 Trigger 1 00100 PWM1 Trigger 2 00101 PWM1 Trigger 1 00010 Reserved 00010 Level software trigger 00001 Common software trigger | 10000 | Reserved | | 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM3 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00100 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 Reserved 00010 Level software trigger 00001 Common software trigger | 01111 | SCCP4 trigger | | 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM1 Trigger 1 00101 PWM1 Trigger 1 00010 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 01110 | SCCP3 trigger | | 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 01101 | SCCP2 trigger | | 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00100 PWM1 Trigger 1 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 01100 | SCCP1 trigger | | 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00100 PWM1 Trigger 1 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 01011 | PWM4 Trigger 2 | | 01000 PWM3 Trigger 1 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 01010 | PWM4 Trigger 1 | | 00111 PWM2 Trigger 2 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 01001 | | | 00110 PWM2 Trigger 1 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 01000 | PWM3 Trigger 1 | | 00101 PWM1 Trigger 2 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 00111 | PWM2 Trigger 2 | | 00100 PWM1 Trigger 1 00011 Reserved 00010 Level software trigger 00001 Common software trigger | 00110 | | | 00011Reserved00010Level software trigger00001Common software trigger | 00101 | PWM1 Trigger 2 | | 00010 Level software trigger 00001 Common software trigger | 00100 | PWM1 Trigger 1 | | Common software trigger | 00011 | Reserved | | | 00010 | | | No trigger is enabled | 00001 | Common software trigger | | | 00000 | No trigger is enabled | Bits 4:0 - TRGSRC10[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | # High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.29 ADC Channel Trigger 3 Selection Register Low Name: ADTRIG3L Offset: 0xB8C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|---------------|-----|-----| | | | | | | | TRGSRC13[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC12[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC13[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | Value Description 11111 ADTRG31 (PPS input) 11110 PTG 11100 CLC2 11100 CLC1 1011-11000 Reserved 10111 SCCP4 output compare trigger 10100 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10000 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01101 SCCP1 trigger 01010 PWM4 Trigger 2 01010 PWM3 Trigger 1 01000 PWM3 Trigger 2 01001 PWM3 Trigger 2 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11110 PTG 11101 CLC2 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10100 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10010 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 11101 CLC2 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10101 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10010 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01101 SCCP1 trigger 01010 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 11100 CLC1 11011-11000 Reserved 10111 SCCP4 output compare trigger 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 11011-11000 Reserved 10111 SCCP4 output compare trigger 10101 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01010 SCCP1 trigger 01010 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 10111 SCCP4 output compare trigger 10100 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01101 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 10110 SCCP3 output compare trigger 10101 SCCP2 output compare trigger 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01101 SCCP3 trigger 01101 SCCP2 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 10101 SCCP2 output compare trigger | | 10100 SCCP1 output compare trigger 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 10011 Reserved 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 10010 CLC4 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 10001 CLC3 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 10000 Reserved 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01111 SCCP4 trigger 01100 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01110 SCCP3 trigger 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01101 SCCP2 trigger 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01100 SCCP1 trigger 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01011 PWM4 Trigger 2 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01010 PWM4 Trigger 1 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01001 PWM3 Trigger 2 01000 PWM3 Trigger 1 | | 01000 PWM3 Trigger 1 | | 1 | | 00111 PWM2 Trigger 2 | | | | 00110 PWM2 Trigger 1 | | 00101 PWM1 Trigger 2 | | 00100 PWM1 Trigger 1 | | 00011 Reserved | | 00010 Level software trigger | | 00001 Common software trigger | | No trigger is enabled | Bits 4:0 - TRGSRC12[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.30 ADC Channel Trigger 3 Selection Register High Name: ADTRIG3H Offset: 0xB8E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|---------------|-----|-----| | | | | | | | TRGSRC15[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC14[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC15[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | | | | Bits 4:0 - TRGSRC14[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.31 ADC Channel Trigger 4 Selection Register Low Name: ADTRIG4L Offset: 0xB90 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----|----|----|-----|-----|---------------|-----|-----|--| | | | | | | | TRGSRC17[4:0] | | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | TRGSRC16[4:0] | | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | Bits 12:8 - TRGSRC17[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | Bits 4:0 - TRGSRC16[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.32 ADC Channel Trigger 4 Selection Register High Name: ADTRIG4H Offset: 0xB92 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|---------------|-----|-----| | | | | | | | TRGSRC19[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC18[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC19[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 1110 | CLC2 | | 11101 | | | | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | | | 1 | Bits 4:0 - TRGSRC18[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ### 13.4.33 ADC Channel Trigger 5 Selection Register Low Name: ADTRIG5L Offset: 0xB94 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|-----|---------------|-----|-----| | | | | | | | TRGSRC21[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | TRGSRC20[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | Bits 12:8 - TRGSRC21[4:0] Trigger Source Selection for Corresponding Analog Inputs bits | Value | Description | |-------------|------------------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 output compare trigger | | 10110 | SCCP3 output compare trigger | | 10101 | SCCP2 output compare trigger | | 10100 | SCCP1 output compare trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | | | | Bits 4:0 - TRGSRC20[4:0] Common Interrupt Enable for Corresponding Analog Inputs bits | Value | Description | |-------------|---------------------| | 11111 | ADTRG31 (PPS input) | | 11110 | PTG | | 11101 | CLC2 | | 11100 | CLC1 | | 11011-11000 | Reserved | | 10111 | SCCP4 trigger | | Value | Description | |-------|-------------------------| | 10110 | SCCP3 trigger | | 10101 | SCCP2 trigger | | 10100 | SCCP1 trigger | | 10011 | Reserved | | 10010 | CLC4 | | 10001 | CLC3 | | 10000 | Reserved | | 01111 | SCCP4 trigger | | 01110 | SCCP3 trigger | | 01101 | SCCP2 trigger | | 01100 | SCCP1 trigger | | 01011 | PWM4 Trigger 2 | | 01010 | PWM4 Trigger 1 | | 01001 | PWM3 Trigger 2 | | 01000 | PWM3 Trigger 1 | | 00111 | PWM2 Trigger 2 | | 00110 | PWM2 Trigger 1 | | 00101 | PWM1 Trigger 2 | | 00100 | PWM1 Trigger 1 | | 00011 | Reserved | | 00010 | Level software trigger | | 00001 | Common software trigger | | 00000 | No trigger is enabled | ## High-Speed, 12-Bit Analog-to-Digital Convert... #### 13.4.34 ADC Digital Comparator x Control Register (x = 0, 1, 2, 3) Name: ADCMPxCON Offset: 0xBA0, 0xBA4, 0xBA8, 0xBAC Legend: HC = Hardware Clearable bit; HS = Hardware Settable bit; HSC = Hardware Settable/Clearable bit ### Bits 12:8 - CHNL[4:0] Input Channel Number bits | Value | Description | |-------------|---------------------------| | 11111-11100 | Reserved | | 11011 | AN27 | | 11010 | AN26 | | 11001 | Band gap, 1.2V (AN25) | | 11000 | Temperature sensor (AN24) | | 10111 | AN23 | | | | | 00010 | AN2 | | 00001 | AN1 | | 00000 | AN0 | #### Bit 7 - CMPEN Comparator Enable bit | Value | Description | |-------|-----------------------------------------------------------| | 1 | Comparator is enabled | | 0 | Comparator is disabled and the STAT status bit is cleared | #### Bit 6 - IE Comparator Common ADC Interrupt Enable bit | Value | Description | |-------|------------------------------------------------------------------------------| | 1 | ADC interrupt will be generated if the comparator detects a comparison event | | 0 | ADC interrupt will not be generated for the comparator | #### Bit 5 - STAT Comparator Event Status bit This bit is cleared by hardware when the channel number is read from the CHNL[4:0] bits. | Value | Description | |-------|------------------------------------------------------------------------------------| | 1 | A comparison event has been detected since the last read of the CHNL[4:0] bits | | 0 | A comparison event has not been detected since the last read of the CHNL[4:0] bits | #### Bit 4 - BTWN Between Low/High Comparator Event bit | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | Generates a comparator event when ADCMPxLO ≤ ADCBUFx < ADCMPxHI | | 0 | Does not generate a digital comparator event when ADCMPxLO ≤ ADCBUFx < ADCMPxHI | #### Bit 3 - HIHI High/High Comparator Event bit | Value | Description | |-------|----------------------------------------------------------------------| | 1 | Generates a digital comparator event when ADCBUFx ≥ ADCMPxHI | | 0 | Does not generate a digital comparator event when ADCBUFx ≥ ADCMPxHI | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 601 High-Speed, 12-Bit Analog-to-Digital Convert... ### Bit 2 - HILO High/Low Comparator Event bit | Value | Description | |-------|----------------------------------------------------------------------| | 1 | Generates a digital comparator event when ADCBUFx < ADCMPxHI | | 0 | Does not generate a digital comparator event when ADCBUFx < ADCMPxHI | ### Bit 1 - LOHI Low/High Comparator Event bit | Value | Description | |-------|----------------------------------------------------------------------| | 1 | Generates a digital comparator event when ADCBUFx ≥ ADCMPxLO | | 0 | Does not generate a digital comparator event when ADCBUFx ≥ ADCMPxLO | #### Bit 0 - LOLO Low/Low Comparator Event bit | Value | Description | |-------|----------------------------------------------------------------------| | 1 | Generates a digital comparator event when ADCBUFx < ADCMPxLO | | 0 | Does not generate a digital comparator event when ADCBUFx < ADCMPxLO | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 602 High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.35 ADC Level-Sensitive Trigger Control Register Low Name: ADLVLTRGL Offset: 0xBD0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-------------|-----|-----|-----|-----|-----|-----|-----|--| | | LVLEN[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | LVLEN[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - LVLEN[15:0] Level Trigger for Corresponding Analog Input Enable bits | Value | Description | |-------|----------------------------------| | 1 | Input trigger is level-sensitive | | 0 | Input trigger is edge-sensitive | High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.36 ADC Level-Sensitive Trigger Control Register High Name: ADLVLTRGH Offset: 0xBD2 Bits 11:0 - LVLEN[27:16] Level Trigger for Corresponding Analog Input Enable bits | Value | Description | |-------|----------------------------------| | 1 | Input trigger is level-sensitive | | 0 | Input trigger is edge-sensitive | ### 13.4.37 Dedicated ADC Core x Control Register Low (x = 0 to 3) Name: ADCOREXL Offset: 0xBD4, 0xBD8, 0xBDC, 0xBE0 Bits 9:0 - SAMC[9:0] Dedicated ADC Core x Conversion Delay Selection bits These bits determine the time between the trigger event and the start of conversion in the number of the Core Clock Periods (T<sub>ADCORE</sub>). During this time, the ADC Core x still continues sampling. This feature is enabled by the SAMCxEN bits in the ADCON4L register. | Value | Description | |------------|--------------------------| | 1111111111 | 1025 T <sub>ADCORE</sub> | | | | | 000000001 | 3 T <sub>ADCORE</sub> | | 000000000 | 2 T <sub>ADCORE</sub> | ## High-Speed, 12-Bit Analog-to-Digital Convert... #### 13.4.38 Dedicated ADC Core x Control Register High (x = 0 to 3) Name: ADCORExH Offset: 0xBD6, 0xBDA, 0xBDE, 0xBE2 #### Note: 1. For the 6-bit ADC core resolution (RES[1:0] = 00), the EISEL[2:0] bits settings, from '100' to '111', are not valid and should not be used. For the 8-bit ADC core resolution (RES[1:0] = 01), the EISEL[2:0] bits settings, '110' and '111', are not valid and should not be used. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|-----|-----|------------|-----|-----|--------| | | | | | | EISEL[2:0] | | RES | 5[1:0] | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | ADCS[6:0] | | , | | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 12:10 - EISEL[2:0] ADC Core x Early Interrupt Time Selection bits | Value | Description | |-------|------------------------------------------------------------------------------------------------------------| | 111 | Early interrupt is set and interrupt is generated 8 T <sub>ADCORE</sub> clocks prior to when data is ready | | 110 | Early interrupt is set and interrupt is generated 7 T <sub>ADCORE</sub> clocks prior to when data is ready | | 101 | Early interrupt is set and interrupt is generated 6 T <sub>ADCORE</sub> clocks prior to when data is ready | | 100 | Early interrupt is set and interrupt is generated 5 T <sub>ADCORE</sub> clocks prior to when data is ready | | 011 | Early interrupt is set and interrupt is generated 4 T <sub>ADCORE</sub> clocks prior to when data is ready | | 010 | Early interrupt is set and interrupt is generated 3 T <sub>ADCORE</sub> clocks prior to when data is ready | | 001 | Early interrupt is set and interrupt is generated 2 T <sub>ADCORE</sub> clocks prior to when data is ready | | 000 | Early interrupt is set and interrupt is generated 1 T <sub>ADCORE</sub> clock prior to when data is ready | ### Bits 9:8 - RES[1:0] ADC Core x Resolution Selection bits | Value | Description | |-------|---------------------------------| | 11 | 12-bit resolution | | 10 | 10-bit resolution | | 01 | 8-bit resolution <sup>(1)</sup> | | 00 | 6-bit resolution <sup>(1)</sup> | #### Bits 6:0 - ADCS[6:0] ADC Core x Input Clock Divider bits These bits determine the number of Source Clock Periods (T<sub>CORESRC</sub>) for one Core Clock Period (T<sub>ADCORE</sub>). | Value | Description | |---------|--------------------------| | 1111111 | 254 Source Clock Periods | | | | | 0000011 | 6 Source Clock Periods | | 0000010 | 4 Source Clock Periods | | 0000001 | 2 Source Clock Periods | | 0000000 | 2 Source Clock Periods | High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.39 ADC Early Interrupt Enable Register Low Name: ADEIEL Offset: 0xBF0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | | | | | EIEN | [15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | EIEN | I[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - EIEN[15:0] Early Interrupt Enable for Corresponding Analog Input bits | Value | Description | |-------|---------------------------------------------| | 1 | Early interrupt is enabled for the channel | | 0 | Early interrupt is disabled for the channel | High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.40 ADC Early Interrupt Enable Register High Name: ADEIEH Offset: 0xBF2 Bits 11:0 - EIEN[27:16] Early Interrupt Enable for Corresponding Analog Input bits | Value | Description | |-------|---------------------------------------------| | 1 | Early interrupt is enabled for the channel | | 0 | Early interrupt is disabled for the channel | © 2021 Microchip Technology Inc. and its subsidiaries High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.41 ADC Early Interrupt Status Register Low Name: ADEISTATL Offset: 0xBF8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | EISTA | T[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | EISTA | T[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - EISTAT[15:0] Early Interrupt Status for Corresponding Analog Input bits | Value | Description | |-------|---------------------------------------------------------------| | 1 | Early interrupt was generated | | 0 | Early interrupt was not generated since the last ADCBUFx read | High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.42 ADC Early Interrupt Status Register High Name: ADEISTATH Offset: 0xBFA Bits 11:0 - EISTAT[27:16] Early Interrupt Status for Corresponding Analog Input bits | Value | Description | |-------|---------------------------------------------------------------| | 1 | Early interrupt was generated | | 0 | Early interrupt was not generated since the last ADCBUFx read | **Datasheet** © 2021 Microchip Technology Inc. and its subsidiaries ## High-Speed, 12-Bit Analog-to-Digital Convert... ### 13.4.43 ADC Control Register 5 Low Name: ADCON5L Offset: 0xC00 Legend: HSC = Hardware Settable/Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|----|----|-------|-------|-------|-------| | | SHRRDY | | | | C3RDY | C2RDY | C1RDY | C0RDY | | Access | R/HSC | | | | R/W | R/W | R/W | R/W | | Reset | 0 | | | | 0 | 0 | 0 | 0 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SHRPWR | | | | C3PWR | C2PWR | C1PWR | C0PWR | | Access | R/W | | | | R/W | R/W | R/W | R/W | | Reset | 0 | | | | 0 | 0 | 0 | 0 | #### Bit 15 - SHRRDY Shared ADC Core Ready Flag bit | Value | Description | |-------|---------------------------------------------| | 1 | ADC core is powered and ready for operation | | 0 | ADC core is not ready for operation | #### Bit 11 - C3RDY Dedicated ADC Core 3 Ready Flag bit | Value | Description | |-------|-----------------------------------------------| | 1 | ADC Core 3 is powered and ready for operation | | 0 | ADC Core 3 is not ready for operation | ### Bit 10 - C2RDY Dedicated ADC Core 2 Ready Flag bit | Value | Description | |-------|-----------------------------------------------| | 1 | ADC Core 2 is powered and ready for operation | | 0 | ADC Core 2 is not ready for operation | ### Bit 9 - C1RDY Dedicated ADC Core 1 Ready Flag bit | Value | Description | |-------|-----------------------------------------------| | 1 | ADC Core 1 is powered and ready for operation | | 0 | ADC Core 1 is not ready for operation | #### Bit 8 - CORDY Dedicated ADC Core 0 Ready Flag bit | Value | Description | |-------|-----------------------------------------------| | 1 | ADC Core 0 is powered and ready for operation | | 0 | ADC Core 0 is not ready for operation | ### Bit 7 - SHRPWR Shared ADC Core Power Enable bit | Value | Description | |-------|---------------------| | 1 | ADC core is powered | | 0 | ADC core is off | #### Bit 3 - C3PWR Dedicated ADC Core 3 Power Enable bit | Value | Description | |-------|-----------------------| | 1 | ADC Core 3 is powered | | 0 | ADC Core 3 off | #### Bit 2 - C2PWR Dedicated ADC Core 2 Power Enable bit | | I VII Dedicated / De Colo E 1 over Enable bit | |-------|-----------------------------------------------| | Value | Description | | 1 | ADC Core 2 is powered | | 0 | ADC Core 2 is off | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 611 High-Speed, 12-Bit Analog-to-Digital Convert... ### Bit 1 - C1PWR Dedicated ADC Core 1 Power Enable bit | Value | Description | |-------|-----------------------| | 1 | ADC Core 1 is powered | | 0 | ADC Core 1 is off | #### Bit 0 - C0PWR Dedicated ADC Core 0 Power Enable bit | Value | Description | |-------|-----------------------| | 1 | ADC Core 0 is powered | | 0 | ADC Core 0 is off | ## High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.44 ADC Control Register 5 High Name: ADCON5H Offset: 0xC02 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|----|----|-------|-------|----------|-------| | | | | | | | WARMT | IME[3:0] | | | Access | | , | | | R/W | R/W | R/W | R/W | | Reset | | | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SHRCIE | | | | C3CIE | C2CIE | C1CIE | C0CIE | | Access | R/W | | | | R/W | R/W | R/W | R/W | | Reset | 0 | | | | 0 | 0 | 0 | 0 | ### Bits 11:8 - WARMTIME[3:0] ADC Dedicated Core Power-up Delay bits These bits determine the power-up delay in the number of the Core Source Clock Periods ( $T_{CORESRC}$ ) for all ADC cores. | Value | Description | |-------|----------------------------| | 1111 | 32768 Source Clock Periods | | 1110 | 16384 Source Clock Periods | | 1101 | 8192 Source Clock Periods | | 1100 | 4096 Source Clock Periods | | 1011 | 2048 Source Clock Periods | | 1010 | 1024 Source Clock Periods | | 1001 | 512 Source Clock Periods | | 1000 | 256 Source Clock Periods | | 0111 | 128 Source Clock Periods | | 0110 | 64 Source Clock Periods | | 0101 | 32 Source Clock Periods | | 0100 | 16 Source Clock Periods | | 00xx | 16 Source Clock Periods | ## Bit 7 - SHRCIE Shared ADC Core Ready Common Interrupt Enable bit | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | Common interrupt will be generated when ADC core is powered and ready for operation | | 0 | Common interrupt is disabled for an ADC core ready event | ## Bit 3 - C3CIE Dedicated ADC Core 3 Ready Common Interrupt Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------------| | 1 | Common interrupt will be generated when ADC Core 3 is powered and ready for operation | | 0 | Common interrupt is disabled for an ADC Core 3 ready event | ## Bit 2 - C2CIE Dedicated ADC Core 2 Ready Common Interrupt Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------------| | 1 | Common interrupt will be generated when ADC Core 2 is powered and ready for operation | | 0 | Common interrupt is disabled for an ADC Core 2 ready event | ## Bit 1 - C1CIE Dedicated ADC Core 1 Ready Common Interrupt Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------------| | 1 | Common interrupt will be generated when ADC Core 1 is powered and ready for operation | | 0 | Common interrupt is disabled for an ADC Core 1 ready event | ### Bit 0 - C0CIE Dedicated ADC Core 0 Ready Common Interrupt Enable bit High-Speed, 12-Bit Analog-to-Digital Convert... | Value | Description | |-------|---------------------------------------------------------------------------------------| | 1 | Common interrupt will be generated when ADC Core 0 is powered and ready for operation | | 0 | Common interrupt is disabled for an ADC Core 0 ready event | High-Speed, 12-Bit Analog-to-Digital Convert... ## 13.4.45 ADC Buffer x Register Name: ADCBUFx **Offset:** 0xC0C, 0xC0E, 0xC10, 0xC12, 0xC14, 0xC16, 0xC18, 0xC1A, 0xC1C, 0xC1E, 0xC20, 0xC22, 0xC24, 0xC26, 0xC28, 0xC2A, 0xC2C, 0xC2E, 0xC30, 0xC32, 0xC34, 0xC36 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|----------|-----|-----|-----| | | | | | ADCBU | Fx[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | ADCBU | JFx[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - ADCBUFx[15:0] Buffer Data bits ## High-Speed Analog Comparator with Slope Comp... # 14. High-Speed Analog Comparator with Slope Compensation DAC Notes: - This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "High-Speed Analog Comparator Module" (www.microchip.com/DS70005280) in the "dsPIC33/PIC24 Family Reference Manual." - Some registers and associated bits described in this section may not be available on all devices. Refer to Memory Organization in this data sheet for device-specific register and bit information. The high-speed analog comparator module provides a method to monitor voltage, current and other critical signals in a power conversion application that may be too fast for the CPU and ADC to capture. The analog comparator module can be used to implement Peak Current mode control, Critical Conduction mode (variable frequency) and Hysteretic Control mode. #### 14.1 Overview The high-speed analog comparator module is comprised of a high-speed comparator, Pulse Density Modulation (PDM) DAC and a slope compensation unit. The slope compensation unit provides a user-defined slope which can be used to alter the DAC output. This feature is useful in applications, such as Peak Current mode control, where slope compensation is required to maintain the stability of the power supply. The user simply specifies the direction and rate of change for the slope compensation and the output of the DAC is modified accordingly. The DAC consists of a PDM unit, followed by a digitally controlled multiphase RC filter. The PDM unit uses a phase accumulator circuit to generate an output stream of pulses. The density of the pulse stream is proportional to the input data value, relative to the maximum value supported by the bit width of the accumulator. The output pulse density is representative of the desired output voltage. The pulse stream is filtered with an RC filter to yield an analog voltage. The output of the DAC is connected to the negative input of the comparator. The positive input of the comparator can be selected using a MUX from the input pins. The comparator provides a high-speed operation with a typical delay of 15 ns. The output of the comparator is processed by the pulse stretcher and the digital filter blocks, which prevent comparator response to unintended fast transients in the inputs. Figure 14-1 shows a block diagram of the high-speed analog comparator module. The DAC module can be operated in one of three modes: Slope Generation mode, Hysteretic mode and Triangle Wave mode. Each of these modes can be used in a variety of power supply applications. **Note:** The DACOUT1 pin can only be associated with a single DAC output at any given time. If more than one DACOEN bit is set, the DACOUT1 pin will be a combination of the signals. INSEL[2:0] **CMPxD** CMPx PWM Trigger **CMPxC CMPxB** Pulse Status **CMPxA** Stretcher and Digital IRQ Filter **CMPPOL** Buffer Amplifier PDM DACx Slope X DACOUT Generator DAC 'n 'n **SLPxDAT** DACxDATH DACXDATL Figure 14-1. High-Speed Analog Comparator Module Block Diagram Note: n = 16 ## 14.2 Features Overview - · Four Rail-to-Rail Analog Comparators - Up to Five Selectable Input Sources per Comparator: - Three external inputs - · Programmable Comparator Hysteresis - · Programmable Output Polarity - · Interrupt Generation Capability - Dedicated Pulse Density Modulation DAC for each Analog Comparator: - PDM unit followed by a digitally controlled multimode multipole RC filter - Multimode Multipole RC Output Filter: - Transition mode: Provides the fastest response - Fast mode: For tracking DAC slopes - Steady-State mode: Provides 12-bit resolution - · Slope Compensation along with each DAC: - Slope Generation mode - Hysteretic Control mode - Triangle Wave mode - Functional Support for the High-Speed PWM module which Includes: - PWM duty cycle control - PWM period control - PWM Fault detect **High-Speed Analog Comparator with Slope Comp...** ## 14.3 DAC Control Registers The DACCTRL1L and DACCTRL2H/L registers are common configuration registers for DAC modules. The DACxCON, DACxDAT, SLPxCON and SLPxDAT registers specify the operation of individual modules. **Datasheet** ## 14.4 DAC Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------|--------------------------------------------------------|-------------|--------------|---------|---------------------|------------|-----------------------------------------|-----------|---------------------|------------|--| | 0x0C48 | DACCTRL1L | 15:8 | DACON | | DACSIDL | | | | | | | | | DACCINETE | 7:0 | CLKSI | EL[1:0] | CLKE | IV[1:0] | | | FCLKDIV[2:0] | | | | 0x0C4A | _ | | | | | | | | | | | | 0004D | Reserved | | | | | | | | | | | | 0x0C4B | | 15:8 | | | | | | | TMODT | IMEIO-01 | | | 0x0C4C | DACCTRL2L | 7:0 | | | | TMODT | IME[9:0] | | TWODT | IIVIL[9.0] | | | | 17 1 C 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 15:8 | | | | TWODT | IIII [U.U] | | SSTIM | 1E[9:0] | | | 0x0C4E | DACCTRL2H | 7:0 | | | | SSTIM | 1E[9:0] | | | | | | 0.0050 | DAGAGONII | 15:8 | DACEN | IRQI | M[1:0] | | | CBE | DACOEN | FLTREN | | | 0x0C50 | DAC1CONL | 7:0 | CMPSTAT | CMPPOL | | INSEL[2:0] | | HYSPOL | HYSS | EL[1:0] | | | 0x0C52 | DAC1CONH | 15:8 | | | | | | | TMC | 3[9:0] | | | 0.00002 | DACTOONIT | 7:0 | | | | TMCI | B[9:0] | | | | | | 0x0C54 | DAC1DATL | 15:8 | | | | | | DACLO | W[11:0] | | | | 0,000 | 5/10/15/112 | 7:0 | | | | DACLO | W[11:0] | | | | | | 0x0C56 | DAC1DATH | 15:8 | | | | | | DACD | AT[11:0] | | | | | 30 100 2 3 10 5 10 10 10 10 10 10 10 10 10 10 10 10 10 | 7:0 | | LIOTO | E1 10 01 | DACDA | AT[11:0] | OL DOT | 00410.01 | | | | 0x0C58 | SLP1CONL | 15:8<br>7:0 | | | EL[3:0]<br>OPB[3:0] | | | | OPA[3:0]<br>RT[3:0] | | | | | | 15:8 | SLOPEN | SLPST | ОРВ[3.0]<br> | | HME | TWME | PSE | | | | 0x0C5A | SLP1CONH | 7:0 | SLOPEN | | | | HIVIE | IVVIVIE | FSE | | | | | | 15:8 | | | | SI PDA | T[15:8] | | | | | | 0x0C5C | SLP1DAT | 7:0 | | | | SLPD | | | | | | | 0x0C5E | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0C5F | | | | | | | | | | | | | 0x0C60 | DAC2CONL | 15:8 | DACEN | IRQI | M[1:0] | | | CBE | DACOEN | FLTREN | | | UXUCUU | DACZCONE | 7:0 | CMPSTAT | CMPPOL | | INSEL[2:0] | | HYSPOL | HYSS | EL[1:0] | | | 0x0C62 | DAC2CONH | 15:8 | | | | | TMCB[9:0] | | | | | | OXOGOZ | BAIOZOOMII | 7:0 | | | | TMCI | B[9:0] | | | | | | 0x0C64 | DAC2DATL | 15:8 | | | | | | DACLO | DW[11:0] | | | | | | 7:0 | DACLOW[11:0] | | | | | | | | | | 0x0C66 | DAC2DATH | 15:8 | | | | | | | CDAT[11:0] | | | | | | 7:0<br>15:8 | HCFSEL[3:0] | | | | SLPSTOPA[3:0] | | | | | | 0x0C68 | SLP2CONL | 7:0 | | | OPB[3:0] | | | | SLPSTRT[3:0] | | | | | | 15:8 | SLOPEN | SLF 31 | J-B[3.0] | | HME | TWME | PSE | | | | 0x0C6A | SLP2CONH | 7:0 | OLOI LIV | | | | Time | TVINE | TOE | | | | | control National Services | 15:8 | | | | SLPDA | T[15:8] | | | | | | 0x0C6C | SLP2DAT | 7:0 | | | | SLPD | | | | | | | 0x0C6E | | | | | | A | | | | | | | | Reserved | | | | | | | | | | | | 0x0C6F | | | | | | | | | | | | | 0x0C70 | DAC3CONL | 15:8 | DACEN | | M[1:0] | | | CBE | DACOEN | FLTREN | | | OXOGTO | BAGGGGAE | 7:0 | CMPSTAT | CMPPOL | | INSEL[2:0] | l/ | HYSPOL | | EL[1:0] | | | 0x0C72 | DAC3CONH | 15:8 | | | | | | | TMC | 3[9:0] | | | | | 7:0 | | | | TMCI | B[9:0] | D 4 6 1 6 | VAUC44.03 | | | | 0x0C74 | <b>DAC3DATL</b> | 15:8 | | | | DAGLO | \\\(\( \)\( \)\( \)\( \)\( \)\( \)\( \) | DACLC | )W[11:0] | | | | | | 7:0 | | | | DACLO | W[11:0] | DACD | AT[11:0] | | | | 0x0C76 | DAC3DATH | 15:8<br>7:0 | | | | DACD | L<br>AT[11:0] | DACD | AT[11:0] | | | | | | 15:8 | | ПСЕ | EL[3:0] | DACDA | λι[11. <b>υ</b> ] | QI DOT | OPA[3:0] | | | | 0x0C78 SL | SLP3CONL | 7:0 | | | OPB[3:0] | | | | RT[3:0] | | | | OXOCTO | OLI SOCIAL | 1.0 | | OLFOI | ני הוסיהו | | | SLESI | 1.1[0.0] | | | | 0,0070 | | 15:8 | SLOPEN | | | | HME | TWME | PSE | | | **High-Speed Analog Comparator with Slope Comp...** | conti | nued | | | | | | | | | | | |---------------------|---------------------------|-------------|-----------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------|--------------------|------------|---------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 15:8 | | | | | AT[15:8] | | | | | | 0x0C7C | SLP3DAT | 7:0 | | | | | AT[7:0] | | | | | | 0x0C7E | | 1.0 | | | | OLI DI | / (1 [7 .0] | | | | | | | Reserved | | | | | | | | | | | | 0x0C7F | | | | | | | | | | | | | 0x0C80 | DAC4CONL | 15:8 | DACEN | IRQN | /I[1:0] | | | CBE | DACOEN | FLTREN | | | 0,0000 | DAOTOONE | 7:0 | CMPSTAT | CMPPOL | | INSEL[2:0] | | HYSPOL | | EL[1:0] | | | 0x0C82 | DAC4CONH | 15:8 | | | | | | | TMCB[9:0] | | | | | | 7:0 | | | | TMC | B[9:0] | D.4.01.6 | 214/14/201 | | | | 0x0C84 | DAC4DATL | 15:8<br>7:0 | | | | DACLO | )<br>W[11:0] | DACLO | DW[11:0] | | | | | | 15:8 | | | | DACLC | [0.11] | DACD | AT[11:0] | | | | 0x0C86 | DAC4DATH | 7:0 | | | | DACD | L<br>AT[11:0] | DACD | AT[TT.0] | | | | | | 15:8 | | HCFS | FI [3:01 | DAODA | 1[11.0] | SLPST | OPA[3:0] | | | | 0x0C88 | SLP4CONL | 7:0 | | | DPB[3:0] | | | | TRT[3:0] | | | | | | 15:8 | SLOPEN | | | | HME | TWME | PSE | | | | 0x0C8A | SLP4CONH | 7:0 | | | | | Arriva de de | | | | | | 0.0000 | OLDADAT. | 15:8 | | | | SLPDA | AT[15:8] | , | | , | | | 0x0C8C | SLP4DAT | 7:0 | | | | SLPD | AT[7:0] | | | | | | 0x0C8E | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0C8F | | 200.00 | | | | | | | | | | | 0x0C90 | DAC5CONL | 15:8 | DACEN | IRQN | <i>I</i> [1:0] | | | CBE | DACOEN | FLTREN | | | | | 7:0 | CMPSTAT | CMPPOL | | INSEL[2:0] | | HYSPOL | | EL[1:0] | | | 0x0C92 | DAC5CONH | 15:8<br>7:0 | | | | | | TMC | B[9:0] | | | | | | 15:8 | TMCB[9:0] DACLOW[11:0] | | | | | | | | | | 0x0C94 | DAC5DATL | 7:0 | | DACLOW[11:0] | | | | | | | | | No. No. of Contract | Managari en appropriation | 15:8 | DACDAT[11:0] | | | | | | | | | | 0x0C96 | DAC5DATH | 7.0 | | | | DACD | AT[11.0] | | | | | | 00000 | OL DECONII | 15:8 | | HCFS | EL[3:0] | | SLPSTOPA[3:0] | | | | | | 0x0C98 | SLP5CONL | 7:0 | | SLPSTO | DPB[3:0] | | SLPSTRT[3:0] | | | | | | 0x0C9A | SLP5CONH | 15:8 | SLOPEN | | | | HME | TWME | PSE | | | | UXUUUA | OLI SCONTI | 7:0 | | | | | | | | | | | 0x0C9C | SLP5DAT | 15:8 | | | | | AT[15:8] | - | | | | | | | 7:0 | | 1 | | SLPD | AT[7:0] | | 1 | I | | | 0x0C9E | Reserved | | | | | | | | | | | | 0x0C9F | Reserveu | | | | | | | | | | | | | | 15:8 | DACEN | IRON | <br>И[1:0] | | | CBE | DACOEN | FLTREN | | | 0x0CA0 | DAC6CONL | 7:0 | CMPSTAT | CMPPOL | 1 | INSEL[2:0] | | HYSPOL | | EL[1:0] | | | 0.05:5 | D.4.00==:::: | 15:8 | (C) | | | | | 0.004 .003 .00-005 | | B[9:0] | | | 0x0CA2 | DAC6CONH | 7:0 | | | | TMC | B[9:0] | | | | | | 0x0CA4 | DAC6DATL | 15:8 | | | | | | DACLO | DW[11:0] | | | | UXUCA4 | DACODATE | 7:0 | | | | DACLC | W[11:0] | | | | | | 0x0CA6 | DAC6DATH | 15:8 | | | | | | DACD | AT[11:0] | | | | 5, ,0 | -,, | 7:0 | | | | DACD | AT[11:0] | | | | | | 0x0CA8 | SLP6CONL | 15:8 | | HCFS | of the control | | | | OPA[3:0] | | | | | | 7:0 | OL ODEN | SLPSTO | DPB[3:0] | | LINAT | | RT[3:0] | | | | 0x0CAA | SLP6CONH | 15:8 | SLOPEN | | | | HME | TWME | PSE | | | | | | 7:0<br>15:8 | | | | el DD/ | <br>AT[15:8] | | | | | | 0x0CAC | SLP6DAT | 7:0 | | | | | AT[7:0] | | | | | | | | 1.0 | | | | OLF D | [ro] | | | | | 70005452B-page 621 ## **High-Speed Analog Comparator with Slope Comp...** #### 14.4.1 **DAC Control 1 Low Register** Name: DACCTRL1L Offset: 0xC48 #### Note: 1. These bits should only be changed when DACON = 0 to avoid unpredictable behavior. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------------|---------|-------------|----|-----|--------------|-----| | | DACON | | DACSIDL | | | | | | | Access | R/W | | R/W | | | | | | | Reset | 0 | | 0 | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CLKSI | CLKSEL[1:0] | | CLKDIV[1:0] | | | FCLKDIV[2:0] | | | Access | R/W | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | #### Bit 15 - DACON Common DAC Module Enable bit | Value | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Enables DAC modules | | 0 | Disables DAC modules and disables FSCM clocks to reduce power consumption; any pending Slope mode and/or underflow conditions are cleared | ### Bit 13 - DACSIDL DAC Stop in Idle Mode bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation in Idle mode | #### Bits 7:6 - CLKSEL[1:0] DAC Clock Source Select bits(1) | Value | Description | |-------|---------------------| | 11 | F <sub>PLLO</sub> | | 10 | AF <sub>PLLO</sub> | | 01 | F <sub>VCO/2</sub> | | 00 | AF <sub>VCO/2</sub> | ## Bits 5:4 - CLKDIV[1:0] DAC Clock Divider bits<sup>(1)</sup> | Value | Description | |-------|--------------------------------------| | 11 | Divide-by-4 | | 10 | Divide-by-3 (non-uniform duty cycle) | | 01 | Divide-by-2 | | 00 | 1x | ## Bits 2:0 - FCLKDIV[2:0] Comparator Filter Clock Divider bits | Value | Description | |-------|-------------| | 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 | 1x | Datasheet © 2021 Microchip Technology Inc. **High-Speed Analog Comparator with Slope Comp...** ## 14.4.2 DAC Control 2 Low Register Name: DACCTRL2L Offset: 0xC4C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|----------|-----|-------|----------| | | | | | | | | TMODT | IME[9:0] | | Access | | | | ). | | 2 | R/W | R/W | | Reset | | | | | | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TMODT | IME[9:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 9:0 - TMODTIME[9:0] Transition Mode Duration bits **High-Speed Analog Comparator with Slope Comp...** ## 14.4.3 DAC Control 2 High Register Name: DACCTRL2H Offset: 0xC4E ### Note: 1. The value for SSTIME[9:0] should be greater than the TMODTIME[9:0] value. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-------|---------| | | | | | | | | SSTIN | 1E[9:0] | | Access | | | | | | | R/W | R/W | | Reset | | | | | | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | SSTIM | 1E[9:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 9:0 – SSTIME[9:0] Time from Start of Transition Mode until Steady-State Filter is Enabled bits<sup>(1)</sup> # **High-Speed Analog Comparator with Slope Comp...** #### 14.4.4 **DACx Control Low Register** Name: **DACxCONL** Offset: 0xC50, 0xC60, 0xC70, 0xC80, 0xC90, 0xCA0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|--------|---------|------------|-----|--------|--------|---------| | | DACEN | IRQI | /I[1:0] | | | CBE | DACOEN | FLTREN | | Access | R/W | R/W | R/W | | | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CMPSTAT | CMPPOL | | INSEL[2:0] | | HYSPOL | HYSSE | EL[1:0] | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - DACEN Individual DACx Module Enable bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------------------| | 1 | Enables DACx module | | 0 | Disables DACx module to reduce power consumption; any pending Slope mode and/or underflow conditions are cleared | ### Bits 14:13 - IRQM[1:0] Interrupt Mode select bits | Value | Description | |-------|------------------------------------------------------------------| | 11 | Generates an interrupt on either a rising or falling edge detect | | 10 | Generates an interrupt on a falling edge detect | | 01 | Generates an interrupt on a rising edge detect | | 00 | Interrupts are disabled | ## Bit 10 - CBE Comparator Blank Enable bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------------------------| | 1 | Enables the analog comparator output to be blanked (gated off) during the recovery transition following | | | the completion of a slope operation | | 0 | Disables the blanking signal to the analog comparator; therefore, the analog comparator output is always active | ## Bit 9 - DACOEN DACx Output Buffer Enable bit | Value | Description | | | | | |-------|---------------------------------------------------------|--|--|--|--| | 1 | DACx analog voltage is connected to the DACOUT1 pin | | | | | | 0 | DACx analog voltage is not connected to the DACOUT1 pin | | | | | ## Bit 8 - FLTREN Comparator Digital Filter Enable bit | Value | Description | |-------|----------------------------| | 1 | Digital filter is enabled | | 0 | Digital filter is disabled | ## Bit 7 - CMPSTAT Comparator Status bits #### Bit 6 - CMPPOL Comparator Output Polarity Control bit | Value | Description | |-------|-----------------------| | 1 | Output is inverted | | 0 | Output is noninverted | #### Bits 5:3 - INSEL[2:0] Comparator Input Source Select bits | Value | Description | |-------|-------------| | · ala | Beschipaen | | 111 | Reserved | | 111 | ricocived | Datasheet 70005452B-page 624 © 2021 Microchip Technology Inc. **High-Speed Analog Comparator with Slope Comp...** | Value | Description | |-------|-----------------| | 110 | Reserved | | 101 | Reserved | | 100 | Reserved | | 011 | CMPxD input pin | | 010 | CMPxC input pin | | 001 | CMPxB input pin | | 000 | CMPxA input pin | #### Bit 2 - HYSPOL Comparator Hysteresis Polarity Select bit | Value | Description | |-------|--------------------------------------------------------------------| | 1 | Hysteresis is applied to the falling edge of the comparator output | | 0 | Hysteresis is applied to the rising edge of the comparator output | ## Bits 1:0 - HYSSEL[1:0] Comparator Hysteresis Select bits | Value | Description | |-------|---------------------------| | 11 | 45 mv hysteresis | | 10 | 30 mv hysteresis | | 01 | 15 mv hysteresis | | 00 | No hysteresis is selected | **High-Speed Analog Comparator with Slope Comp...** ## 14.4.5 DACx Control High Register Name: DACxCONH Offset: 0xC52, 0xC62, 0xC72, 0xC82, 0xC92, 0xCA2 Bits 9:0 - TMCB[9:0] DACx Leading-Edge Blanking bits These register bits specify the blanking period for the comparator, following changes to the DAC output during Change-of-State (COS), for the input signal selected by the HCFSEL[3:0] bits in 14.4.8 SLPxCONL. **High-Speed Analog Comparator with Slope Comp...** ## 14.4.6 DACx Data Low Register Name: DACxDATL **Offset:** 0xC54, 0xC64, 0xC74, 0xC84, 0xC94, 0xCA4 Bits 11:0 - DACLOW[11:0] DACx Low Data bits In Hysteretic mode, Slope Generator mode and Triangle mode, this register specifies the low data value and/or limit for the DACx module. Valid values are from 205 to 3890. ## **High-Speed Analog Comparator with Slope Comp...** ## 14.4.7 DACx Data High Register Name: DACxDATH **Offset:** 0xC56, 0xC66, 0xC76, 0xC86, 0xC96, 0xCA6 Bits 11:0 - DACDAT[11:0] DACx High Data bits This register specifies the high DACx data value. Valid values are from 205 to 3890. ### 14.4.8 DAC Slope x Control Low Register Name: SLPxCONL Offset: 0xC58, 0xC68, 0xC78, 0xC88, 0xC98, 0xCA8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|--------|----------|-----|---------------|-------|---------|-----| | | HCFSEL[3:0] | | | | SLPSTOPA[3:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | SLPSTO | DPB[3:0] | | | SLPST | RT[3:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:12 - HCFSEL[3:0] Hysteretic Comparator Function Input Select bits The selected input signal controls the switching between the DACx high limit (DACxDATH) and the DACx low limit (DACxDATL) as the data source for the PDM DAC. It modifies the polarity of the comparator, and the rising and falling edges initiate the start of the LEB counter (TMCB[9:0] bits in 14.4.5 DACxCONH). | Input Selection | Source | |-----------------|--------| | 1111 | 1 | | 1100 | 0 | | 1011 | 0 | | 1010 | 0 | | 1001 | 0 | | 1000 | PWM8H | | 0111 | PWM7H | | 0110 | PWM6H | | 0101 | PWM5H | | 0100 | PWM4H | | 0011 | PWM3H | | 0010 | PWM2H | | 0001 | PWM1H | | 0000 | 0 | ## Bits 11:8 - SLPSTOPA[3:0] Slope Stop A Signal Select bits The selected Slope Stop A signal is logically OR'd with the selected Slope Stop B signal to terminate the slope function. | Slope Stop A Signal Selection | Source | |-------------------------------|----------------| | 1101-1111 | 1 | | 1000 | PWM8 Trigger 2 | | 0111 | PWM7 Trigger 2 | | 0110 | PWM6 Trigger 2 | | 0101 | PWM5 Trigger 2 | | 0100 | PWM4 Trigger 2 | | 0011 | PWM3 Trigger 2 | | 0010 | PWM2 Trigger 2 | | 0001 | PWM1 Trigger 2 | | 0000 | 0 | ### Bits 7:4 - SLPSTOPB[3:0] Slope Stop B Signal Select bits The selected Slope Stop B signal is logically OR'd with the selected Slope Stop A signal to terminate the slope function. **High-Speed Analog Comparator with Slope Comp...** | Slope Stop B Signal Selection | Source | |-------------------------------|----------| | 0100-0111 | 1 | | 0110 | CMP6 out | | 0101 | CMP5 out | | 0100 | CMP4 out | | 0011 | CMP3 out | | 0010 | CMP2 out | | 0001 | CMP1 out | | 0000 | 0 | ## Bits 3:0 - SLPSTRT[3:0] Slope Start Signal Select bits | Slope Start Signal Selection | Source | |------------------------------|----------------| | 1101-1111 | 1 | | 1000 | PWM8 Trigger 1 | | 0111 | PWM7 Trigger 1 | | 0110 | PWM6 Trigger 1 | | 0101 | PWM5 Trigger 1 | | 0100 | PWM4 Trigger 1 | | 0011 | PWM3 Trigger 1 | | 0010 | PWM2 Trigger 1 | | 0001 | PWM1 Trigger 1 | | 0000 | 0 | ## **High-Speed Analog Comparator with Slope Comp...** ## 14.4.9 DAC Slope x Control High Register Name: SLPxCONH Offset: 0xC5A, 0xC6A, 0xC7A, 0xC8A, 0xC9A, 0xCAA #### Notes: 1. HME mode requires the user to disable the slope function (SLOPEN = 0). 2. TWME mode requires the user to enable the slope function (SLOPEN = 1). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|----|----|-----|------|-----|---| | | SLOPEN | | | | HME | TWME | PSE | | | Access | R/W | | | | R/W | R/W | R/W | | | Reset | 0 | | | | 0 | 0 | 0 | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset Bit 15 - SLOPEN Slope Function Enable/On bit | | PEG EN CIOPO I GITOGOTI ENGLISTO | |-------|------------------------------------------------------------------------------------| | Value | Description | | 1 | Enables slope function | | 0 | Disables slope function; slope accumulator is disabled to reduce power consumption | #### Bit 11 - HME Hysteretic Mode Enable bit(1) | Value | Description | |-------|-----------------------------------| | 1 | Enables Hysteretic mode for DACx | | 0 | Disables Hysteretic mode for DACx | ## Bit 10 - TWME Triangle Wave Mode Enable bit(2) | Value | Description | |-------|--------------------------------------| | 1 | Enables Triangle Wave mode for DACx | | 0 | Disables Triangle Wave mode for DACx | ## Bit 9 - PSE Positive Slope Mode Enable bit | Value | Description | |-------|-------------------------------------| | 1 | Slope mode is positive (increasing) | | 0 | Slope mode is negative (decreasing) | ## **High-Speed Analog Comparator with Slope Comp...** ## 14.4.10 DAC Slope x Data Register Name: SLPxDAT Offset: 0xC5C, 0xC6C, 0xC7C, 0xC8C, 0xC9C, 0xCAC | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-------|---------|-----|-----|-----|--|--| | | | | | SLPDA | T[15:8] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SLPDAT[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 – SLPDAT[15:0] Slope Ramp Rate Value bits The SLPDATx value is in 12.4 format. ## 15. Quadrature Encoder Interface (QEI) #### Notes: - This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive resource. For more information, refer to the "Quadrature Encoder Interface (QEI)" (www.microchip.com/DS70000601) in the "dsPIC33/PIC24 Family Reference Manual." - 2. Some registers and associated bits described in this section may not be available on all devices. Refer to 4. Memory Organization in this data sheet for device-specific register and bit information. The Quadrature Encoder Interface (QEI) module provides the interface to incremental encoders for obtaining mechanical position data. Quadrature Encoders, also known as incremental encoders or optical encoders, detect position and speed of rotating motion systems. Quadrature Encoders enable closed-loop control of motor control applications, such as Switched Reluctance (SR) and AC Induction Motors (ACIM). A typical Quadrature Encoder includes a slotted wheel attached to the shaft of the motor and an emitter/detector module that senses the slots in the wheel. Typically, three output channels, Phase A (QEAx), Phase B (QEBx) and Index (INDXx), provide information on the movement of the motor shaft, including distance and direction. The two channels, Phase A (QEAx) and Phase B (QEBx), are typically 90 degrees out of phase with respect to each other. The Phase A and Phase B channels have a unique relationship. If Phase A leads Phase B, the direction of the motor is deemed positive or forward. If Phase A lags Phase B, the direction of the motor is deemed negative or reverse. The Index pulse occurs once per mechanical revolution and is used as a reference to indicate an absolute position. Figure 15-1 illustrates the Quadrature Encoder Interface signals. The Quadrature signals from the encoder can have four unique states ('01', '00', '10' and '11') that reflect the relationship between QEAx and QEBx. Figure 15-1 illustrates these states for one count cycle. The order of the states get reversed when the direction of travel changes. The Quadrature Decoder increments or decrements the 32-bit up/down Position x Counter (POSxCNTH/L) registers for each Change-of-State (COS). The counter increments when QEAx leads QEBx and decrements when QEBx leads QEAx. Table 15-1 shows an overview of the QEI module. Figure 15-1. Quadrature Encoder Interface Signals Table 15-1 shows the truth table that describes how the Quadrature signals are decoded. Table 15-1. Truth Table for Quadrature Encoder | Current Qua | drature State | Previous Qua | adrature State | Action | | | |-------------|---------------|--------------|----------------|------------------------------|--|--| | QA | QB | QA | QB | Action | | | | 1, | 1 | 1 | 1 | No count or direction change | | | | 1 | 1 | 1 | 0 | Count up | | | | 1 | 1 | 0 | 1 | Count down | | | Quadrature Encoder Interface (QEI) | continued | | | | | | | | | | | |-------------|---------------|--------------|---------------|------------------------------|--|--|--|--|--|--| | Current Qua | drature State | Previous Qua | drature State | Action | | | | | | | | QA | QB | QA | QB | Action | | | | | | | | 1 | 1, | 0 | 0 | Invalid state change; ignore | | | | | | | | 1 | 0 | 1 | 1 | Count down | | | | | | | | 1 | 0 | 1 | 0 | No count or direction change | | | | | | | | 1 | 0 | 0 | 1 | Invalid state change; ignore | | | | | | | | 1 | 0 | 0 | 0 | Count up | | | | | | | | 0 | 1 | 1 | 1 | Count up | | | | | | | | 0 | 1 | 1 | 0 | Invalid state change; ignore | | | | | | | | 0 | 1 | 0 | 1 | No count or direction change | | | | | | | | 0 | 1 | 0 | 0 | Count down | | | | | | | | 0 | 0 | 1 | 1 | Invalid state change; ignore | | | | | | | | 0 | 0 | 1 | 0 | Count down | | | | | | | | 0 | 0 | 0 | 1 | Count up | | | | | | | | 0 | 0 | 0 | 0 | No count or direction change | | | | | | | Figure 15-2 illustrates the simplified block diagram of the QEI module. The QEI module consists of decoder logic to interpret the Phase A (QEAx) and Phase B (QEBx) signals, and an up/down counter to accumulate the count. The counter pulses are generated when the Quadrature state changes. The count direction information must be maintained in a register until a direction change is detected. The module also includes digital noise filters, which condition the input signal. 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 (INDXx) 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 ## 15.1 QEI Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------|--------|-------------|------------|----------------------|----------|----------|----------|--|--| | 0x0140 | QEI1CON | 15:8 | QEIEN | | QEISIDL | | PIMOD[2:0] | | IMV | [1:0] | | | | 000140 | QEITCON | 7:0 | | | INTDIV[2:0] | | CNTPOL | GATEN | CCM | l[1:0] | | | | 0x0142 | | | | | | | | | | | | | | 0x0143 | Reserved | | | | | | | | | | | | | | | 15:8 | QCAPEN | FLTREN | | QFDIV[2:0] | | OUTF | NC[1:0] | SWPAB | | | | 0x0144 | QEI1IOCL | 7:0 | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | | | | | GALLINA SALVA | 15:8 | | | | <u></u> | | | | | | | | 0x0146 | QEI1IOCH(1) | 7:0 | | | | | | | | HCAPEN | | | | 0x0148 | QEI1STAT | 15:8 | | | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | | | | 0X0146 | QEIISIAI | 7:0 | PCIIRQ | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | | | | 0x014A | | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | | 0x014B | | 15.0 | | | | DOCCA | ITI4E:01 | | | | | | | 0x014C | POS1CNTL | 15:8<br>7:0 | | | | | NT[15:8]<br>NT[7:0] | | | | | | | | | 15:8 | | | | | T[31:24] | | | | | | | 0x014E | POS1CNTH | 7:0 | | | | | T[23:16] | | | | | | | 0x0150 | | | | | | | | | | | | | | *** | Reserved | | | | | | | | | | | | | 0x0151 | | | | | | | | | | | | | | 0x0152 | POS1HLDH | 15:8 | | | | | H[31:24] | | | | | | | | | 7:0 | | | | | DH[23:16] | | | | | | | 0x0154 | VEL1CNTL | 15:8 | VELCNT[15:8] | | | | | | | | | | | | | 7:0 | VELCNT[7:0] VELCNT[31:24] | | | | | | | | | | | 0x0156 | VEL1CNTH(1) | 15:8<br>7:0 | | | | | T[23:16] | | | | | | | 0x0158 | | 7.0 | | | | VELCIN | 1[23.10] | | | | | | | | Reserved | | | | | | | | | | | | | 0x0159 | | | | | | | | | | | | | | 0x015A | VEL1HLDH | 15:8 | | | | | H[31:24] | | | | | | | UXUTSA | VELTHEDH | 7:0 | | | | | H[23:16] | | | | | | | 0x015C | INT1TMRL | 15:8 | | | | | R[15:8] | | | | | | | CONTRACTOR CONTRACTOR | 1000 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 10 | 7:0 | | | | | IR[7:0] | | | | | | | 0x015E | INT1TMRH | 15:8 | | | | | R[31:24] | | | | | | | | | 7:0<br>15:8 | | | | | R[23:16]<br>_D[15:8] | | | | | | | 0x0160 | INT1HLDL | 7:0 | | | | INTXH | 5/1 5 | | | | | | | | | 15:8 | | | | | D[31:24] | | | | | | | 0x0162 | INT1HLDH | 7:0 | | | | | 0[23:16] | | | | | | | 0x0164 | INDX1CNTL | 15:8 | | | | INDXCI | NT[15:8] | | | | | | | 0.00104 | INDATONIL | 7:0 | | | | INDXC | NT[7:0] | | | | | | | 0x0166 | INDX1CNTH | 15:8 | | | | | IT[31:24] | | | | | | | 27.5500 A.C. W. Libba and a | | 7:0 | | | | INDXCN | IT[23:16] | | | | | | | 0x0168 | Percryod | | | | | | | | | | | | | 0x0169 | Reserved | | | | | | | | | | | | | | | 15:8 | | | | INDXHLI | DH[31:24] | | | | | | | 0x016A | INDX1HLDH | 7:0 | | | | | DH[23:16] | | | | | | | 0,0400 | OFMOTO | 15:8 | | | | QEIGE | C[15:8] | | | | | | | 0x016C | QEI1GECL | 7:0 | | | | QEIGE | EC[7:0] | | | | | | | 0x016E | QEI1GECH | 15:8 | | | | | 0[31:24] | | | | | | | - CASTOL | QLITOLOTT | 7:0 | | | | | C[23:16] | | | | | | | 0x0170 | QEI1LECL | 15:8 | | | | | C[15:8] | | | | | | | | The second secon | 7:0 | QEILEC[7:0] | | | | | | | | | | Quadrature Encoder Interface (QEI) | conti | | | | | | | | | | | |----------|------------------------------|-------------|--------|--------|-------------|-----------------|----------------------|----------|----------|----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0172 | QEI1LECH | 15:8 | | | | QEILE | | | | | | 0.0172 | QEITEEOIT | 7:0 | | | | QEILE | | | | | | 0x0174 | QEI2CON | 15:8 | QEIEN | | QEISIDL | | PIMOD[2:0] | | | [1:0] | | 0.0470 | | 7:0 | | | INTDIV[2:0] | | CNTPOL | GATEN | CCM | 1[1:0] | | 0x0176 | Reserved | | | | | | | | | | | 0x0177 | Reserved | | | | | | | | | | | | OFINION | 15:8 | QCAPEN | FLTREN | | QFDIV[2:0] | | OUTF | NC[1:0] | SWPAB | | 0x0178 | QEI2IOCL | 7:0 | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | | 0x017A | QEI2IOCH(1) | 15:8 | | | | | | | | | | OXO 1771 | QLIZIOON(1) | 7:0 | | | | | | | | HCAPEN | | 0x017C | QEI2STAT | 15:8 | | | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | | | . 162 30 1886 376 000 | 7:0 | PCIIRQ | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | | 0x017E | Reserved | | | | | | | | | | | 0x017F | Reserved | | | | | | | | | | | | (E-67-612 2 - 120) | 15:8 | | | | POSCN | NT[15:8] | | | | | 0x0180 | POS2CNTL | 7:0 | | | | | NT[7:0] | | | | | 00400 | DOCCONTU | 15:8 | | | | POSCN | T[31:24] | | | | | 0x0182 | POS2CNTH | 7:0 | | | | POSCN | T[23:16] | | | | | 0x0184 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0187 | | | | | | | | | | | | 0x0188 | VEL2CNTL | 15:8<br>7:0 | | | | VELCI | | | | | | | | 15:8 | | | | VELCN | | | | | | 0x018A | VEL2CNTH(1) | 7:0 | | | | VELCN | | | | | | 0x018C | | | | | | A. 2001 BOX 200 | | | | | | | Reserved | | | | | | | | | | | 0x018F | | | | | | | | | | | | 0x0190 | INT2TMRL | 15:8 | | | | INTTM | | | | | | | 1,304 (1,000) | 7:0 | | | | | IR[7:0] | | | | | 0x0192 | INT2TMRH | 15:8<br>7:0 | | | | | R[31:24]<br>R[23:16] | | | | | | | 15:8 | | | | | .D[15:8] | | | | | 0x0194 | INT2HLDL | 7:0 | | | | INTXH | | | | | | | Tariba Caraca | 15:8 | | | | INTHL | | | | | | 0x0196 | INT2HLDH | 7:0 | | | | INTHL | 0[23:16] | | | | | 0x0198 | INDX2CNTL | 15:8 | | | | INDXCI | | | | | | 0.0130 | INDAZCINTE | 7:0 | | | | INDXC | | | | | | 0x019A | INDX2CNTH | 15:8 | | | | | T[31:24] | | | | | | 2404.00 PA 12 TO A 10 A 10 A | 7:0 | | | 1 | INDXCN | T[23:16] | | 1 | | | 0x019C | Reserved | | | | | | | | | | | 0x019F | Reserved | | | | | | | | | | | | (2 m) 2 m (2 m) | 15:8 | | | | QEIGE | C[15:8] | | | | | 0x01A0 | QEI2GECL | 7:0 | | | | | C[7:0] | | | | | 0v0143 | OFICECU | 15:8 | | | | QEIGE | | | | | | 0x01A2 | QEI2GECH | 7:0 | | | | QEIGE | | | | | | 0x01A4 | QEI2LECL | 15:8 | | | | | C[15:8] | | | | | | | 7:0 | | | | | C[7:0] | | | | | 0x01A6 | QEI2LECH | 15:8 | | | | | [31:24] | | | | | 0v0149 | | 7:0 | | | 1 | QEILE | C[23:16] | | | | | 0x01A8 | Reserved | | | | | | | | | | | | . 13001700 | | | | | | | | | | | 0x053F | | | | | | | | | 1 | | | 0x0540 | QEI3CON | 15:8 | QEIEN | | QEISIDL | | PIMOD[2:0] | | IMV | [1:0] | Quadrature Encoder Interface (QEI) | conti | continued | | | | | | | | | | | | |---------|------------------|-------------|-----------------------------|---------------|--------------|-------------|---------------------|----------|----------|----------|--|--| | | | | | | _ | | | | | | | | | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 0x0542 | | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | | 0x0543 | | 45.0 | OCADEN | FLTDEN | | OEDIV(10:01 | | OUTE | NCI4.01 | CIMPAD | | | | 0x0544 | <b>QEI3IOCL</b> | 15:8<br>7:0 | QCAPEN | FLTREN | OEDBOI | QFDIV[2:0] | HOME | | NC[1:0] | SWPAB | | | | | | 15:8 | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | | | | 0x0546 | QEI3IOCH(1) | 7:0 | | | | | | | | HCAPEN | | | | | t com attraction | 15:8 | | | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | | | | 0x0548 | QEI3STAT | 7:0 | PCIIRQ | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | | | | 0x054A | | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | | 0x054B | | | | | | | | | | | | | | 0x054C | POS3CNTL | 15:8 | | | | | IT[15:8] | | | | | | | 3,00,10 | | 7:0 | | | | | NT[7:0] | | | | | | | 0x054E | POS3CNTH | 15:8 | | | | | T[31:24] | | | | | | | | | 7:0 | | | | POSCN | T[23:16] | | | | | | | 0x0550 | Reserved | | | | | | | | | | | | | 0x0553 | Reserveu | | | | | | | | | | | | | | | 15:8 | | | | VELCN | T[15:8] | | | | | | | 0x0554 | VEL3CNTL | 7:0 | VELCNT[7:0] | | | | | | | | | | | | Density Control | 15:8 | | VELCNT[31:24] | | | | | | | | | | 0x0556 | VEL3CNTH(1) | 7:0 | VELCNT[23:16] | | | | | | | | | | | 0x0558 | | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | | 0x055B | | | | | | | | | | | | | | 0x055C | INT3TMRL | 15:8 | | | | | R[15:8] | | | | | | | | | 7:0<br>15:8 | | | | | IR[7:0]<br>R[31:24] | | | | | | | 0x055E | INT3TMRH | 7:0 | | | | | | | | | | | | | | 15:8 | INTTMR[23:16] INTXHLD[15:8] | | | | | | | | | | | 0x0560 | INT3HLDL | 7:0 | | | INTXHLD[7:0] | | | | | | | | | 0.0555 | WITCH TO THE | 15:8 | | | | INTHL | | | | | | | | 0x0562 | INT3HLDH | 7:0 | | | | | [23:16] | | | | | | | 0x0564 | INDX3CNTL | 15:8 | | | | | NT[15:8] | | | | | | | 000004 | INDASCINTE | 7:0 | | | | INDXC | NT[7:0] | | | | | | | 0x0566 | INDX3CNTH | 15:8 | | | | | T[31:24] | | | | | | | | III DAGGITTI | 7:0 | | | | INDXCN | T[23:16] | | | | | | | 0x0568 | Deer | | | | | | | | | | | | | 0x056B | Reserved | | | | | | | | | | | | | | | 15:8 | | | | OFIGE | C[15:8] | | | | | | | 0x056C | QEI3GECL | 7:0 | | | | | EC[7:0] | | | | | | | | 0202000000000 | 15:8 | | | | | C[31:24] | | | | | | | 0x056E | QEI3GECH | 7:0 | | | | | C[23:16] | | | | | | | 0.0570 | OFINE FOL | 15:8 | | | | | C[15:8] | | | | | | | 0x0570 | QEI3LECL | 7:0 | | | | QEILE | C[7:0] | | | | | | | 0x0572 | QEI3LECH | 15:8 | | | | QEILE | 0[31:24] | | | | | | | 0,0012 | QLIOLLOTT | 7:0 | | | | QEILE | C[23:16] | | | | | | ## 15.1.1 QEIx Control Register Name: QEIxCON **Offset:** 0x140, 0x174, 0x540 #### Notes: - 1. When CCMx = 10 or CCMx = 11, all of the QEI counters operate as timers and the PIMOD[2:0] bits are ignored. - 2. When CCMx = 00, and QEAx and QEBx values match the 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. - Not all devices support this mode. - The QCAPEN and HCAPEN bits must be cleared during PIMODx Modes 2 through 7 to ensure proper functionality. Not all devices support HCAPEN. | Bit | 15 | 14 | 13 12 | | 11 | 10 | 9 | 8 | |--------|-------|-----|-------------|-----|------------|-------|-----|--------| | | QEIEN | | QEISIDL | | PIMOD[2:0] | | IMV | [1:0] | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | _ | _ | _ | | - | _ | | _ | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | INTDIV[2:0] | | CNTPOL | GATEN | CCM | I[1:0] | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 15 - QEIEN Quadrature Encoder Interface Module Enable bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Module counters are enabled | | 0 | Module counters are disabled, but SFRs can be read or written | ### Bit 13 - QEISIDL QEI Stop in Idle Mode bit | 1 | Value | Description | |---|-------|------------------------------------------------------------| | | 1 | Discontinues module operation when device enters Idle mode | | Ì | 0 | Continues module operation in Idle mode | ### Bits 12:10 - PIMOD[2:0] Position Counter Initialization Mode Select bits (1,5) | D113 12.10 | Timob[2:0] Toolion counter intralization wode octob bio | | | | |------------|---------------------------------------------------------------------------------------------------------|--|--|--| | Value | Description | | | | | 111 | Modulo Count mode for position counter and every Index event resets the position counter <sup>(4)</sup> | | | | | 110 | Modulo Count mode for position counter | | | | | 101 | Resets the position counter when the position counter equals the QEIxGEC register | | | | | 100 | Second Index event after Home event initializes the position counter with the contents of the QEIxIC | | | | | | register | | | | | 011 | First Index event after Home event initializes the position counter with the contents of the QEIxIC | | | | | | register | | | | | 010 | Next Index input event initializes the position counter with the contents of the QEIxIC register | | | | | 001 | Every Index input event resets the position counter | | | | | 000 | Index input event does not affect the position counter | | | | | | | | | | ### Bits 9:8 - IMV[1:0] Index Match Value bits(2) | Value | Description | |-------|-----------------------------------------------| | 11 | Index match occurs when QEBx = 1 and QEAx = 1 | | 10 | Index match occurs when QEBx = 1 and QEAx = 0 | | 01 | Index match occurs when QEBx = 0 and QEAx = 1 | | 00 | Index match occurs when QEBx = 0 and QEAx = 0 | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 639 **Quadrature Encoder Interface (QEI)** Bits 6:4 – INTDIV[2:0] Timer Input Clock Prescale Select bits<sup>(3)</sup> (interval timer, main timer (position counter), velocity counter and Index counter internal clock divider select) | Value | Description | |-------|----------------------| | 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 - CNTPOL Position and Index Counter/Timer Direction Select bit | Value | Description | | | | | |-------|-----------------------------------------------------------------------------|--|--|--|--| | 1 | Counter direction is negative unless modified by an external up/down signal | | | | | | 0 | Counter direction is positive unless modified by an external up/down signal | | | | | ### Bit 2 - GATEN External Count Gate Enable bit | Value | Description | |-------|-----------------------------------------------------------------| | 1 | External gate signal controls position counter operation | | 0 | External gate signal does not affect position counter operation | ### Bits 1:0 - CCM[1:0] Counter Control Mode Selection bits | | The tree control control mode concentration | | | |-------|-------------------------------------------------|--|--| | Value | Description | | | | 11 | Internal Timer mode | | | | 10 | External Clock Count with External Gate mode | | | | 01 | External Clock Count with External Up/Down mode | | | | 00 | Quadrature Encoder mode | | | ## 15.1.2 QEIx I/O Control Register Name: QEIXIOCL **Offset:** 0x144, 0x178, 0x544 **Legend:** x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|------------|------|-------|---------|-------| | | QCAPEN | FLTREN | | QFDIV[2:0] | | OUTF | NC[1:0] | SWPAB | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | HOMPOL | IDXPOL | QEBPOL | QEAPOL | HOME | INDEX | QEB | QEA | | Access | R/W | R/W | R/W | R/W | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | X | X | X | X | #### Bit 15 - QCAPEN QEIx Position Counter Input Capture Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------------------| | 1 | HOMEx input event (positive edge) triggers a position capture event (HCAPEN must be cleared) | | 0 | HOMEx input event (positive edge) does not trigger a position capture event | ### Bit 14 - FLTREN QEAx/QEBx/INDXx/HOMEx Digital Filter Enable bit | Value | Description | | | | |-------|-------------------------------------------------|--|--|--| | 1 | Input pin digital filter is enabled | | | | | 0 | Input pin digital filter is disabled (bypassed) | | | | ### Bits 13:11 - QFDIV[2:0] QEAx/QEBx/INDXx/HOMEx Digital Input Filter Clock Divide Select bits | Value | Description | |-------|--------------------| | 111 | 1:256 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 | #### Bits 10:9 - OUTFNC[1:0] QEIx Module Output Function Mode Select bits | Value | Description | |-------|-----------------------------------------------------------------------| | 11 | The CNTCMPx pin goes high when POSxCNT ≤ QEIxLEC or POSxCNT ≥ QEIxGEC | | 10 | The CNTCMPx pin goes high when POSxCNT ≤ QEIxLEC | | 01 | The CNTCMPx pin goes high when POSxCNT ≥ QEIxGEC | | 00 | Output is disabled | ## Bit 8 - SWPAB Swap QEAx and QEBx Inputs bit | Value | Description | | | | |-------|-------------------------------------------------------------|--|--|--| | 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 | Value | Description | |-------|-----------------------| | 1 | Input is inverted | | 0 | Input is not inverted | ## Bit 6 - IDXPOL INDXx Input Polarity Select bit **Quadrature Encoder Interface (QEI)** | Value | Description | |-------|-----------------------| | 1 | Input is inverted | | 0 | Input is not inverted | #### Bit 5 - QEBPOL QEBx Input Polarity Select bit | Value | Description | |-------|-----------------------| | 1 | Input is inverted | | 0 | Input is not inverted | #### Bit 4 - QEAPOL QEAx Input Polarity Select bit | | and the derivative of the state | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 1 | Input is inverted | | 0 | Input is not inverted | ## Bit 3 – HOME Status of HOMEx Input Pin After Polarity Control bit (read-only) | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 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) | Value | Description | |-------|----------------------------------------------------------------------------------------------------------| | 1 | Pin is at logic '1' if the IDXPOL bit is set to '0'; pin is at logic '0' if the IDXPOL bit is set to '1' | | 0 | Pin is at logic '0' if the IDXPOL bit is set to '0'; pin is at logic '1' if the IDXPOL bit is set to '1' | ## Bit 1 - QEB Status of QEBx Input Pin After Polarity Control and SWPAB Pin Swapping bit (read-only) | DIL I QLD | Otatus of QEBX input in Arter Folanty Control and OWI AB Fin Gwapping bit (read-only) | | | | | |-----------|----------------------------------------------------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | Physical pin, QEBx, is at logic '1' if QEBPOL bit is set to '0' and SWPAB bit is set to '0'; | | | | | | | physical pin, QEBx, is at logic '0' if QEBPOL bit is set to '1' and SWPAB bit is set to '0'; | | | | | | | physical pin, QEAx, is at logic '1' if QEBPOL bit is set to '0' and SWPAB bit is set to '1'; | | | | | | | physical pin, QEAx, is at logic '0' if QEBPOL bit is set to '1' and SWPAB bit is set to '1' | | | | | | 0 | Physical pin, QEBx, is at logic '0' if QEBPOL bit is set to '0' and SWPAB bit is set to '0'; | | | | | | | physical pin, QEBx, is at logic '1' if QEBPOL bit is set to '1' and SWPAB bit is set to '0'; | | | | | | | physical pin, QEAx, is at logic '0' if QEBPOL bit is set to '0' and SWPAB bit is set to '1'; | | | | | | | physical pin, QEAx, 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) | Value | Description | |-------|-----------------------------------------------------------------------------------------------------| | 1 | Physical pin, QEAx, is at logic '1' if QEAPOL bit is set to '0' and SWPAB bit is set to '0'; | | | physical pin, QEAx, is at logic '0' if QEAPOL bit is set to '1' and SWPAB bit is set to '0'; | | | physical pin, QEBx, is at logic '1' if QEAPOL bit is set to '0' and SWPAB bit is set to '1'; | | | physical pin, QEBx, is at logic '0' if QEAPOL bit is set to '1' and SWPAB bit is set to '1' | | 0 | Physical pin, QEAx, is at logic '0' if QEAPOL bit is set to '0' and SWPAB bit is set to '0'; | | | physical pin, QEAx, is at logic '1' if QEAPOL bit is set to '1' and SWPAB bit is set to '0'; | | | physical pin, QEBx, is at logic '0' if QEAPOL bit is set to '0' and SWPAB bit is set to '1'; | | | physical pin, QEBx, is at logic '1' if the QEAPOL bit is set to '1' and the SWPAB bit is set to '1' | **Quadrature Encoder Interface (QEI)** ## 15.1.3 QEIx I/O Control High Register Name: QEIxIOCH<sup>(1)</sup> **Offset:** 0x146, 0x17A, 0x546 #### Note: 1. This register is not present on all devices. Bit 0 - HCAPEN Position Counter Input Capture by Home Event Enable bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | HOMEx input event (positive edge) triggers a position capture event | | 0 | HOMEx input event (positive edge) does not trigger a position capture event | Quadrature Encoder Interface (QEI) ### 15.1.4 QEIx Status Register Name: QEIxSTAT **Offset:** 0x148, 0x17C, 0x548 #### Note: 1. This status bit is only applicable to PIMOD[2:0] modes, '011' and '100'. Legend: C = Clearable bit, HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|----------|----------|----------|----------|----------|----------| | | | | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | | Access | | | R/C/HS | R/W | R/C/HS | R/W | R/C/HS | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PCIIRQ | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | | Access | R/C/HS | R/W | R/C/HS | R/W | R/C/HS | R/W | R/C/HS | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 13 - PCHEQIRQ Position Counter Greater Than Compare Status bit | Value | Description | |-------|-------------------| | 1 | POSxCNT ≥ QEIxGEC | | 0 | POSxCNT < QEIxGEC | #### Bit 12 - PCHEQIEN Position Counter Greater Than Compare Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 11 - PCLEQIRQ Position Counter Less Than Compare Status bit | Value | Description | |-------|-------------------| | 1 | POSxCNT ≤ QEIxLEC | | 0 | POSxCNT > QEIxLEC | ## Bit 10 - PCLEQIEN Position Counter Less Than Compare Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | ## Bit 9 - POSOVIRQ Position Counter Overflow Status bit | Value | Description | |-------|--------------------------| | 1 | Overflow has occurred | | 0 | No overflow has occurred | ## Bit 8 - POSOVIEN Position Counter Overflow Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | ### Bit 7 - PCIIRQ Position Counter (Homing) Initialization Process Complete Status bit<sup>(1)</sup> | Value | Description | |-------|-------------------------------| | 1 | POSxCNT was reinitialized | | 0 | POSxCNT was not reinitialized | ### Bit 6 - PCIIEN Position Counter (Homing) Initialization Process Complete Interrupt Enable bit **Quadrature Encoder Interface (QEI)** | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | ### Bit 5 - VELOVIRQ Velocity Counter Overflow Status bit | Value | Description | | |-------|--------------------------|--| | 1 | Overflow has occurred | | | 0 | No overflow has occurred | | #### Bit 4 - VELOVIEN Velocity Counter Overflow Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 3 - HOMIRQ Status Flag for Home Event Status bit | Value | Description | |-------|----------------------------| | 1 | Home event has occurred | | 0 | No Home event has occurred | ### Bit 2 - HOMIEN Home Input Event Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | ### Bit 1 - IDXIRQ Status Flag for Index Event Status bit | Value | Description | |-------|-----------------------------| | 1 | Index event has occurred | | 0 | No Index event has occurred | ### Bit 0 - IDXIEN Index Input Event Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | **Quadrature Encoder Interface (QEI)** ## 15.1.5 Position x Counter Register Low Name: POSxCNTL **Offset:** 0x14C, 0x180, 0x54C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|--------------|-----|-----|-----|-----|-----|-----|-----|--| | | POSCNT[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | POSCNT[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - POSCNT[15:0] Low Word Used to Form 32-Bit Position Counter Register (POSxCNT) bits **Quadrature Encoder Interface (QEI)** ## 15.1.6 Position x Counter Register High Name: POSxCNTH **Offset:** 0x14E, 0x182, 0x54E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|---------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | POSCNT[31:24] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | POSCNT[23:16] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - POSCNT[31:16] High Word Used to Form 32-Bit Position Counter Register (POSxCNT) bits **Quadrature Encoder Interface (QEI)** ## 15.1.7 Position 1 Counter Hold Register High Name: POS1HLDH Offset: 0x152 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--| | | POSHLDH[31:24] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | POSHLDH[23:16] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - POSHLDH[31:16] Hold for Reading/Writing Position 1 Counter Register (POS1CNT) bits Quadrature Encoder Interface (QEI) ## 15.1.8 Velocity x Counter Register Low Name: VELxCNTL **Offset:** 0x154, 0x188, 0x554 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----|--------------|-----|-------|---------|-----|-----|-----|--|--|--| | | | VELCNT[15:8] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | VELCI | NT[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:0 - VELCNT[15:0] Velocity Counter bits **Quadrature Encoder Interface (QEI)** ## 15.1.9 Velocity x Counter Register High Name: VELxCNTH<sup>(1)</sup> Offset: 0x156, 0x18A, 0x556 Note: 1. This register is not present on all devices. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|----------|-----|-----|-----| | | | | | VELCN. | T[31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | VELCN. | T[23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - VELCNT[31:16] Velocity Counter bits Quadrature Encoder Interface (QEI) ## 15.1.10 Velocity 1 Counter Hold Register High Name: VEL1HLDH Offset: 0x15A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|--------|----------|-----|-----|-----|--|--| | | VELHLDH[31:24] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | VELHLD | H[23:16] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - VELHLDH[31:16] Velocity Counter Hold Value bits Quadrature Encoder Interface (QEI) ## 15.1.11 Interval x Timer Register Low Name: INTxTMRL **Offset:** 0x15C, 0x190, 0x55C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | INTTM | R[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | INTTM | IR[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - INTTMR[15:0] Low Word Used to Form 32-Bit Interval Timer Register (INTxTMR) bits Quadrature Encoder Interface (QEI) ## 15.1.12 Interval x Timer Register High Name: INTxTMRH **Offset:** 0x15E, 0x192, 0x55E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|----------|-----|-----|-----| | | | | | INTTM | R[31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | INTTMF | R[23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - INTTMR[31:16] High Word Used to Form 32-Bit Interval Timer Register (INTxTMR) bits **Quadrature Encoder Interface (QEI)** ## 15.1.13 Index x Counter Hold Register Low Name: INTxHLDL **Offset:** 0x160, 0x194, 0x560 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|----------|-----|-----|-----| | | | | | INTXHL | .D[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | INTXH | LD[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - INTXHLD[15:0] Hold for Reading/Writing Index x Counter Register (IDXxCNT) bits **Quadrature Encoder Interface (QEI)** #### 15.1.14 Index x Counter Hold Register High Name: INTxHLDH **Offset:** 0x162,0x196, 0x562 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|---------|-----|-----|-----| | | | | | INTHLE | [31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | INTHLE | [23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - INTHLD[31:16] Hold for Reading/Writing Index x Counter Register (IDXxCNT) bits **Quadrature Encoder Interface (QEI)** ## 15.1.15 Index x Counter Register Low Name: INDXxCNTL **Offset:** 0x164, 0x198, 0x564 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|----------|-----|-----|-----| | | | | | INDXC | NT[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | INDXC | NT[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - INDXCNT[15:0] Low Word Used to Form 32-Bit Index x Counter Register (INDXxCNT) bits **Quadrature Encoder Interface (QEI)** #### 15.1.16 Index x Counter Register High Name: INDXxCNTH **Offset:** 0x166, 0x19A, 0x566 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|--------|-----------|-----|-----|-----|--|--| | | INDXCNT[31:24] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | INDXCN | IT[23:16] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - INDXCNT[31:16] High Word Used to Form 32-Bit Index x Counter Register (INDXxCNT) bits **Quadrature Encoder Interface (QEI)** #### 15.1.17 Index 1 Counter Hold Register High Name: INDX1HLDH Offset: 0x16A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----------------|-----|-----|--------|-----------|-----|-----|-----|--|--| | | INDXHLDH[31:24] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | INDXHL | DH[23:16] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | **Bits 15:0 – INDXHLDH[31:16]** Hold Register for Reading/Writing Index 1 Counter High Word Register (INDX1CNTH) bits **Quadrature Encoder Interface (QEI)** #### 15.1.18 QEIx Greater Than or Equal Compare Register Low Name: QEIxGECL **Offset:** 0x16C, 0x1A0, 0x56C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | QEIGE | C[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | QEIGE | C[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - QEIGEC[15:0] Low Word Used to Form 32-Bit Greater Than or Equal Compare Register (QEIxGEC) bits **Quadrature Encoder Interface (QEI)** #### 15.1.19 QEIx Greater Than or Equal Compare Register High Name: QEIxGECH **Offset:** 0x16E, 0x1A2, 0x56E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|---------------|---------------|-----|-----|-----|-----|-----|-----|--|--| | | QEIGEC[31:24] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | QEIGEC[23:16] | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 – QEIGEC[31:16] High Word Used to Form 32-Bit Greater Than or Equal Compare Register (QEIxGEC) bits **Quadrature Encoder Interface (QEI)** #### 15.1.20 QEIx Less Than or Equal Compare Register Low Name: QEIxLECL **Offset:** 0x170, 0x1A4, 0x570 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | QEILE | C[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | QEILE | C[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - QEILEC[15:0] Low Word Used to Form 32-Bit Less Than or Equal Compare Register (QEIxLEC) bits **Quadrature Encoder Interface (QEI)** #### 15.1.21 QEIx Less Than or Equal Compare Register High Name: QEIxLECH **Offset:** 0x172, 0x1A6, 0x572 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|---------|-----|-----|-----| | | | | | QEILEC | [31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | QEILEC | [23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - QEILEC[31:16] High Word Used to Form 32-Bit Less Than or Equal Compare Register (QEIxLEC) bits ## Universal Asynchronous Receiver Transmitter ... ## 16. Universal Asynchronous Receiver Transmitter (UART) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**Multiprotocol Universal Asynchronous Receiver Transmitter (UART) Module**" (www.microchip.com/DS70005288) in the "dsPIC33/PIC24 Family Reference Manual". The Universal Asynchronous Receiver Transmitter (UART) is a flexible serial communication peripheral used to interface dsPIC microcontrollers with other equipment, including computers and peripherals. The UART is a full-duplex, asynchronous communication channel that can be used to implement protocols, such as RS-232 and RS-485. The UART also supports the following hardware extensions: - LIN/J2602 - · Direct Matrix Architecture (DMX) - Smart Card The primary features of the UART are: - · Full or Half-Duplex Operation - · Up to 8-Deep TX and RX First-In First-Out (FIFO) Buffers - · 8-Bit or 9-Bit Data Width - · Configurable Stop Bit Length - Flow Control - · Auto-Baud Calibration - · Parity, Framing and Buffer Overrun Error Detection - · Address Detect - · Break Transmission - · Transmit and Receive Polarity Control - Manchester Encoder/Decoder - · Operation in Sleep mode - · Wake from Sleep on Sync Break Received Interrupt #### 16.1 Architectural Overview The UART transfers bytes of data, to and from device pins, using First-In First-Out (FIFO) buffers up to eight bytes deep. The status of the buffers and data is made available to user software through Special Function Registers (SFRs). The UART implements multiple interrupt channels for handling transmit, receive and error events. A simplified block diagram of the UART is shown in Figure 16-1. Figure 16-1. Simplified UARTx Block Diagram #### 16.2 Character Frame A typical UART character frame is shown in Figure 16-2. The Idle state is high with a 'Start' condition indicated by a falling edge. The Start bit is followed by the number of data, parity/address detect and Stop bits defined by the MOD[3:0] (UxMODE[3:0]) bits selected. Figure 16-2. UART Character Frame #### 16.3 Data Buffers Both transmit and receive functions use buffers to store data shifted to/from the pins. These buffers are FIFOs and are accessed by reading the SFRs, UxTXREG and UxRXREG, respectively. Each data buffer has multiple flags associated with its operation to allow software to read the status. Interrupts can also be configured based on the space available in the buffers. The transmit and receive buffers can be cleared and their pointers reset using the associated TX/RX Buffer Empty Status bits, UTXBE (UxSTAH[5]) and URXBE (UxSTAH[1]). #### 16.4 Protocol Extensions The UART provides hardware support for LIN/J2602, DMX and smart card protocol extensions to reduce software overhead. A protocol extension is enabled by writing a value to the MOD[3:0] (UxMODE[3:0]) selection bits and further configured using the UARTx Timing Parameter registers, UxP1, UxP2, UxP3 and UxP3H. Details regarding operation and usage are discussed in their respective chapters. Not all protocols are available on all devices. ## 16.5 UART Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------------------------------------|----------|-----------|--------|--------------|----------------|---------|--------|--------------|-----------| | 0x0238 | HIMODE | 15:8 | UARTEN | | USIDL | WAKE | RXBIMD | | BRKOVR | UTXBRK | | UXU238 | U1MODE | 7:0 | BRGH | ABAUD | UTXEN | URXEN | | MOI | D[3:0] | | | 0x023A | U1MODEH | 15:8 | SLPEN | ACTIVE | | | BCLKMOD | BCLKS | SEL[1:0] | HALFDPLX | | UXUZSA | OTMODER | 7:0 | RUNOVF | URXINV | STSE | | C0EN | UTXINV | FLO | | | 0x023C | U1STA | 15:8 | TXMTIE | PERIE | ABDOVE | CERIE | FERIE | RXBKIE | OERIE | TXCIE | | 0,0200 | 01017 | 7:0 | TRMT | PERR | ABDOVF | CERIF | FERR | RXBKIF | OERR | TXCIF | | 0x023E | U1STAH | 15:8 | | | UTXISEL[2:0] | | | | URXISEL[2:0] | | | UNULUL | 0101111 | 7:0 | TXWRE | STPMD | UTXBE | UTXBF | RIDLE | XON | URXBE | URXBF | | 0x0240 | U1BRG | 15:8 | | | | | [15:8] | | | | | | | 7:0 | | | | BRO | G[7:0] | | | | | 0x0242 | U1BRGH | 15:8 | | | | | | | | | | | | 7:0 | | | | | | BRG | [19:16] | | | 0x0244 | U1RXREG | 15:8 | | | | 5,755 | | | | | | 0.0040 | | 7:0 | | | | RXRE | G[7:0] | | | I | | 0x0246 | D | | | | | | | | | | | <br>0v0247 | Reserved | | | | | | | | | | | 0x0247 | | 15:8 | LAST | | | | | | | | | 0x0248 | <b>U1TXREG</b> | 7:0 | LAGI | | | TXRE | [G[7:0] | | | | | 0x024A | | 1.0 | | | | TXIXE | .0[7.0] | | | | | | Reserved | | | | | | | | | | | 0x024B | | | | | | | | | | | | | | 15:8 | | | | | | | | P1[8] | | 0x024C | U1P1 | 7:0 | | , | | P1 | [7:0] | | | | | 0.0045 | LUDO | 15:8 | | | | | | | | P2[8] | | 0x024E | U1P2 | 7:0 | | , | | P2 | [7:0] | | | | | 0x0250 | U1P3 | 15:8 | | | | P3[ | 15:8] | | | | | UXU250 | UIPS | 7:0 | | | | P3 | [7:0] | | | | | 0x0252 | U1P3H | 15:8 | | | | | | | | | | 0,0202 | 011 011 | 7:0 | | | | P3[2 | 23:16] | | | | | 0x0254 | U1TXCHK | 15:8 | | | | | | | | | | UNUZU I | OTIXOTIK | 7:0 | | | | TXCF | IK[7:0] | | | | | 0x0256 | U1RXCHK | 15:8 | | | | | | | | | | 20000000000000 | or or a separation | 7:0 | | 1 | | RXC | łK[7:0] | | 1 | | | 0x0258 | U1SCCON | 15:8 | | | | | | | | | | | | 7:0 | | | TXRP | | CONV | T0PD | PRTCL | | | 0x025A | <b>U1SCINT</b> | 15:8 | | | RXRPTIF | TXRPTIF | | BTCIF | WTCIF | GTCIF | | | | 7:0 | | | RXRPTIE | TXRPTIE | | BTCIE | WTCIE | GTCIE | | 0x025C | U1INT | 15:8 | \A/I II E | ADDIE | | | | ADDIE | | | | 0x025E | | 7:0 | WUIF | ABDIF | | | | ABDIE | | | | | Reserved | | | | | | | | | | | 0x025F | i (Coci veu | | | | | | | | | | | | | 15:8 | UARTEN | | USIDL | WAKE | RXBIMD | | BRKOVR | UTXBRK | | 0x0260 | U2MODE | 7:0 | BRGH | ABAUD | UTXEN | URXEN | | MOI | D[3:0] | 2.7.DIXIX | | | EST TO AND A TOPIC STORAGE TO THE ST | 15:8 | SLPEN | ACTIVE | | 35343931946231 | BCLKMOD | | SEL[1:0] | HALFDPLX | | 0x0262 | U2MODEH | 7:0 | RUNOVF | URXINV | STSE | L[1:0] | C0EN | UTXINV | | [1:0] | | | Title- | 15:8 | TXMTIE | PERIE | ABDOVE | CERIE | FERIE | RXBKIE | OERIE | TXCIE | | 0x0264 | U2STA | 7:0 | TRMT | PERR | ABDOVF | CERIF | FERR | RXBKIF | OERR | TXCIF | | 00000 | LIGOTALI | 15:8 | | | UTXISEL[2:0] | | | | URXISEL[2:0] | | | 0x0266 | U2STAH | 7:0 | TXWRE | STPMD | UTXBE | UTXBF | RIDLE | XON | URXBE | URXBF | | 0,0000 | LIADDO | 15:8 | | | | BRG | [15:8] | | | | | 0x0268 | U2BRG | 7:0 | | | | | G[7:0] | | | | | 0,0006.4 | Habbott | 15:8 | | | | | | | | | | 0x026A | U2BRGH | 7:0 | | | | | | BRG | [19:16] | | ## **Universal Asynchronous Receiver Transmitter ...** | conti | nued | | | | | | | | | | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|--------|--------------------|-------------|----------------|--------|--------------------|----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 15:8 | | _ | | | | | | - | | 0x026C | U2RXREG | 7:0 | | | | RXRF | [<br>[G[7:0] | | | | | 0x026E | | | | | | | [] | | | | | | Reserved | | | | | | | | | | | 0x026F | | | | | | | | | | | | 0x0270 | <b>U2TXREG</b> | 15:8 | LAST | | | | | | | | | 0x0272 | | 7:0 | | | | TXRE | G[7:0] | | | | | | Reserved | | | | | | | | | | | 0x0273 | | | | | | | | | | | | 0x0274 | U2P1 | 15:8 | | | | | | | | P1[8] | | 0.0274 | 021 1 | 7:0 | | | 1 | P1 | [7:0] | | , | | | 0x0276 | U2P2 | 15:8 | | | | | | | | P2[8] | | | | 7:0 | | | | | [7:0] | | | | | 0x0278 | U2P3 | 15:8<br>7:0 | | | | | 15:8]<br>[7:0] | | | | | | \$10000000000 | 15:8 | | | | 1 5 | | | | | | 0x027A | U2P3H | 7:0 | | | 1 | P3[2 | 23:16] | | 1 | | | 0x027C | U2TXCHK | 15:8 | | | | | | | | | | 0.0270 | OZTACHK | 7:0 | | | | TXCF | HK[7:0] | | | | | 0x027E | U2RXCHK | 15:8 | | | | | | | | | | | 5 No. 5 Table 10 About 10 About 1 | 7:0<br>15:8 | | | | RXC | HK[7:0] | | | | | 0x0280 | U2SCCON | 7:0 | | | TYPE | <br>PT[1:0] | CONV | T0PD | PRTCL | | | | 10 Table | 15:8 | | | RXRPTIF | TXRPTIF | CONV | BTCIF | WTCIF | GTCIF | | 0x0282 | U2SCINT | 7:0 | | | RXRPTIE | TXRPTIE | | BTCIE | WTCIE | GTCIE | | 0x0284 | U2INT | 15:8 | | | | | | | | | | 0X0204 | UZINT | 7:0 | WUIF | ABDIF | | | | ABDIE | | | | 0x0286 | _1 | | | | | | | | | | | 0x0EFF | Reserved | | | | | | | | | | | | | 15:8 | UARTEN | | USIDL | WAKE | RXBIMD | | BRKOVR | UTXBRK | | 0x0F00 | U3MODE | 7:0 | BRGH | ABAUD | UTXEN | URXEN | | IOM | D[3:0] | | | 0x0F02 | U3MODEH | 15:8 | SLPEN | ACTIVE | | | BCLKMOD | | SEL[1:0] | HALFDPLX | | UXUFUZ | OSMODEN | 7:0 | RUNOVF | URXINV | | L[1:0] | C0EN | UTXINV | | [1:0] | | 0x0F04 | U3STA | 15:8 | TXMTIE | PERIE | ABDOVE | CERIE | FERIE | RXBKIE | OERIE | TXCIE | | | | 7:0<br>15:8 | TRMT | PERR | ABDOVF | CERIF | FERR | RXBKIF | OERR | TXCIF | | 0x0F06 | U3STAH | 7:0 | TXWRE | STPMD | UTXISEL[2:0] UTXBE | UTXBF | RIDLE | XON | URXISEL[2:0] URXBE | URXBF | | | | 15:8 | | 5 MD | J.ADL | | [15:8] | 2,011 | C. JUDE | 3.00 | | 0x0F08 | U3BRG | 7:0 | | | | | G[7:0] | | | | | 0x0F0A | U3BRGH | 15:8 | | | | | | | | | | OXOI OA | JOBRON | 7:0 | | | | | | BRG | [19:16] | | | 0x0F0C | U3RXREG | 15:8 | | | | DVDE | 017.01 | | | | | 0x0F0E | | 7:0 | | | | RXRE | EG[7:0] | | | | | | Reserved | | | | | | | | | | | 0x0F0F | | | | | | | | | | | | 0x0F10 | U3TXREG | 15:8 | LAST | | | | | | | | | | COLVINEO | 7:0 | | | | TXRE | G[7:0] | | | | | 0x0F12 | | | | | | | | | | | | <br>0x0F13 | Reserved | | | | | | | | | | | | 1,25 | 15:8 | | | | | | | | P1[8] | | 0x0F14 | U3P1 | 7:0 | | | | P1 | [7:0] | | | | | 0x0F16 | U3P2 | 15:8 | | | | | | | | P2[8] | | UNUFIU | 03F2 | 7:0 | | | | | [7:0] | | | | | 0x0F18 | U3P3 | 15:8 | | | | | 15:8] | | | | | | | 7:0 | | | | P3 | [7:0] | | | | ## **Universal Asynchronous Receiver Transmitter ...** | contii | nued | | | | | | | | | | | | |---------|-----------|----------|------------|-------|---------|---------|--------|-------|-------|-------|--|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 0x0F1A | U3P3H | 15:8 | | | | | | | | | | | | UXUFIA | USPSH | 7:0 | | | | P3[2 | :3:16] | | | | | | | 0x0F1C | U3TXCHK | 15:8 | | | | | | | | | | | | UXUFIC | USTACHK | 7:0 | TXCHK[7:0] | | | | | | | | | | | 0x0F1E | U3RXCHK | 15:8 | | | | | | | | | | | | UXUFIE | USRACHK | 7:0 | RXCHK[7:0] | | | | | | | | | | | 0x0F20 | U3SCCON | 15:8 | | | | | | | | | | | | UXUFZU | USSCCON | 7:0 | | | TXRF | PT[1:0] | CONV | T0PD | PRTCL | | | | | 0,40500 | LIZOCINIT | 15:8 | | | RXRPTIF | TXRPTIF | | BTCIF | WTCIF | GTCIF | | | | 0x0F22 | U3SCINT | 7:0 | | | RXRPTIE | TXRPTIE | | BTCIE | WTCIE | GTCIE | | | | 0,0004 | LIGINIT | 15:8 | | | | | | | | | | | | 0x0F24 | U3INT | 7:0 | WUIF | ABDIF | | | | ABDIE | | | | | ## Universal Asynchronous Receiver Transmitter ... #### 16.5.1 **UARTx Configuration Register** Name: **UxMODE** Offset: 0x238, 0x260, 0xF00 Note: 1. R/HS/HC in DMX and LIN mode. Legend: HC = Hardware Clearable bit; HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|-------|-------|--------|-----|--------|--------| | | UARTEN | | USIDL | WAKE | RXBIMD | | BRKOVR | UTXBRK | | Access | R/W | | R/W | R/W | R/W | | R/W | R/W/HC | | Reset | 0 | | 0 | 0 | 0 | | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BRGH | ABAUD | UTXEN | URXEN | | MOD | [3:0] | | | Access | R/W | R/W/HC | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - UARTEN UART Enable bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 1 | UART is ready to transmit and receive | | 0 | UART state machine, FIFO Buffer Pointers and counters are reset; registers are readable and writable | #### Bit 13 - USIDL UART Stop in Idle Mode bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation in Idle mode | #### Bit 12 - WAKE Wake-up Enable bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Module will continue to sample the RX pin – interrupt generated on falling edge, bit cleared in hardware on following rising edge; if ABAUD is set, Auto-Baud Detection (ABD) will begin immediately | | 0 | RX pin is not monitored nor rising edge detected | #### Bit 11 - RXBIMD Receive Break Interrupt Mode bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | RXBKIF flag when a minimum of 23 (DMX)/11 (asynchronous or LIN/J2602) low bit periods are | | | detected | | 0 | RXBKIF flag when the Break makes a low-to-high transition after being low for at least 23/11-bit | | | periods | #### Bit 9 - BRKOVR Send Break Software Override bit #### Overrides the TX Data Line: | Value | Description | |-------|-------------------------------------------------------------------------------| | 1 | Makes the TX line active (Output 0 when UTXINV = 0, Output 1 when UTXINV = 1) | | 0 | TX line is driven by the shifter | #### Bit 8 - UTXBRK UART Transmit Break bit(1) | Value | Description | |-------|----------------------------------------------------------------------------| | 1 | Sends Sync Break on next transmission; cleared by hardware upon completion | | 0 | Sync Break transmission is disabled or has completed | #### Bit 7 - BRGH High Baud Rate Select bit | Value | Description | |-------|------------------------------------| | 1 | High Speed: Baud rate is baudclk/4 | Datasheet ## Universal Asynchronous Receiver Transmitter ... | Value | Description | |-------|------------------------------------| | 0 | Low Speed: Baud rate is baudclk/16 | #### Bit 6 – ABAUD Auto-Baud Detect Enable bit (read-only when MOD[3:0] = 1xxx) | Value | Description | |-------|-------------------------------------------------------------------------------------------------| | 1 | Enables baud rate measurement on the next character – requires reception of a Sync field (55h); | | | cleared in hardware upon completion | | 0 | Baud rate measurement is disabled or has completed | #### Bit 5 - UTXEN UART Transmit Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | Transmit enabled – except during Auto-Baud Detection | | 0 | Transmit disabled – all transmit counters, pointers and state machines are reset; TX buffer is not | | | flushed, status bits are not reset | #### Bit 4 - URXEN UART Receive Enable bit | Value | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------| | 1 | Receive enabled – except during Auto-Baud Detection | | 0 | Receive disabled – all receive counters, pointers and state machines are reset; RX buffer is not flushed, status bits are not reset | #### Bits 3:0 - MOD[3:0] UART Mode bits | Value | Description | |-------|-----------------------------------------------------------------------------------------| | Other | Reserved | | 1111 | Smart card | | 1110 | IrDA <sup>®</sup> | | 1101 | Reserved | | 1100 | LIN Commander/Responder | | 1011 | LIN Responder only | | 1010 | DMX | | 1001 | Reserved | | 1000 | Reserved | | 0111 | Reserved | | 0110 | Reserved | | 0101 | Reserved | | 0100 | Asynchronous 9-bit UART with address detect, ninth bit = 1 signals address | | 0011 | Asynchronous 8-bit UART without address detect, ninth bit is used as an even parity bit | | 0010 | Asynchronous 8-bit UART without address detect, ninth bit is used as an odd parity bit | | 0001 | Asynchronous 7-bit UART | | 0000 | Asynchronous 8-bit UART | ## Universal Asynchronous Receiver Transmitter ... #### 16.5.2 UARTx Configuration Register High Name: UxMODEH **Offset:** 0x23A, 0x262, 0xF02 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|------------|-----|---------|--------|---------|----------| | | SLPEN | ACTIVE | | | BCLKMOD | BCLKS | EL[1:0] | HALFDPLX | | Access | R/W | R | | | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RUNOVF | URXINV | STSEL[1:0] | | C0EN | UTXINV | FLC | D[1:0] | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - SLPEN Run During Sleep Enable bit | Value | Description | |-------|-------------------------------------------| | 1 | UART BRG clock runs during Sleep | | 0 | UART BRG clock is turned off during Sleep | #### Bit 14 - ACTIVE UART Running Status bit | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | UART clock request is active (user can not update the UxMODE/UxMODEH registers) | | 0 | UART clock request is not active (user can update the UxMODE/UxMODEH registers) | #### Bit 11 - BCLKMOD Baud Clock Generation Mode Select bit | Value | Description | |-------|---------------------------------------------------------------------------------------------------| | 1 | Uses fractional Baud Rate Generation | | 0 | Uses legacy divide-by-x counter for baud clock generation (x = 4 or 16 depending on the BRGH bit) | #### Bits 10:9 - BCLKSEL[1:0] Baud Clock Source Selection bits | Value | Description | |-------|---------------------------------------| | 11 | AF <sub>VCO</sub> /3 | | 10 | Fosc | | 01 | Reserved | | 00 | F <sub>OSC</sub> /2 (F <sub>P</sub> ) | #### Bit 8 - HALFDPLX UART Half-Duplex Selection Mode bit | Value | Description | |-------|------------------------------------------------------------------------------------------------| | 1 | Half-Duplex mode: UxTX is driven as an output when transmitting and tri-stated when TX is Idle | | 0 | Full-Duplex mode: UxTX is driven as an output at all times when both UARTEN and UTXEN are set | #### Bit 7 - RUNOVF Run During Overflow Condition Mode bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 1 | When an Overflow Error (OERR) condition is detected, the RX shifter continues to run so as to remain | | | synchronized with incoming RX data; data are not transferred to UxRXREG when it is full (i.e., no | | | UxRXREG data are overwritten) | | 0 | When an Overflow Error (OERR) condition is detected, the RX shifter stops accepting new data | | | (Legacy mode) | #### Bit 6 - URXINV UART Receive Polarity bit | Value | Description | |-------|-------------------------------------------| | 1 | Inverts RX polarity; Idle state is low | | 0 | Input is not inverted; Idle state is high | ## **Universal Asynchronous Receiver Transmitter ...** # Bits 5:4 – STSEL[1:0] Number of Stop Bits Selection bits Value Description 11 2 Stop bits sent, 1 checked at receive 10 2 Stop bits sent, 2 checked at receive 01 1.5 Stop bits sent, 1.5 checked at receive 00 1 Stop bit sent, 1 checked at receive #### Bit 3 - C0EN Enable Legacy Checksum (C0) Transmit and Receive bit | Value | Description | |-------|---------------------------------------------------------------------------------------------| | 1 | Checksum Mode 1 (enhanced LIN checksum in LIN mode; add all TX/RX words in all other modes) | | 0 | Checksum Mode 0 (legacy LIN checksum in LIN mode; not used in all other modes) | #### Bit 2 - UTXINV UART Transmit Polarity bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Inverts TX polarity; TX is low in Idle state | | 0 | Output data are not inverted; TX output is high in Idle state | #### Bits 1:0 – FLO[1:0] Flow Control Enable bits (only valid when MOD[3:0] = $0 \times \times \times$ ) | Value | Description | |-------|-------------------------------------------------------------------| | 11 | Reserved | | 10 | RTS-DSR (for TX side)/CTS-DTR (for RX side) hardware flow control | | 01 | XON/XOFF software flow control | | 00 | Flow control off | ## Universal Asynchronous Receiver Transmitter ... #### 16.5.3 UARTx Status Register Name: UxSTA **Offset:** 0x23C, 0x264, 0xF04 Legend: HC = Hardware Clearable bit; HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|-------|--------|--------|-------|--------|--------|--------| | | TXMTIE | PERIE | ABDOVE | CERIE | FERIE | RXBKIE | OERIE | TXCIE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TRMT | PERR | ABDOVF | CERIF | FERR | RXBKIF | OERR | TXCIF | | Access | R | R | R/W/HS | R/W/HC | R | R/W/HC | R/W/HC | R/W/HC | | Reset | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - TXMTIE Transmit Shifter Empty Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 14 - PERIE Parity Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 13 - ABDOVE Auto-Baud Rate Acquisition Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 12 - CERIE Checksum Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 11 - FERIE Framing Error Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 10 - RXBKIE Receive Break Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 9 - OERIE Receive Buffer Overflow Interrupt Enable bit | Value | Description | |-------|-----------------------| | 1 | Interrupt is enabled | | 0 | Interrupt is disabled | #### Bit 8 - TXCIE Transmit Collision Interrupt Enable bit | D 0 | THE THATOMIC COMOINT METALE DIE | | | | | |-------|---------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | Interrupt is enabled | | | | | | 0 | Interrupt is disabled | | | | | ## Universal Asynchronous Receiver Transmitter ... | Bit 7 – T | Bit 7 - TRMT Transmit Shifter Empty Interrupt Flag bit (read-only) | | | | | | |-----------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Value | Value Description | | | | | | | 1 | Transmit Shift Register (TSR) is empty (end of last Stop bit when STPMD = 1 or middle of first Stop bit | | | | | | | | when STPMD = 0) | | | | | | | 0 | Transmit Shift Register is not empty | | | | | | #### Bit 6 - PERR Parity Error/Address Received/Forward Frame Interrupt Flag bit #### LIN and Parity Modes: - 1 = Parity error detected - 0 = No parity error detected #### Address Mode: - 1 = Address received - 0 = No address detected #### All Other Modes: Not used. #### Bit 5 - ABDOVF Auto-Baud Rate Acquisition Interrupt Flag bit (must be cleared by software) | Va | lue | Description | |----|-----|----------------------------------------------------------------------------------------------| | 1 | | BRG rolled over during the auto-baud rate acquisition sequence (must be cleared in software) | | 0 | | BRG has not rolled over during the auto-baud rate acquisition sequence | #### Bit 4 – CERIF Checksum Error Interrupt Flag bit (must be cleared by software) | Value | Description | |-------|-------------------| | 1 | Checksum error | | 0 | No checksum error | #### Bit 3 - FERR Framing Error Interrupt Flag bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------------| | 1 | Framing Error: Inverted level of the Stop bit corresponding to the topmost character in the buffer; | | | propagates through the buffer with the received character | | 0 | No framing error | #### Bit 2 - RXBKIF Receive Break Interrupt Flag bit (must be cleared by software) | Value | Description | |-------|-----------------------| | 1 | A Break was received | | 0 | No Break was detected | ## Bit 1 – OERR Receive Buffer Overflow Interrupt Flag bit (must be cleared by software) | Value | Description | |-------|-----------------------------------| | 1 | Receive buffer has overflowed | | 0 | Receive buffer has not overflowed | #### Bit 0 - TXCIF Transmit Collision Interrupt Flag bit (must be cleared by software) | Value | Description | |-------|----------------------------------------------------| | 1 | Transmitted word is not equal to the received word | | 0 | Transmitted word is equal to the received word | #### Universal Asynchronous Receiver Transmitter ... #### 16.5.4 UARTx Status Register High Name: UxSTAH **Offset:** 0x23E, 0x266, 0xF06 #### Note: 1. The receive watermark interrupt is not set if PERIF or FERIF is set and the corresponding IE bit is set. Legend: S = Settable bit, HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|-------|--------------|-------|-------|-----|--------------|-------| | | | | UTXISEL[2:0] | | | | URXISEL[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 0 | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXWRE | STPMD | UTXBE | UTXBF | RIDLE | XON | URXBE | URXBF | | Access | R/W/HS | R/W | R/S | R | R | R | R/S | R | | Reset | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | #### Bits 14:12 - UTXISEL[2:0] UART Transmit Interrupt Select bits | Value | Description | | | | | | | |-------|--------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 111 | ets transmit interrupt when there is one empty slot left in the buffer | | | | | | | | | | | | | | | | | 010 | Sets transmit interrupt when there are six empty slots or more in the buffer | | | | | | | | 001 | Sets transmit interrupt when there are seven empty slots or more in the buffer | | | | | | | | 000 | Sets transmit interrupt when there are eight empty slots in the buffer; TX buffer is empty | | | | | | | #### Bits 10:8 - URXISEL[2:0] UART Receive Interrupt Select bits(1) | Value | Description | |-------|----------------------------------------------------------------------------------------| | 111 | Triggers receive interrupt when there are eight words in the buffer; RX buffer is full | | | | | 001 | Triggers receive interrupt when there are two words or more in the buffer | | 000 | Triggers receive interrupt when there is one word or more in the buffer | #### Bit 7 - TXWRE TX Write Transmit Error Status bit #### LIN and Parity Modes: - 1 = A new byte was written when buffer was full or when P2[8:0] = 0 (must be cleared by software) - 0 = No error #### Address Detect Mode: - 1 = A new byte was written when buffer was full or to P1[8:0] when P1x was full (must be cleared by software) - 0 = No error #### Other Modes: - 1 = A new byte was written when buffer was full (must be cleared by software) - 0 = No error #### Bit 6 - STPMD Stop Bit Detection Mode bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | Triggers RXIF at the end of the last Stop bit | | 0 | Triggers RXIF in the middle of the first (or second, depending on the STSEL[1:0] setting) Stop bit | #### Bit 5 - UTXBE UART TX Buffer Empty Status bit | | ABE OF THE Build Empty Status Sit | |-------|---------------------------------------------------------------------------------------------------| | Value | Description | | 1 | Transmit buffer is empty; writing '1' when UTXEN = 0 will reset the TX FIFO Pointers and counters | | 0 | Transmit buffer is not empty | #### Bit 4 - UTXBF UART TX Buffer Full Status bit ## Universal Asynchronous Receiver Transmitter ... | Value | Description | |-------|-----------------------------| | 1 | Transmit buffer is full | | 0 | Transmit buffer is not full | #### Bit 3 - RIDLE Receive Idle bit | Value | Description | |-------|-------------------------------------| | 1 | UART RX line is in the Idle state | | 0 | UART RX line is receiving something | #### Bit 2 - XON UART in XON Mode bit Only valid when FLO[1:0] control bits are set to XON/XOFF mode. | Value | Description | |-------|------------------------------------------------| | 1 | UART has received XON | | 0 | UART has not received XON or XOFF was received | #### Bit 1 - URXBE UART RX Buffer Empty Status bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | Receive buffer is empty; writing '1' when URXEN = 0 will reset the RX FIFO Pointers and counters | | 0 | Receive buffer is not empty | #### Bit 0 - URXBF UART RX Buffer Full Status bit | Value | Description | |-------|----------------------------| | 1 | Receive buffer is full | | 0 | Receive buffer is not full | **Datasheet** 70005452B-page 675 © 2021 Microchip Technology Inc. ## Universal Asynchronous Receiver Transmitter ... ## 16.5.5 UARTx Baud Rate Register Low Name: UxBRG **Offset:** 0x240, 0x268, 0xF08 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----------|-----|-----|-----|-----|-----|-----|-----|--|--| | | BRG[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | BRG[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - BRG[15:0] Baud Rate Divisor bits ## Universal Asynchronous Receiver Transmitter ... #### 16.5.6 UARTx Baud Rate Register High Name: UxBRGH **Offset:** 0x242, 0x26A, 0xF0A Bits 3:0 - BRG[19:16] Baud Rate Divisor bits ## Universal Asynchronous Receiver Transmitter ... #### 16.5.7 UARTx Receive Buffer Register Name: UxRXREG **Offset:** 0x244, 0x26C, 0xF0C **Legend:** x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|----|----|----|----|----|---|---| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RXREG[7:0] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | X | X | X | X | X | X | X | X | Bits 7:0 - RXREG[7:0] Received Character Data bits 7-0 ## Universal Asynchronous Receiver Transmitter ... #### 16.5.8 UARTx Transmit Buffer Register Name: UxTXREG **Offset:** 0x248, 0x270, 0xF10 **Legend:** x = Bit is unknown | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|----|----|------|--------|----|---|---| | | LAST | | | | | | | | | Access | W | | | | | | | | | Reset | X | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TXRE | G[7:0] | | | | | Access | W | W | W | W | W | W | W | W | | Reset | X | X | X | X | X | X | X | X | Bit 15 - LAST Last Byte Indicator for Smart Card Support bit **Bits 7:0 – TXREG[7:0]** Transmitted Character Data bits 7-0 If the buffer is full, further writes to the buffer are ignored. ## Universal Asynchronous Receiver Transmitter ... #### 16.5.9 UARTx Timing Parameter 1 Register Name: UxP Offset: 0x24C, 0x274, 0xF14 Bits 8:0 - P1[8:0] Parameter 1 bits DMX TX: Number of Bytes to Transmit – 1 (not including Start code). LIN TX: PID to transmit (bits[5:0]). Asynchronous TX with Address Detect: Address to transmit. A '1' is automatically inserted into bit 9 (bits[7:0]). Smart Card Mode: Guard Time Counter bits. This counter is operated on the bit clock whose period is always equal to one ETU (bits[8:0]). Other Modes: ## Universal Asynchronous Receiver Transmitter ... #### 16.5.10 UARTx Timing Parameter 2 Register Name: UxP2 Offset: 0x24E, 0x276, 0xF16 #### Bits 8:0 - P2[8:0] Parameter 2 bits **DMX RX**: The first byte number to receive - 1, not including Start code (bits[8:0]). LIN Responder TX: Number of bytes to transmit (bits[7:0]). Asynchronous RX with Address Detect: Address to start matching (bits[7:0]). Smart Card Mode: Block Time Counter bits. This counter is operated on the bit clock whose period is always equal to one ETU (bits[8:0]). Other Modes: ## Universal Asynchronous Receiver Transmitter ... #### 16.5.11 UARTx Timing Parameter 3 Register Low Name: UxP3 **Offset:** 0x250, 0x278, 0xF18 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------|-----|-----|-----|-----|-----|-----|-----|--|--| | | P3[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | P3[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - P3[15:0] Parameter 3 bits DMX RX: The last byte number to receive - 1, not including Start code (bits[8:0]). LIN Responder RX: Number of bytes to receive (bits[7:0]). Asynchronous RX: Used to mask the UxP2 address bits; 1 = P2 address bit is used, 0 = P2 address bit is masked off (bits[7:0]). Smart Card Mode: Waiting Time Counter bits (bits[15:0]). Other Modes: ## Universal Asynchronous Receiver Transmitter ... #### 16.5.12 UARTx Timing Parameter 3 Register High Name: UxP3H Offset: 0x252, 0x27A, 0xF1A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|-----|-----|-----|------|-------|-----|-----|-----| | <b>^</b> | | | | | | | | | | Access<br>Reset | | | | | | | | | | 110001 | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | P3[2 | 3:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - P3[23:16] Parameter 3 High bits Smart Card Mode: Waiting Time Counter bits (bits[23:16]). Other Modes: ## Universal Asynchronous Receiver Transmitter ... #### 16.5.13 UARTx Transmit Checksum Register Name: UxTXCHK Offset: 0x254, 0x27C, 0xF1C Bits 7:0 - TXCHK[7:0] Transmit Checksum bits (calculated from TX words) LIN Modes: C0EN = 1: Sum of all transmitted data + addition carries, including PID. C0EN = 0: Sum of all transmitted data + addition carries, excluding PID. LIN Responder: Cleared when Break is detected. LIN Commander/Responder: Cleared when Break is detected. Other Modes: C0EN = 1: Sum of every byte transmitted + addition carries. C0EN = 0: Value remains unchanged. ### Universal Asynchronous Receiver Transmitter ... ### 16.5.14 UARTx Receive Checksum Register Name: UxRXCHK **Offset:** 0x256, 0x27E, 0xF1E Bits 7:0 - RXCHK[7:0] Receive Checksum bits (calculated from RX words) LIN Modes: C0EN = 1: Sum of all received data + addition carries, including PID. C0EN = 0: Sum of all received data + addition carries, excluding PID. LIN Client: Cleared when Break is detected. LIN Host/Client: Cleared when Break is detected. Other Modes: C0EN = 1: Sum of every byte received + addition carries. C0EN = 0: Value remains unchanged. ### Universal Asynchronous Receiver Transmitter ... ### 16.5.15 UARTx Smart Card Configuration Register Name: UxSCCON **Offset:** 0x258, 0x280, 0xF20 Bits 5:4 - TXRPT[1:0] Transmit Repeat Selection bits | Value | Description | |-------|----------------------------------------| | 11 | Retransmits the error byte four times | | 10 | Retransmits the error byte three times | | 01 | Retransmits the error byte twice | | 00 | Retransmits the error byte once | ### Bit 3 - CONV Logic Convention Selection bit | Value | Description | | | |-------|--------------------------|--|--| | 1 | Inverse logic convention | | | | 0 | Direct logic convention | | | ### Bit 2 – T0PD Pull-Down Duration for T = 0 Error Handling bit | Value | Description | |-------|-------------| | 1 | 2 ETU | | 0 | 1 ETU | ### Bit 1 - PRTCL Smart Card Protocol Selection bit | Value | Description | |-------|-------------| | 1 | T = 1 | | 0 | T = 0 | ## Universal Asynchronous Receiver Transmitter ... ### 16.5.16 UARTx Smart Card Interrupt Register Name: UxSCINT **Offset:** 0x25A, 0x282, 0xF22 Legend: HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|---------|---------|----|--------|--------|--------| | | | | RXRPTIF | TXRPTIF | | BTCIF | WTCIF | GTCIF | | Access | | | R/W/HS | R/W/HS | | R/W/HS | R/W/HS | R/W/HS | | Reset | | | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RXRPTIE | TXRPTIE | | BTCIE | WTCIE | GTCIE | | Access | | | R/W | R/W | | R/W | R/W | R/W | | Reset | | | 0 | 0 | | 0 | 0 | 0 | ### Bit 13 - RXRPTIF Receive Repeat Interrupt Flag bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------------| | 1 | Parity error has persisted after the same character has been received five times (four retransmits) | | 0 | Flag is cleared | ### Bit 12 - TXRPTIF Transmit Repeat Interrupt Flag bit | Value | Description | |-------|-----------------------------------------------------------------------| | 1 | Line error has been detected after the last retransmit per TXRPT[1:0] | | 0 | Flag is cleared | ### Bit 10 - BTCIF Block Time Counter Interrupt Flag bit | Value | Description | |-------|--------------------------------------| | 1 | Block Time Counter has reached 0 | | 0 | Block Time Counter has not reached 0 | ### Bit 9 - WTCIF Waiting Time Counter Interrupt Flag bit | Value | Description | |-------|----------------------------------------| | 1 | Waiting Time Counter has reached 0 | | 0 | Waiting Time Counter has not reached 0 | ### Bit 8 - GTCIF Guard Time Counter Interrupt Flag bit | Value | Description | |-------|--------------------------------------| | 1 | Guard Time Counter has reached 0 | | 0 | Guard Time Counter has not reached 0 | ### Bit 5 - RXRPTIE Receive Repeat Interrupt Enable bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------| | 1 | An interrupt is invoked when a parity error has persisted after the same character has been received five times (four retransmits) | | 0 | Interrupt is disabled | ### Bit 4 - TXRPTIE Transmit Repeat Interrupt Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------------------------------| | 1 | An interrupt is invoked when a line error is detected after the last retransmit per TXRPT[1:0] has been | | | completed) | | 0 | Interrupt is disabled | ### Bit 2 - BTCIE Block Time Counter Interrupt Enable bit © 2021 Microchip Technology Inc. Datasheet 70005452B-page 687 ## Universal Asynchronous Receiver Transmitter ... | Value | Description | |-------|------------------------------------------| | 1 | Block Time Counter interrupt is enabled | | 0 | Block Time Counter interrupt is disabled | ### Bit 1 - WTCIE Waiting Time Counter Interrupt Enable bit | Value | Description | |-------|--------------------------------------------| | 1 | Waiting Time Counter interrupt is enabled | | 0 | Waiting Time Counter interrupt is disabled | ### Bit 0 - GTCIE Guard Time Counter Interrupt Enable bit | Value | Description | |-------|------------------------------------------| | 1 | Guard Time Counter interrupt is enabled | | 0 | Guard Time Counter interrupt is disabled | ## Universal Asynchronous Receiver Transmitter ... ### 16.5.17 UARTx Interrupt Register Name: UxIN Offset: 0x25C, 0x284, 0xF24 Legend: HS = Hardware Settable bit ### Bit 7 - WUIF Wake-up Interrupt Flag bit | Value | Description | |-------|---------------------------------------------------------------------------------------------------| | 1 | Sets when WAKE = 1 and RX makes a 1-to-0 transition; triggers event interrupt (must be cleared by | | | software) | | 0 | WAKE is not enabled or WAKE is enabled, but no wake-up event has occurred | ### Bit 6 - ABDIF Auto-Baud Completed Interrupt Flag bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------------| | 1 | Sets when ABD sequence makes the final 1-to-0 transition; triggers event interrupt (must be cleared by | | | software) | | 0 | ABAUD is not enabled or ABAUD is enabled but auto-baud has not completed | ### Bit 2 - ABDIE Auto-Baud Completed Interrupt Enable Flag bit | Value | Description | |-------|----------------------------------------| | 1 | Allows ABDIF to set an event interrupt | | 0 | ABDIF does not set an event interrupt | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 689 Serial Peripheral Interface (SPI) ## 17. Serial Peripheral Interface (SPI) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**Serial Peripheral Interface (SPI) with Audio Codec Support**" (www.microchip.com/DS70005136) in the "dsPIC33/PIC24 Family Reference Manual". The Serial Peripheral Interface (SPI) module is a synchronous serial interface, useful for communicating with other peripheral or microcontroller devices. These peripheral devices may be serial EEPROMs, shift registers, display drivers, A/D Converters, etc. The SPI module is compatible with the Motorola® SPI and SIOP interfaces. All devices in the dsPIC33CK512MP608 family include three SPI modules. The module supports operation in two Buffer modes. In Standard mode, data are shifted through a single serial buffer. In Enhanced Buffer mode, data are shifted through a FIFO buffer. The FIFO level depends on the configured mode. Note: FIFO depth for this device is four (in 8-Bit Data mode). Variable length data can be transmitted and received, from 2 to 32 bits. **Note:** Do not perform Read-Modify-Write operations (such as bit-oriented instructions) on the SPIxBUF register in either Standard or Enhanced Buffer mode. The module also supports Audio modes. Four different Audio modes are available. - I<sup>2</sup>S mode - · Left Justified mode - · Right Justified mode - PCM/DSP mode In each of these modes, the serial clock is free-running and audio data are always transferred. The SPI serial interface consists of four pins: - SDIx: Serial Data Input - SDOx: Serial Data Output - SCKx: Shift Clock Input or Output The SPI module can be configured to operate using two, three or four pins. The SPI module has the ability to generate three interrupts, reflecting the events that occur during the data communication. The following types of interrupts can be generated: - 1. Receive interrupts are signaled by SPIxRXIF. This event occurs when: - RX watermark interrupt - SPIROV = 1 - SPIRBF = 1 - SPIRBE = 1 provided the respective mask bits are enabled in SPIxIMSKL/H. - 2. Transmit interrupts are signalled by SPIxTXIF. This event occurs when: - TX watermark interrupt - SPITUR = 1 - SPITBF = 1 - SPITBE = 1 provided the respective mask bits are enabled in SPIxIMSKL/H. - 3. General interrupts are signalled by SPIxGIF. This event occurs when: - FRMERR = 1 - SPIBUSY = 1 - SRMT = 1 Serial Peripheral Interface (SPI) provided the respective mask bits are enabled in SPIxIMSKL/H. Block diagrams of the module in Standard and Enhanced modes are shown in Figure 17-1 and Figure 17-2. **Note:** In this section, the SPI modules are referred to together as SPIx, or separately as SPI1, SPI2 or SPI3. Special Function Registers will follow a similar notation. For example, SPIxCON1 and SPIxCON2 refer to the control registers for any of the three SPI modules. To set up the SPIx module for the Standard Host mode of operation: - 1. If using interrupts: - 1.1. Clear the interrupt flag bits in the respective IFSx register. - 1.2. Set the interrupt enable bits in the respective IECx register. - 1.3. Write the SPIxIP bits in the respective IPCx register to set the interrupt priority. - 2. Write the desired settings to the SPIxCON1L and SPIxCON1H registers with the MSTEN bit (SPIxCON1L[5]) = 1. - 3. Clear the SPIROV bit (SPIxSTATL[6]). - Enable SPIx operation by setting the SPIEN bit (SPIxCON1L[15]). - 5. Write the data to be transmitted to the SPIxBUFL and SPIxBUFH registers. Transmission (and reception) will start as soon as data are written to the SPIxBUFL and SPIxBUFH registers. To set up the SPIx module for the Standard Client mode of operation: - 1. Clear the SPIxBUF registers. - 2. If using interrupts: - 2.1. Clear the SPIxBUFL and SPIxBUFH registers. - 2.2. Set the interrupt enable bits in the respective IECx register. - 2.3. Write the SPIxIP bits in the respective IPCx register to set the interrupt priority. - 3. Write the desired settings to the SPIxCON1L, SPIxCON1H and SPIxCON2L registers with the MSTEN bit (SPIxCON1L[5]) = 0. - 4. Clear the SMP bit. - 5. If the CKE bit (SPIxCON1L[8]) is set, then the SSEN bit (SPIxCON1L[7]) must be set to enable the SSX pin. - 6. Clear the SPIROV bit (SPIxSTATL[6]). - 7. Enable SPIx operation by setting the SPIEN bit (SPIxCON1L[15]). **Datasheet** Figure 17-1. SPIx Module Block Diagram (Standard Mode) To set up the SPIx module for the Enhanced Buffer Host mode of operation: - 1. If using interrupts: - 1.1. Clear the interrupt flag bits in the respective IFSx register. - 1.2. Set the interrupt enable bits in the respective IECx register. - 1.3. Write the SPIxIP bits in the respective IPCx register. - 2. Write the desired settings to the SPIxCON1L, SPIxCON1H and SPIxCON2L registers with MSTEN (SPIxCON1L[5]) = 1. - 3. Clear the SPIROV bit (SPIxSTATL[6]). - 4. Select Enhanced Buffer mode by setting the ENHBUF bit (SPIxCON1L[0]). - 5. Enable SPIx operation by setting the SPIEN bit (SPIxCON1L[15]). - Write the data to be transmitted to the SPIxBUFL and SPIxBUFH registers. Transmission (and reception) will start as soon as data are written to the SPIxBUFL and SPIxBUFH registers. To set up the SPIx module for the Enhanced Buffer Client mode of operation: - 1. Clear the SPIxBUFL and SPIxBUFH registers. - 2. If using interrupts: - 2.1. Clear the interrupt flag bits in the respective IFSx register. - 2.2. Set the interrupt enable bits in the respective IECx register. - 2.3. Write the SPIxIP bits in the respective IPCx register to set the interrupt priority. - 3. Write the desired settings to the SPIxCON1L, SPIxCON1H and SPIxCON2L registers with the MSTEN bit (SPIxCON1L[5]) = 0. - 4. Clear the SMP bit. - 5. If the CKE bit is set, then the SSEN bit must be set, thus enabling the SSx pin. - 6. Clear the SPIROV bit (SPIxSTATL[6]). - 7. Select Enhanced Buffer mode by setting the ENHBUF bit (SPIxCON1L[0]). - 8. Enable SPIx operation by setting the SPIEN bit (SPIxCON1L[15]). Figure 17-2. SPIx Module Block Diagram (Enhanced Mode) To set up the SPIx module for Audio mode: - Clear the SPIxBUFL and SPIxBUFH registers. - 2. If using interrupts: - 2.1. Clear the interrupt flag bits in the respective IFSx register. - 2.2. Set the interrupt enable bits in the respective IECx register. - Write the SPIxIP bits in the respective IPCx register to set the interrupt priority. - 3. Write the desired settings to the SPIxCON1L, SPIxCON1H and SPIxCON2L registers with AUDEN (SPIxCON1H[15]) = 1. - Clear the SPIROV bit (SPIxSTATL[6]). - 5. Enable SPIx operation by setting the SPIEN bit (SPIxCON1L[15]). - 6. Write the data to be transmitted to the SPIxBUFL and SPIxBUFH registers. Transmission (and reception) will start as soon as data are written to the SPIxBUFL and SPIxBUFH registers. Serial Peripheral Interface (SPI) Figure 17-3. SPIx Main Connection (Standard Mode) - Note 1: Using the SSx pin in Client mode of operation is optional. - 2: User must write transmit data to read the received data from SPIxBUF. The SPIxTXB and SPIxRXB registers are memory-mapped to SPIxBUF. Serial Peripheral Interface (SPI) Figure 17-4. SPIx Main Connection (Enhanced Buffer Modes) - Note 1: Using the SSx pin in Client mode is optional. - 2: User must write transmit data to read the received data from SPIxBUF. The SPIxTXB and SPIxRXB registers are memory-mapped to SPIxBUF. Equation 17-1. Relationship Between Device and SPIx Clock Speed $$Baud\ Rate = \frac{FP}{(2*(SPIxBRG+1))}$$ Where: FP is the Peripheral Bus Clock Frequency. ## 17.1 SPI Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------|-----------|---------|----------|----------------|------------------|-------------|----------| | 0x02AC | SDI1CON11 | 15:8 | SPIEN | | SPISIDL | DISSDO | MODE32 and | MODE16[1:0] | SMP | CKE | | UXUZAC | SPI1CON1L | 7:0 | SSEN | CKP | MSTEN | DISSDI | DISSCK | MCLKEN | SPIFE | ENHBUF | | 0,000 | CDI4CON4II | 15:8 | AUDEN | SPISGNEXT | IGNROV | IGNTUR | AUDMONO | URDTEN | AUDM | OD[1:0] | | 0x02AE | SPI1CON1H | 7:0 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | | FRMCNT[2:0] | | | 00000 | CDMCONOL | 15:8 | | | | | | | | | | 0x02B0 | SPI1CON2L | 7:0 | | | | | | WLENGTH[4:0 | ] | | | 0x02B2 | | | | | | | | | | | | 0x02B3 | Reserved | | | | | | | | | | | 0x02B4 | SPI1STATL | 15:8 | | | | FRMERR | SPIBUSY | | | SPITUR | | OXOZD4 | OFFICIALE | 7:0 | SRMT | SPIROV | SPIRBE | | SPITBE | | SPITBF | SPIRBF | | 0x02B6 | SPI1STATH | 15:8 | | | | | | M[5:0] | | | | UNUZBO | OFFICIALLI | 7:0 | | | | | TXEL | M[5:0] | | | | 0x02B8 | SPI1BUFL | 15:8 | | | | DATA | [15:8] | | | | | 0.0260 | SFIIBUFL | 7:0 | | | | DATA | <b>4</b> [7:0] | | | | | OVOODA | CDMDUELL | 15:8 | | | | DATA | [31:24] | | | | | 0x02BA | SPI1BUFH | 7:0 | | | | DATA | [23:16] | | | | | 00000 | ODIADDOI | 15:8 | | | | | | BRG[12:8] | | | | 0x02BC | SPI1BRGL | 7:0 | | , | | BRG | G[7:0] | | | | | 0x02BE | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x02BF | | | | | | | | | | | | 0x02C0 | SPI1IMSKL | 15:8 | | | | FRMERREN | BUSYEN | | | SPITUREN | | UXUZCU | SPITIMSKL | 7:0 | SRMTEN | SPIROVEN | SPIRBEN | | SPITBEN | | SPITBFEN | SPIRBFEN | | 0.0000 | SPI1IMSKH | 15:8 | RXWIEN | | | , | RXMS | K[5:0] | | | | 0x02C2 | | 7:0 | TXWIEN | | | | TXMS | K[5:0] | | | | | SPI1URDTL | 15:8 | | | | SPI1URI | | | | | | 0x02C4 | | 7:0 | | | | SPI1UR | | | | | | | | 15:8 | | | | | TH[31:24] | | | | | 0x02C6 | SPI1URDTH | 7:0 | | | | SPI1URD | | | | | | | AND DESCRIPTION OF THE PARTY | 15:8 | SPIEN | | SPISIDL | DISSDO | | MODE16[1:0] | SMP | CKE | | 0x02C8 | SPI2CON1L | 7:0 | SSEN | CKP | MSTEN | DISSDI | DISSCK | MCLKEN | SPIFE | ENHBUF | | | SPI2CON1H | 15:8 | AUDEN | SPISGNEXT | IGNROV | IGNTUR | AUDMONO | URDTEN | | OD[1:0] | | 0x02CA | | 7:0 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | | FRMCNT[2:0] | | | | | 15:8 | | | | | | | | | | 0x02CC | SPI2CON2L | 7:0 | | | | | ļ | U<br>WLENGTH[4:0 | ].<br>] | | | 0x02CE | | , | | | | | | | | | | | Reserved | | | | | | | | | | | 0x02CF | | | | | | | | | | | | 0.0000 | 001007471 | 15:8 | | | | FRMERR | SPIBUSY | | | SPITUR | | 0x02D0 | SPI2STATL | 7:0 | SRMT | SPIROV | SPIRBE | | SPITBE | | SPITBF | SPIRBF | | | | 15:8 | | | | | RXEL | M[5:0] | | | | 0x02D2 | SPI2STATH | 7:0 | | | | | TXEL | M[5:0] | | | | | (Appropries) | 15:8 | | | | DATA | [15:8] | | | | | 0x02D4 | SPI2BUFL | 7:0 | | | | DATA | | | | | | Bertingwood | 72.02-11-12-00 (2.03.00.01) | 15:8 | | | | | [31:24] | | | | | 0x02D6 | SPI2BUFH | 7:0 | | | | | [23:16] | | | | | | 1 325 Spe \$100 min 1 200 | 15:8 | | | | | | BRG[12:8] | | | | 0x02D8 | SPI2BRGL | 7:0 | | | | BRG | G[7:0] | | | | | 0x02DA | | | | | | 2.,0 | | | | | | | Reserved | | | | | | | | | | | 0x02DB | | | | | | | | | | | | | | 15:8 | | | | FRMERREN | BUSYEN | | | SPITUREN | | 0,0000 | CDIOINACIA | 10.0 | | | | | | | | | | 0x02DC | SPI2IMSKL | 7:0 | SRMTEN | SPIROVEN | SPIRBEN | | SPITBEN | | SPITBFEN | SPIRBFEN | | 0x02DC<br>0x02DE | SPI2IMSKL<br>SPI2IMSKH | | SRMTEN<br>RXWIEN | SPIROVEN | SPIRBEN | | | SK[5:0] | SPITBFEN | SPIRBFEN | Serial Peripheral Interface (SPI) | conti | continued | | | | | | | | | | | |----------------------|------------|----------|--------|-----------|------------|--------------|------------|-------------|-------------|----------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0x02E0 | SPI2URDTL | 15:8 | | ' | | SPI2URI | OTL[15:8] | | | | | | UXUZEU | SPIZURDIL | 7:0 | | | | SPI2UR | DTL[7:0] | | | | | | 0x02E2 | SPI2URDTH | 15:8 | | | | SPI2URD | TH[31:24] | | | | | | UXUZEZ | SPIZURDIH | 7:0 | | | | SPI2URD | TH[23:16] | | | | | | 0x02E4 | SPI3CON1L | 15:8 | SPIEN | | SPISIDL | DISSDO | MODE32 and | MODE16[1:0] | SMP | CKE | | | UXU2E4 | SPISCONIL | 7:0 | SSEN | CKP | MSTEN | DISSDI | DISSCK | MCLKEN | SPIFE | ENHBUF | | | 0x02E6 | SPI3CON1H | 15:8 | AUDEN | SPISGNEXT | IGNROV | IGNTUR | AUDMONO | URDTEN | AUDMo | OD[1:0] | | | UXUZEO | SPISCONTH | 7:0 | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | | FRMCNT[2:0] | | | | 0x02E8 | SPI3CON2L | 15:8 | | | | | | | | | | | UXUZEO | SPISCONZL | 7:0 | | | | WLENGTH[4:0] | | | | | | | 0x02EA | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x02EB | | | | | | | | | | | | | 0x02EC | SPI3STATL | 15:8 | | | | FRMERR | SPIBUSY | | | SPITUR | | | UXUZEC | SPISSIAIL | 7:0 | SRMT | SPIROV | SPIRBE | | SPITBE | | SPITBF | SPIRBF | | | 0x02EE | SPI3STATH | 15:8 | | | | | RXEL | M[5:0] | | | | | UXUZEE | SPISSIAIT | 7:0 | | | TXELM[5:0] | | | | | | | | 0x02F0<br><br>0x02F7 | Reserved | | | | | | | | | | | | 0x02F8 | SPI3IMSKL | 15:8 | | | | FRMERREN | BUSYEN | | | SPITUREN | | | UXUZF0 | SPISINISKL | 7:0 | SRMTEN | SPIROVEN | SPIRBEN | | SPITBEN | | SPITBFEN | SPIRBFEN | | | 0x02FA | SPI3IMSKH | 15:8 | RXWIEN | | | | RXMS | K[5:0] | | | | | UXUZFA | SCISIMISKE | 7:0 | TXWIEN | | | | TXMS | K[5:0] | | | | Serial Peripheral Interface (SPI) ### 17.1.1 SPIx Control Register 1 Low Name: SPIxCON1L **Offset:** 0x2AC, 0x2C8, 0x2E4 #### Notes: - 1. When AUDEN = 1, this module functions as if CKE = 0, regardless of its actual value. - 2. When FRMEN = 1, SSEN is not used. - 3. MCLKEN can only be written when the SPIEN bit = 0. - 4. This channel is not meaningful for DSP/PCM mode as LRC follows FRMSYPW. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-----|---------|--------|------------|-------------|-------|--------| | | SPIEN | | SPISIDL | DISSDO | MODE32 and | MODE16[1:0] | SMP | CKE | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SSEN | CKP | MSTEN | DISSDI | DISSCK | MCLKEN | SPIFE | ENHBUF | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - SPIEN SPIx On bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------| | 1 | Enables module | | 0 | Turns off and resets module, disables clocks, disables interrupt event generation, allows SFR | | | modifications | ### Bit 13 - SPISIDL SPIx Stop in Idle Mode bit | Value | Description | |-------|---------------------------------------| | 1 | Halts in CPU Idle mode | | 0 | Continues to operate in CPU Idle mode | ### Bit 12 - DISSDO Disable SDOx Output Port bit | Value | Description | |-------|------------------------------------------------------------------------| | 1 | SDOx pin is not used by the module; pin is controlled by port function | | 0 | SDOx pin is controlled by the module | ### Bits 11:10 - MODE32 and MODE16[1:0] Serial Word Length Select bits<sup>(1,4)</sup> | MODE32 | MODE16 | AUDEN | Communication | | | | | |--------|--------|-------|-------------------------------------------------------|--|--|--|--| | 1 | X | | 32-Bit | | | | | | 0 | 1 | 0 | 16-Bit | | | | | | 0 | 0 | | 8-Bit | | | | | | 1 | 1 | | 24-Bit Data, 32-Bit FIFO, 32-Bit Channel/64-Bit Frame | | | | | | 1 | 0 | 1 | 32-Bit Data, 32-Bit FIFO, 32-Bit Channel/64-Bit Frame | | | | | | 0 | 1 | 1 | 16-Bit Data, 16-Bit FIFO, 32-Bit Channel/64-Bit Frame | | | | | | 0 | 0 | | 16-Bit FIFO, 16-Bit Channel/32-Bit Frame | | | | | ### Bit 9 - SMP SPIx Data Input Sample Phase bit Client Mode: Input data are always sampled at the middle of data output time, regardless of the SMP setting. Host Mode: | <u>Host Wode.</u> | | | | | | |-------------------|----------------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | Input data are sampled at the end of data output time | | | | | | 0 | Input data are sampled at the middle of data output time | | | | | Serial Peripheral Interface (SPI) | Bit 8 – CKE SPIx Clock Edge Select bit <sup>(1)</sup> | | | | | |-------------------------------------------------------|----------------------------------------------------------------------------|--|--|--| | Value | Description | | | | | 1 | Transmit happens on transition from active clock state to Idle clock state | | | | | 0 | Transmit happens on transition from Idle clock state to active clock state | | | | ### Bit 7 - SSEN Client Select Enable bit (Client mode)(2) | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1 | SSx pin is used by the macro in Client mode; SSx pin is used as the Client select input | | 0 | SSx pin is not used by the macro (SSx pin will be controlled by the port I/O) | ### Bit 6 - CKP Clock Polarity Select bit | Value | Description | |-------|-------------------------------------------------------------------| | 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 | ### Bit 5 - MSTEN Host Mode Enable bit | Value | Description | |-------|-------------| | 1 | Host mode | | 0 | Client mode | ### Bit 4 - DISSDI Disable SDIx Input Port bit | Value | Description | |-------|------------------------------------------------------------------------| | 1 | SDIx pin is not used by the module; pin is controlled by port function | | 0 | SDIx pin is controlled by the module | ### Bit 3 - DISSCK Disable SCKx Output Port bit | Value | Description | |-------|------------------------------------------------------------------------| | 1 | SCKx pin is not used by the module; pin is controlled by port function | | 0 | SCKx pin is controlled by the module | ### Bit 2 - MCLKEN Host Clock Enable bit(3) | Value | Description | |-------|--------------------------| | 1 | MCLK is used by the BRG | | 0 | PBCLK is used by the BRG | ### Bit 1 - SPIFE Frame Sync Pulse Edge Select bit | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | Frame Sync pulse (Idle-to-active edge) coincides with the first bit clock | | 0 | Frame Sync pulse (Idle-to-active edge) precedes the first bit clock | ### Bit 0 - ENHBUF Enhanced Buffer Enable bit | Value | Description | |-------|----------------------------------| | 1 | Enhanced Buffer mode is enabled | | 0 | Enhanced Buffer mode is disabled | © 2021 Microchip Technology Inc. and its subsidiaries Serial Peripheral Interface (SPI) ### 17.1.2 SPIx Control Register 1 High Name: SPIxCON1H **Offset:** 0x2AE, 0x2CA, 0x2E6 #### Notes: - 1. AUDEN can only be written when the SPIEN bit = 0. - 2. AUDMONO can only be written when the SPIEN bit = 0 and is only valid for AUDEN = 1. - 3. URDTEN is only valid when IGNTUR = 1. - 4. AUDMOD[1:0] can only be written when the SPIEN bit = 0 and is only valid when AUDEN = 1. When NOT in PCM/DSP mode, this module functions as if FRMSYPW = 1, regardless of its actual value. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-----------|--------|--------|---------|--------|-------------|-----| | | AUDEN | SPISGNEXT | IGNROV | IGNTUR | AUDMONO | URDTEN | AUDMOD[1:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FRMEN | FRMSYNC | FRMPOL | MSSEN | FRMSYPW | | FRMCNT[2:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - AUDEN Audio Codec Support Enable bit(1) | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | Audio protocol is enabled; MSTEN controls the direction of both SCKx and frame (a.k.a. LRC), and | | | this module functions as if FRMEN = 1, FRMSYNC = MSTEN, FRMCNT[2:0] = 001 and SMP = 0, | | | regardless of their actual values | | 0 | Audio protocol is disabled | ### Bit 14 - SPISGNEXT SPIx Sign-Extend RX FIFO Read Data Enable bit | Value | Description | |-------|-----------------------------------------| | 1 | Data from RX FIFO are sign-extended | | 0 | Data from RX FIFO are not sign-extended | ### Bit 13 - IGNROV Ignore Receive Overflow bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------------------------| | 1 | A Receive Overflow (ROV) is NOT a critical error; during ROV, data in the FIFO are not overwritten by the receive data | | 0 | A ROV is a critical error that stops SPI operation | ### Bit 12 - IGNTUR Ignore Transmit Underrun bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 1 | A Transmit Underrun (TUR) is NOT a critical error and data indicated by URDTEN are transmitted until | | | the SPIxTXB is not empty | | 0 | A TUR is a critical error that stops SPI operation | ### Bit 11 - AUDMONO Audio Data Format Transmit bit(2) | Value | Description | |-------|-------------------------------------------------------------------------------------------| | 1 | Audio data are mono (i.e., each data word is transmitted on both left and right channels) | | 0 | Audio data are stereo | ### Bit 10 - URDTEN Transmit Underrun Data Enable bit(3) | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Transmits data out of SPIxURDT register during Transmit Underrun conditions | | 0 | Transmits the last received data during Transmit Underrun conditions | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 700 Serial Peripheral Interface (SPI) | Bits 9:8 - | Bits 9:8 – AUDMOD[1:0] Audio Protocol Mode Selection bits <sup>(4)</sup> | | |------------|----------------------------------------------------------------------------------------------|--| | Value | Description | | | 11 | PCM/DSP mode | | | 10 | Right Justified mode: This module functions as if SPIFE = 1, regardless of its actual value | | | 01 | Left Justified mode: This module functions as if SPIFE = 1, regardless of its actual value | | | 00 | I <sup>2</sup> S mode: This module functions as if SPIFE = 0, regardless of its actual value | | ### Bit 7 - FRMEN Framed SPIx Support bit | Value | Description | |-------|----------------------------------------------------------------------------| | 1 | Framed SPIx support is enabled (SSx pin is used as the FSYNC input/output) | | 0 | Framed SPIx support is disabled | ### Bit 6 - FRMSYNC Frame Sync Pulse Direction Control bit | Value | Description | |-------|---------------------------------| | 1 | Frame Sync pulse input (Client) | | 0 | Frame Sync pulse output (Host) | ### Bit 5 - FRMPOL Frame Sync/Client Select Polarity bit | Value | Description | |-------|-----------------------------------------------| | 1 | Frame Sync pulse/Client select is active-high | | 0 | Frame Sync pulse/Client select is active-low | ### Bit 4 - MSSEN Host Mode Client Select Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | SPIx Client select support is enabled with polarity determined by FRMPOL (SSx pin is automatically | | | driven during transmission in Host mode) | | 0 | Client select SPIx support is disabled (SSx pin will be controlled by port I/O) | ### Bit 3 - FRMSYPW Frame Sync Pulse-Width bit | Value | Description | |-------|------------------------------------------------------------------------------------------| | 1 | Frame Sync pulse is one serial word length wide (as defined by MODE[32,16]/WLENGTH[4:0]) | | 0 | Frame Sync pulse is one clock (SCKx) wide | ### Bits 2:0 - FRMCNT[2:0] Frame Sync Pulse Counter bits Controls the number of serial words transmitted per Sync pulse. | Value | Description | |-------|--------------------------------------------------------------------------------------| | 111 | Reserved | | 110 | Reserved | | 101 | Generates a Frame Sync pulse on every 32 serial words | | 100 | Generates a Frame Sync pulse on every 16 serial words | | 011 | Generates a Frame Sync pulse on every 8 serial words | | 010 | Generates a Frame Sync pulse on every 4 serial words | | 001 | Generates a Frame Sync pulse on every 2 serial words (value used by audio protocols) | | 000 | Generates a Frame Sync pulse on each serial word | **Serial Peripheral Interface (SPI)** ### 17.1.3 SPIx Control Register 2 Low Name: SPIxCON2L Offset: 0x2B0, 0x2CC, 0x2E8 ### Notes: 1. These bits are effective when AUDEN = 0 only. 2. Varying the length by changing these bits does not affect the depth of the TX/RX FIFO. Bits 4:0 - WLENGTH[4:0] Variable Word Length bits(1,2) | 11111 32-b<br>11110 31-b | cription<br>bit data<br>bit data | |--------------------------|--------------------------------------| | 11110 <b>31-</b> b | | | | oit data | | | | | | it data | | | it data | | 11011 <b>28-b</b> | it data | | | oit data | | | it data | | | it data | | | oit data | | | oit data | | | oit data | | | oit data | | 2000 | oit data | | | oit data | | | oit data | | 10000 <b>17-b</b> | oit data | | | it data | | 01110 <b>15-b</b> | it data | | | it data | | | it data | | 01011 <b>12-b</b> | oit data | | | it data | | | it data | | | data | | | data | | | data | | | data | | 00100 <b>5-bit</b> | data | | | data | | | data | | | data | | 00000 See | MODE[32,16] bits in SPIxCON1L[11:10] | Serial Peripheral Interface (SPI) ### 17.1.4 SPIx Status Register Low Name: SPIxSTATL **Offset:** 0x2B4, 0x2D0, 0x2EC #### Note: 1. SPITUR is cleared when SPIEN = 0. When IGNTUR = 1, SPITUR provides dynamic status of the Transmit Underrun condition, but does not stop RX/TX operation and does not need to be cleared by software. Legend: C = Clearable bit; HS = Hardware Settable bit; HSC = Hardware Settable/Clearable bit #### Bit 12 - FRMERR SPIx Frame Error Status bit | Value | Description | |-------|----------------------------| | 1 | Frame error is detected | | 0 | No frame error is detected | #### Bit 11 - SPIBUSY SPIx Activity Status bit | Value | Description | |-------|-------------------------------------------------| | 1 | Module is currently busy with some transactions | | 0 | No ongoing transactions (at time of read) | ### Bit 8 - SPITUR SPIx Transmit Underrun Status bit(1) | Value | Description | |-------|---------------------------------------------------------------| | 1 | Transmit buffer has encountered a Transmit Underrun condition | | 0 | Transmit buffer does not have a Transmit Underrun condition | ### Bit 7 - SRMT Shift Register Empty Status bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | No current or pending transactions (i.e., neither SPIxTXB or SPIxTXSR contains data to transmit) | | 0 | Current or pending transactions | ### Bit 6 - SPIROV SPIx Receive Overflow Status bit | Value | Description | |-------|----------------------------------------------------------------------------------| | 1 | A new byte/half-word/word has been completely received when the SPIxRXB was full | | 0 | No overflow | ### Bit 5 - SPIRBE SPIx RX Buffer Empty Status bit ### Standard Buffer Mode: Automatically set in hardware when SPIxBUF is read from, reading SPIxRXB. Automatically cleared in hardware when SPIx transfers data from SPIxRXSR to SPIxRXB. ### Enhanced Buffer Mode: Indicates RXELM[5:0] = 000000. | Value | Description | |-------|------------------------| | 1 | RX buffer is empty | | 0 | RX buffer is not empty | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 703 Serial Peripheral Interface (SPI) ### Bit 3 - SPITBE SPIx Transmit Buffer Empty Status bit Standard Buffer Mode: Automatically set in hardware when SPIx transfers data from SPIxTXB to SPIxTXSR. Automatically cleared in hardware when SPIxBUF is written, loading SPIxTXB. Enhanced Buffer Mode: Indicates TXELM[5:0] = 0000000. | Value | Description | |-------|----------------------| | 1 | SPIxTXB is empty | | 0 | SPIxTXB is not empty | ### Bit 1 - SPITBF SPIx Transmit Buffer Full Status bit Standard Buffer Mode: Automatically set in hardware when SPIxBUF is written, loading SPIxTXB. Automatically cleared in hardware when SPIx transfers data from SPIxTXB to SPIxTXSR. **Enhanced Buffer Mode:** Indicates TXELM[5:0] = 111111. | Value | Description | |-------|------------------| | 1 | SPIxTXB is full | | 0 | SPIxTXB not full | ### Bit 0 - SPIRBF SPIx Receive Buffer Full Status bit Standard Buffer Mode: Automatically set in hardware when SPIx transfers data from SPIxRXSR to SPIxRXB. Automatically cleared in hardware when SPIxBUF is read from, reading SPIxRXB. **Enhanced Buffer Mode:** Indicates RXELM[5:0] = 111111. | Value | Description | |-------|---------------------| | 1 | SPIxRXB is full | | 0 | SPIxRXB is not full | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 704 Serial Peripheral Interface (SPI) ### 17.1.5 SPIx Status Register High Name: SPIxSTATH **Offset:** 0x2B6, 0x2D2, 0x2EE #### Notes: - 1. RXELM3 and TXELM3 bits are only present when FIFODEPTH = 8 or higher. - 2. RXELM4 and TXELM4 bits are only present when FIFODEPTH = 16 or higher. - 3. RXELM5 and TXELM5 bits are only present when FIFODEPTH = 32. Legend: HSC = Hardware Settable/Clearable bit Bits 13:8 - RXELM[5:0] Receive Buffer Element Count bits (valid in Enhanced Buffer mode)(1,2,3) Bits 5:0 – TXELM[5:0] Transmit Buffer Element Count bits (valid in Enhanced Buffer mode)(1,2,3) Serial Peripheral Interface (SPI) ### 17.1.6 SPIx Buffer Register Low Name: SPIxBUFL Offset: 0x2B8, 0x2D4 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|------------|-----|-----|-----|-----|-----|-----|-----|--| | | DATA[15:8] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DATA[7:0] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - DATA[15:0] SPI FIFO Data bits Serial Peripheral Interface (SPI) ### 17.1.7 SPIx Buffer Register High Name: SPIxBUFH Offset: 0x2BA, 0x2D6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|--------|-----|-----|-----| | | | | | DATA[ | 31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DATA[ | 23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - DATA[31:16] SPI FIFO Data bits Serial Peripheral Interface (SPI) ### 17.1.8 SPIx Baud Rate Generator Register Low Name: SPIxBRGL Offset: 0x2BC, 0x2D8 ### Note: 1. Changing the BRG value when SPIEN = 1 causes undefined behavior. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-----|-------|-----------|-----|-----| | | | | | | | BRG[12:8] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | BRG | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 12:0 - BRG[12:0] SPI Baud Rate Generator Divisor bits<sup>(1)</sup> Serial Peripheral Interface (SPI) ### 17.1.9 SPIx Interrupt Mask Register Low Name: SPIxIMSKL **Offset:** 0x2C0, 0x2DC, 0x2F8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----------|---------|----------|---------|----|----------|----------| | | | | | FRMERREN | BUSYEN | | | SPITUREN | | Access | | | | R/W | R/W | , | | R/W | | Reset | | | | 0 | 0 | | | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SRMTEN | SPIROVEN | SPIRBEN | | SPITBEN | | SPITBFEN | SPIRBFEN | | Access | R/W | R/W | R/W | | R/W | | R/W | R/W | | Reset | 0 | 0 | 0 | | 0 | | 0 | 0 | ### Bit 12 - FRMERREN Enable Interrupt Events via FRMERR bit | Value | Description | |-------|--------------------------------------------------| | 1 | Frame error generates an interrupt event | | 0 | Frame error does not generate an interrupt event | ### Bit 11 - BUSYEN Enable Interrupt Events via SPIBUSY bit | Value | Description | |-------|----------------------------------------------| | 1 | SPIBUSY generates an interrupt event | | 0 | SPIBUSY does not generate an interrupt event | ### Bit 8 - SPITUREN Enable Interrupt Events via SPITUR bit | Value | Description | |-------|--------------------------------------------------------| | 1 | Transmit Underrun (TUR) generates an interrupt event | | 0 | Transmit Underrun does not generate an interrupt event | ### Bit 7 - SRMTEN Enable Interrupt Events via SRMT bit | Value | Description | |-------|---------------------------------------------------------| | 1 | Shift Register Empty (SRMT) generates interrupt events | | 0 | Shift Register Empty does not generate interrupt events | ### Bit 6 - SPIROVEN Enable Interrupt Events via SPIROV bit | Value | Description | |-------|------------------------------------------------------------| | 1 | SPIx Receive Overflow (ROV) generates an interrupt event | | 0 | SPIx Receive Overflow does not generate an interrupt event | ### Bit 5 - SPIRBEN Enable Interrupt Events via SPIRBE bit | Value | Description | |-------|-----------------------------------------------------------| | 1 | SPIx RX buffer empty generates an interrupt event | | 0 | SPIx RX buffer empty does not generate an interrupt event | ### Bit 3 - SPITBEN Enable Interrupt Events via SPITBE bit | Value | Description | |-------|-----------------------------------------------------------------| | 1 | SPIx transmit buffer empty generates an interrupt event | | 0 | SPIx transmit buffer empty does not generate an interrupt event | ### Bit 1 - SPITBFEN Enable Interrupt Events via SPITBF bit | Value | Description | |-------|----------------------------------------------------------------| | 1 | SPIx transmit buffer full generates an interrupt event | | n | SPIx transmit buffer full does not generate an interrupt event | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 709 Serial Peripheral Interface (SPI) #### Bit 0 - SPIRBFEN Enable Interrupt Events via SPIRBF bit | Dit 0 - 31 INDI LIN Chable interrupt Events via 31 INDI bit | | | | | |-------------------------------------------------------------|---------------------------------------------------------------|--|--|--| | Value | Description | | | | | 1 | SPIx receive buffer full generates an interrupt event | | | | | 0 | SPIv receive huffer full does not generate an interrupt event | | | | Serial Peripheral Interface (SPI) ### 17.1.10 SPIx Interrupt Mask Register High Name: SPIxIMSKH Offset: 0x2C2, 0x2DE, 0x2FA #### Notes: - Mask values higher than FIFODEPTH are not valid. The module will not trigger a match for any value in this case. - 2. RXMSK2 and TXMSK2 bits are only present when FIFODEPTH = 8 or higher. - 3. RXMSK3 and TXMSK3 bits are only present when FIFODEPTH = 16 or higher. - 4. RXMSK4 and TXMSK4 bits are only present when FIFODEPTH = 32. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|-----|-----|------|--------|-----|-----| | | RXWIEN | | | | RXMS | K[5:0] | | | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TXWIEN | | | | TXMS | K[5:0] | | , | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | Bit 15 - RXWIEN Receive Watermark Interrupt Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------| | 1 | Triggers receive buffer element watermark interrupt when RXMSK[5:0] ≤ RXELM[5:0] | | 0 | Disables receive buffer element watermark interrupt | ### Bits 13:8 - RXMSK[5:0] RX Buffer Mask bits(1,2,3,4) RX mask bits; used in conjunction with the RXWIEN bit. ### Bit 7 - TXWIEN Transmit Watermark Interrupt Enable bit | Value | Description | |-------|-----------------------------------------------------------------------------------| | 1 | Triggers transmit buffer element watermark interrupt when TXMSK[5:0] = TXELM[5:0] | | 0 | Disables transmit buffer element watermark interrupt | ### Bits 5:0 – TXMSK[5:0] TX Buffer Mask bits<sup>(1,2,3,4)</sup> TX mask bits; used in conjunction with the TXWIEN bit. **Serial Peripheral Interface (SPI)** ### 17.1.11 SPIx Underrun Data Register Low Name: SPIxURDTL Offset: 0x2C4, 0x2E0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|---------|-----------|-----|-----|-----| | | | | | SPIxURE | DTL[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | SPIxUR | DTL[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - SPIxURDTL[15:0] SPI Underrun Data bits These bits are only used when URDTEN = 1. This register holds the data to transmit when a Transmit Underrun condition occurs. When the MODE[32:16] or WLENGTH[4:0] bits select 16 to 9-bit data, the SPIx only uses URDATA[15:0]. When the MODE[32:16] or WLENGTH[4:0] bits select 8 to 2-bit data, the SPIx only uses URDATA[7:0]. Serial Peripheral Interface (SPI) ### 17.1.12 SPIx Underrun Data Register Low Name: SPIxURDTH Offset: 0x2C6, 0x2E2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|---------|-----------|-----|-----|-----| | | | | | SPIxURD | TH[31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | SPIxURD | TH[23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - SPIxURDTH[31:16] SPI Underrun Data bits These bits are only used when URDTEN = 1. This register holds the data to transmit when a Transmit Underrun condition occurs. When the MODE[32:16] or WLENGTH[4:0] bits select 32 to 25-bit data, the SPIx only uses URDATA[31:16]. When the MODE[32:16] or WLENGTH[4:0] bits select 24 to 17-bit data, the SPIx only uses URDATA[23:16]. Inter-Integrated Circuit (I2C) ## 18. Inter-Integrated Circuit (I<sup>2</sup>C) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. For more information, refer to "Inter-Integrated Circuit (I<sup>2</sup>C)" (www.microchip.com/DS70000195) in the "dsPIC33/PIC24 Family Reference Manual". The Inter-Integrated Circuit ( $I^2C$ ) module is a serial interface useful for communicating with other peripheral or microcontroller devices. These peripheral devices may be serial EEPROMs, display drivers, A/D Converters, etc. The I<sup>2</sup>C module supports these features: - · 7-Bit and 10-Bit Device Addresses - General Call Address as Defined in the I<sup>2</sup>C Protocol - Both 100 kHz and 400 kHz Bus Specifications - · Configurable Address Masking - · Multi-Host modes to Prevent Loss of Messages in Arbitration - Bus Repeater mode, Allowing the Acceptance of All Messages as a Client, regardless of the Address - · Automatic SCL A block diagram of the module is shown in Figure 18-1. ### 18.1 Communicating as a Host in a Single Host Environment The details of sending a message in Host mode depends on the communication protocol for the device being communicated with. Typically, the sequence of events is as follows: - Assert a Start condition on SDAx and SCLx. - 2. Send the I<sup>2</sup>C device address byte to the Client with a write indication. - 3. Wait for and verify an Acknowledge from the Client. - 4. Send the first data byte (sometimes known as the command) to the Client. - 5. Wait for and verify an Acknowledge from the Client. - 6. Send the serial memory address low byte to the Client. - 7. Repeat Steps 4 and 5 until all data bytes are sent. - 8. Assert a Repeated Start condition on SDAx and SCLx. - 9. Send the device address byte to the Client with a read indication. - 10. Wait for and verify an Acknowledge from the Client. - 11. Enable Host reception to receive serial memory data. - 12. Generate an ACK or NACK condition at the end of a received byte of data. - 13. Generate a Stop condition on SDAx and SCLx. Figure 18-1. I2Cx Block Diagram ### 18.2 Setting Baud Rate When Operating as a Bus Main To compute the Baud Rate Generator reload value, use Equation 18-1. Equation 18-1. Computing Baud Rate Reload Value<sup>(1,2,3)</sup> $I2CxBRG = ((1/F_{SCL} - Delay) \cdot F_{CY}) - 2$ #### Notes: - These clock rate values are for guidance only. The actual clock rate should be measured in its intended application. - 2. Typical value of delay varies from 110 ns to 150 ns. - 3. I2CxBRG values of 0 to 3 are expressly forbidden. The user should never program the I2CxBRG with a value of 0x0, 0x1, 0x2 or 0x3 as indeterminate results may occur. ### 18.3 Client Address Masking The I2CxMSK register (I2CxMASK) designates address bit positions as "don't care" for both 7-Bit and 10-Bit Addressing modes. Setting a particular bit location (= 1) in the I2CxMSK register causes the Client module to respond, whether the corresponding address bit value is a '0' or a '1'. For example, when I2CxMSK is set to '0010000000', the Client module will detect both addresses, '0000000000' and '0010000000'. To enable address masking, the Intelligent Peripheral Management Interface (IPMI) must be disabled by clearing the STRICT bit (I2CxCONL[11]). **Note:** As a result of changes in the I<sup>2</sup>C protocol, the addresses in Table 18-2 are reserved and will not be Acknowledged in Client mode. This includes any address mask settings that include any of these addresses. Table 18-1. I2Cx Clock Rates<sup>(1,2)</sup> | - | _ | I2CxBRG Value | | | | |-----------------|------------------|---------------|-------------|--|--| | F <sub>cY</sub> | F <sub>SCL</sub> | Decimal | Hexadecimal | | | | 100 MHz | 1 MHz | 41 | 29 | | | | 100 MHz | 400 kHz | 116 | 74 | | | | 100 MHz | 100 kHz | 491 | 1EB | | | | 80 MHz | 1 MHz | 32 | 20 | | | | 80 MHz | 400 kHz | 92 | 5C | | | | 80 MHz | 100 kHz | 392 | 188 | | | | 60 MHz | 1 MHz | 24 | 18 | | | | 60 MHz | 400 kHz | 69 | 45 | | | | 60 MHz | 100 kHz | 294 | 126 | | | | 40 MHz | 1 MHz | 15 | 0F | | | | 40 MHz | 400 kHz | 45 | 2D | | | | 40 MHz | 100 kHz | 195 | C3 | | | | 20 MHz | 1 MHz | 7 | 7 | | | ### Notes: - 1. Based on $F_{CY} = F_{OSC}/2$ ; Doze mode and PLL are disabled. - 2. These clock rate values are for guidance only. The actual clock rate can be affected by various system-level parameters. The actual clock rate should be measured in its intended application. Inter-Integrated Circuit (I2C) | continued | | | | | | |-----------------|------------------|---------------|-------------|--|--| | F | F | I2CxBRG Value | | | | | F <sub>CY</sub> | F <sub>SCL</sub> | Decimal | Hexadecimal | | | | 20 MHz | 400 kHz | 22 | 16 | | | | 20 MHz | 100 kHz | 97 | 61 | | | ### Notes: - 1. Based on $F_{CY} = F_{OSC}/2$ ; Doze mode and PLL are disabled. - These clock rate values are for guidance only. The actual clock rate can be affected by various system-level parameters. The actual clock rate should be measured in its intended application. Table 18-2. I2Cx Reserved Addresses<sup>(1)</sup> | Client Address | R/W Bit | Description | |----------------|---------|-----------------------------------------| | 0000 000 | 0 | General Call Address <sup>(2)</sup> | | 0000 000 | 1 | Start Byte | | 0000 001 | Х | Cbus Address | | 0000 01x | Х | Reserved | | 0000 1xx | Х | HS Mode Host Code | | 1111 0xx | Х | 10-Bit Client Upper Byte <sup>(3)</sup> | | 1111 1xx | Х | Reserved | ### Note: - 1. The address bits listed here will never cause an address match independent of address mask settings. - 2. This address will be Acknowledged only if GCEN = 1. - 3. A match on this address can only occur on the upper byte in 10-Bit Addressing mode. ### 18.4 SMBus Support The dsPIC33CK512MP608 family devices have support for SMBus through options in the input voltage thresholds. There are two control bits to select one of three options: SMEN (I2CxCONL[8]) and Configuration bit, SMBEN (FDEVOPT[10]). I2CxCONL details the setting of these control bits. Table 18-3. I<sup>2</sup>C Pin Voltage Threshold | | SMEN SFR Bit (I2CxCONL[8]) | SMBEN Configuration Bit (FDEVOPT[10]) | |----------------------------|----------------------------|---------------------------------------| | I <sup>2</sup> C (default) | 0 | х | | SMBus 2.0 | 1 | 0 | | SMBus 3.0 | 1 | 1 | ## 18.5 I2C Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------|------------------|----------|---------|--------|---------|--------|--------|-------|--------|-------| | 0x0200 | I2C1CONL | 15:8 | I2CEN | | I2CSIDL | SCLREL | STRICT | A10M | DISSLW | SMEN | | 0x0200 | IZCICONE | 7:0 | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | 0x0202 | I2C1CONH | 15:8 | | | | | | | | | | UNUZUZ | 1201001111 | 7:0 | | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | 0x0204 | I2C1STAT | 15:8 | ACKSTAT | TRSTAT | ACKTIM | | | BCL | GCSTAT | ADD10 | | | N=== This in the | 7:0 | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | | 0x0206 | | | | | | | | | | | | <br>0x020B | Reserved | | | | | | | | | | | 00000 | IOOAMOK | 15:8 | | | | | | | MSK | [9:8] | | 0x020C | I2C1MSK | 7:0 | | | | MSK | [7:0] | , | | | | 0x020E<br><br>0x021B | Reserved | | | | | | | | | | | 0,0210 | IOCOCONII | 15:8 | I2CEN | | I2CSIDL | SCLREL | STRICT | A10M | DISSLW | SMEN | | 0x021C | I2C2CONL | 7:0 | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | 0x021E | I2C2CONH | 15:8 | | | | | | | | | | UXUZ IL | IZCZCONH | 7:0 | | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | 0x0220 | I2C2STAT | 15:8 | ACKSTAT | TRSTAT | ACKTIM | | | BCL | GCSTAT | ADD10 | | 0X0220 | 120231A1 | 7:0 | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | | 0x0222<br><br>0x0227 | Reserved | | | | | | | | | | | 0.0000 | 100011014 | 15:8 | | | | | | | MSK | [9:8] | | 0x0228 | I2C2MSK | 7:0 | | | | MSK | [7:0] | , | | | | 0x022A<br><br>0x0F5B | Reserved | | | | | | | | | | | 00550 | IOCOCONII | 15:8 | I2CEN | | I2CSIDL | SCLREL | STRICT | A10M | DISSLW | SMEN | | 0x0F5C | I2C3CONL | 7:0 | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | 00555 | IDCCCONILI | 15:8 | | | | | | | | | | 0x0F5E | I2C3CONH | 7:0 | | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | 0x0F60 | I2C3STAT | 15:8 | ACKSTAT | TRSTAT | ACKTIM | | | BCL | GCSTAT | ADD10 | | UXUFOU | 12C3S1A1 | 7:0 | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | | 0x0F62<br><br>0x0F67 | Reserved | | | | | | | | | | | | | 15:8 | | | | | | | MSK | [9:8] | | 0x0F68 | I2C3MSK | 7:0 | | | | MSK | 717.01 | | | 1 | Inter-Integrated Circuit (I2C) ### 18.5.1 I2Cx Control Register Low Name: I2CxCONL **Offset:** 0x200, 0x21C, 0xF5C #### Notes: - 1. Automatically cleared to '0' at the beginning of Client transmission; automatically cleared to '0' at the end of Client reception. - 2. Automatically cleared to '0' at the beginning of Client transmission. ### Legend: HC = Hardware Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|---------|--------|--------|--------|--------|--------| | | I2CEN | | I2CSIDL | SCLREL | STRICT | A10M | DISSLW | SMEN | | Access | R/W | | R/W/HC | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | GCEN | STREN | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | Access | R/W | R/W | R/W | R/W/HC | R/W/HC | R/W/HC | R/W/HC | R/W/HC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - I2CEN I2Cx Enable bit (writable from software only) | Va | lue | Description | |----|-----|--------------------------------------------------------------------------------------| | 1 | | Enables the I2Cx module, and configures the SDAx and SCLx pins as serial port pins | | 0 | | Disables the I2Cx module; all I <sup>2</sup> C pins are controlled by port functions | ### Bit 13 - I2CSIDL I2Cx Stop in Idle Mode bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation in Idle mode | # **Bit 12 – SCLREL** SCLx Release Control bit (I<sup>2</sup>C Client mode only)<sup>(1)</sup> If STREN = 1:<sup>(2)</sup> User software may write '0' to initiate a clock stretch and write '1' to release the clock. Hardware clears at the beginning of every Client data byte transmission. Hardware clears at the end of every Client address byte reception. Hardware clears at the end of every Client data byte reception. ### If STREN = 0: User software may only write '1' to release the clock. Hardware clears at the beginning of every Client data byte transmission. Hardware clears at the end of every Client address byte reception. | Value | Description | |-------|------------------------------------------| | 1 | Releases the SCLx clock | | 0 | Holds the SCLx clock low (clock stretch) | ### Bit 11 - STRICT I2Cx Strict Reserved Address Rule Enable bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Strict reserved addressing is enforced; for reserved addresses. | | | (In Client Mode) – The device doesn't respond to reserved address space and addresses falling in that category are NACKed. | | | (In Host Mode) – The device is allowed to generate addresses with reserved address space. | | 0 | Reserved addressing would be Acknowledged. | | | (In Client Mode) – The device will respond to an address falling in the reserved address space. When there is a match with any of the reserved addresses, the device will generate an ACK. | | | (In Host Mode) – Reserved. | Inter-Integrated Circuit (I2C) #### Bit 10 - A10M 10-Bit Client Address Flag bit | Value | Description | |-------|------------------------------------| | 1 | I2CxADD is a 10-bit Client address | | 0 | I2CxADD is a 7-bit Client address | #### Bit 9 - DISSLW Slew Rate Control Disable bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------| | 1 | Slew rate control is disabled for Standard Speed mode (100 kHz, also disabled for 1 MHz mode) | | 0 | Slew rate control is enabled for High-Speed mode (400 kHz) | #### Bit 8 - SMEN SMBus Input Levels Enable bit | Value | Description | |-------|------------------------------------------------------------------------------| | 1 | Enables input logic so thresholds are compliant with the SMBus specification | | 0 | Disables SMBus-specific inputs | ### Bit 7 – GCEN General Call Enable bit (in I<sup>2</sup>C Client mode only) | I | Value | Description | |---|-------|-------------------------------------------------------------------------------------------------------| | | 1 | Enables interrupt when a general call address is received in I2CxRSR; module is enabled for reception | | | 0 | General call address is disabled. | ### Bit 6 - STREN SCLx Clock Stretch Enable bit In I<sup>2</sup>C Client mode only; used in conjunction with the SCLREL bit. | Value | Description | |-------|---------------------------| | 1 | Enables clock stretching | | 0 | Disables clock stretching | ### Bit 5 - ACKDT Acknowledge Data bit In $I^2C$ Host mode during Host Receive mode. The value that will be transmitted when the user initiates an Acknowledge sequence at the end of a receive. In I<sup>2</sup>C Client mode when AHEN = 1 or DHEN = 1. The value that the Client will transmit when it initiates an Acknowledge sequence at the end of an address or data reception. | Value | Description | |-------|--------------| | 1 | NACK is sent | | 0 | ACK is sent | ### Bit 4 - ACKEN Acknowledge Sequence Enable bit In I<sup>2</sup>C Host mode only; applicable during Host Receive mode. | Value | Description | |-------|------------------------------------------------------------------------------------| | 1 | Initiates Acknowledge sequence on SDAx and SCLx pins, and transmits ACKDT data bit | | 0 | Acknowledge sequence is Idle | ### Bit 3 – RCEN Receive Enable bit (in I<sup>2</sup>C Host mode only) | Value | Description | |-------|----------------------------------------------------------------------------------------------------------------| | 1 | Enables Receive mode for I <sup>2</sup> C; automatically cleared by hardware at end of 8-bit receive data byte | | 0 | Receive sequence is not in progress | ### Bit 2 – PEN Stop Condition Enable bit (in I<sup>2</sup>C Host mode only) | Value | Description | |-------|------------------------------------------------| | 1 | Initiates Stop condition on SDAx and SCLx pins | | 0 | Stop condition is Idle | ### Bit 1 - RSEN Restart Condition Enable bit (in I<sup>2</sup>C Host mode only) | Value | Description | |-------|---------------------------------------------------| | 1 | Initiates Restart condition on SDAx and SCLx pins | | 0 | Restart condition is Idle | ### Bit 0 - SEN Start Condition Enable bit (in I<sup>2</sup>C Host mode only) Inter-Integrated Circuit (I2C) | Value | Description | |-------|-------------------------------------------------| | 1 | Initiates Start condition on SDAx and SCLx pins | | 0 | Start condition is Idle | Inter-Integrated Circuit (I2C) ## 18.5.2 I2Cx Control Register High Name: I2CxCONH **Offset:** 0x202, 0x21E, 0xF5E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|------|------|------|-------|-------|------|------| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 6 - PCIE Stop Condition Interrupt Enable bit | Value | Description | |-------|--------------------------------------------------| | 1 | Enables interrupt on detection of Stop condition | | 0 | Stop detection interrupts are disabled | #### Bit 5 - SCIE Start Condition Interrupt Enable bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Enables interrupt on detection of Start or Restart conditions | | 0 | Start detection interrupts are disabled | #### Bit 4 - BOEN Buffer Overwrite Enable bit | Value | Description | |-------|----------------------------------------------------------------------------------------------------| | 1 | I2CxRCV is updated and an ACK is generated for a received address/data byte, ignoring the state of | | | the I2COV bit only if RBF bit = 0 | | 0 | I2CxRCV is only updated when I2COV is clear | ## Bit 3 - SDAHT SDAx Hold Time Selection bit | Value | Description | |-------|--------------------------------------------------------------------| | 1 | Minimum of 300 ns hold time on SDAx after the falling edge of SCLx | | 0 | Minimum of 100 ns hold time on SDAx after the falling edge of SCLx | ## Bit 2 - SBCDE Client Mode Bus Collision Detect Enable bit If, on the rising edge of SCLx, SDAx is sampled low when the module is outputting a high state, the BCL bit is set and the bus goes Idle. This Detection mode is only valid during data and ACK transmit sequences. | Value | Description | |-------|----------------------------------------------| | 1 | Enables Client bus collision interrupts | | 0 | Client bus collision interrupts are disabled | #### Bit 1 - AHEN Address Hold Enable bit | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1 | Following the 8th falling edge of SCLx for a matching received address byte; SCLREL bit | | | (I2CxCONL[12]) will be cleared and the SCLx will be held low | | 0 | Address holding is disabled | #### Bit 0 - DHEN Data Hold Enable bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------------| | 1 | Following the 8th falling edge of SCLx for a received data byte; Client hardware clears the SCLREL bit | | | (I2CxCONL[12]) and SCLx is held low | | 0 | Data holding is disabled | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 722 Inter-Integrated Circuit (I2C) #### 18.5.3 I2Cx Status Register Name: I2CxSTAT **Offset:** 0x204, 0x220, 0xF60 Legend: C = Clearable bit; HS = Hardware Settable bit; HSC = Hardware Settable/Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|--------|--------|-------|-------|---------|--------|-------| | | ACKSTAT | TRSTAT | ACKTIM | | | BCL | GCSTAT | ADD10 | | Access | R/HSC | R/HSC | R/HSC | | | R/C/HSC | R/HSC | R/HSC | | Reset | 0 | 0 | 0 | | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | IWCOL | I2COV | D/A | Р | S | R/W | RBF | TBF | | Access | R/C/HS | R/C/HS | R/HSC | R/HSC | R/HSC | R/HSC | R/HSC | R/HSC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - ACKSTAT Acknowledge Status bit (updated in all Host and Client modes) | Val | ue | Description | |-----|----|------------------------------------------| | 1 | | Acknowledge was not received from Client | | 0 | | Acknowledge was received from Client | ## Bit 14 – TRSTAT Transmit Status bit (when operating as I<sup>2</sup>C Host; applicable to Host transmit operation) | Value | Description | |-------|-------------------------------------------------| | 1 | Host transmit is in progress (eight bits + ACK) | | 0 | Host transmit is not in progress | ## Bit 13 – ACKTIM Acknowledge Time Status bit (valid in I<sup>2</sup>C Client mode only) | 1 | Value | Description | |---|-------|-----------------------------------------------------------------------------------------------------| | | 1 | Indicates I <sup>2</sup> C bus is in an Acknowledge sequence, set on 8th falling edge of SCLx clock | | | 0 | Not an Acknowledge sequence, cleared on 9th rising edge of SCLx clock | #### Bit 10 - BCL Bus Collision Detect bit (Host/Client mode; cleared when I<sup>2</sup>C module is disabled, I2CEN = 0) | (110000011) | Those cheft mode, diedred when i e modale is disabled, 120E14 - 57 | | |-------------|------------------------------------------------------------------------------|--| | Value | Description | | | 1 | A bus collision has been detected during a Host or Client transmit operation | | | 0 | No bus collision has been detected | | #### Bit 9 - GCSTAT General Call Status bit (cleared after Stop detection) | V | alue | Description | |---|------|---------------------------------------| | 1 | | General call address was received | | 0 | | General call address was not received | #### Bit 8 - ADD10 10-Bit Address Status bit (cleared after Stop detection) | Value | Description | |-------|--------------------------------| | 1 | 10-bit address was matched | | 0 | 10-bit address was not matched | ### Bit 7 - IWCOL I2Cx Write Collision Detect bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------| | 1 | An attempt to write to the I2CxTRN register failed because the I <sup>2</sup> C module is busy; must be cleared in software | | 0 | No collision | #### Bit 6 - I2COV I2Cx Receive Overflow Flag bit **Inter-Integrated Circuit (I2C)** | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 1 | A byte was received while the I2CxRCV register is still holding the previous byte; I2COV is a "don't | | | care" in Transmit mode, must be cleared in software | | 0 | No overflow | #### Bit 5 – D/ $\overline{A}$ Data/ $\overline{Address}$ bit (when operating as I<sup>2</sup>C Client) | Value | Description | |-------|---------------------------------------------------------------------| | 1 | Indicates that the last byte received was data | | 0 | Indicates that the last byte received or transmitted was an address | #### Bit 4 - P I2Cx Stop bit Updated when Start, Reset or Stop is detected; cleared when the $I^2C$ module is disabled, I2CEN = 0. | Value | Description | |-------|--------------------------------------------------| | 1 | Indicates that a Stop bit has been detected last | | 0 | Stop bit was not detected last | #### Bit 3 - S I2Cx Start bit Updated when Start, Reset or Stop is detected; cleared when the $I^2C$ module is disabled, I2CEN = 0. | Value | Description | |-------|-----------------------------------------------------------------------| | 1 | Indicates that a Start (or Repeated Start) bit has been detected last | | 0 | Start bit was not detected last | ### Bit 2 – R/W Read/Write Information bit (when operating as I<sup>2</sup>C Client) | DIC | readitivite information by (whom operating do t o official) | |-------|-------------------------------------------------------------| | Value | Description | | 1 | Read: Indicates the data transfer is output from the Client | | 0 | Write: Indicates the data transfer is input to the Client | ### Bit 1 - RBF Receive Buffer Full Status bit | Value | Description | |-------|-------------------------------------------| | 1 | Receive is complete, I2CxRCV is full | | 0 | Receive is not complete, I2CxRCV is empty | ## Bit 0 - TBF Transmit Buffer Full Status bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Transmit is in progress, I2CxTRN is full (eight bits of data) | | 0 | Transmit is complete, I2CxTRN is empty | **Inter-Integrated Circuit (I2C)** # 18.5.4 I2Cx Client Mode Address Mask Register Name: I2CxMSK **Offset:** 0x20C, 0x228, 0xF68 Bits 9:0 - MSK[9:0] I2Cx Mask for Address Bit x Select bits | Value | Description | |-------|-------------------------------------------------------------------------------------------------------| | 1 | Enables masking for bit x of the incoming message address; bit match is not required in this position | | 0 | Disables masking for bit x; bit match is required in this position | # 19. Parallel Main Port (PMP) #### Notes: - This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Parallel Main Port (PMP)" (www.microchip.com/DS70005344) in the "dsPIC33/PIC24 Family Reference Manual". - 2. Not all device variants include the PMP. Refer to dsPIC33CK512MP608 Product Families for availability. The Parallel Main Port (PMP) is a parallel 8-bit/16-bit I/O module specifically designed to communicate with a wide variety of parallel devices, such as communication peripherals, LCDs, external memory devices and microcontrollers. Because the interfaces to parallel peripherals vary significantly, the PMP module is highly configurable. The key features of the PMP module include: - · Host and Client Operating modes - · Up to 16 Programmable Address Lines - Up to Two Chip Select Lines - · Programmable Strobe Options: - Individual read and write strobes or read/write strobe with enable strobe - · Address Auto-Increment/Auto-Decrement - · Programmable Address/Data Multiplexing - · Programmable Polarity on Control Signals - · Legacy Parallel Client Port Support - · Enhanced Parallel Client Support: - Address support - Four bytes deep, auto-incrementing buffer - Schmitt Trigger or TTL Input Buffers - Programmable Wait States - · Dual Buffer Mode with Separate Read and Write Registers - Read Initiate Control Figure 19-1. PMP Module Pinout and Connections to External Devices # 19.1 Parallel Main Port Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------|--------------|----------|-------------------------|------------------|--------|--------|-------------|----------|---------|--------| | 00440 | DMCON | 15:8 | ON | | SIDL | ADRMI | JX[1:0] | PMPTTL | PTWREN | PTRDEN | | 0x01A8 | PMCON | 7:0 | CSF | [1:0] | ALP | CS2P | CS1P | | WRSP | RDSP | | 0x01AA | PMCONH | 15:8 | | | | | | | | | | UXUTAA | PMICONH | 7:0 | RDSTART | | | | | | DUALBUF | | | 0x01AA | PMADDR | 15:8 | CS2/ADDR15 | CS1/ADDR14 | | | | R[13:0] | | | | OXOTAA | TWADDIX | 7:0 | | | | ADDR | [13:0] | | | | | 0x01AA | PMRADDR(2) | 15:8 | RCS2/<br>RADDR15 | RCS1/<br>RADDR14 | | | RADD | R[13:0] | | | | | | 7:0 | | | | RADDI | R[13:0] | | | | | 0x01AC | PMMODE | 15:8 | BUSY | IRQM | 1[1:0] | INCM | 1[1:0] | MODE16 | MOD | E[1:0] | | UXUTAC | PININIODE | 7:0 | WAIT | B[1:0] | | WAITI | M[3:0] | | WAIT | E[1:0] | | 0x01AE<br><br>0x01B3 | Reserved | | | | | | | | | | | 0x01B4 | PMDOUT1 | 15:8 | | | | DATAOL | JT[15:8] | | | | | 000104 | FINIDOUTT | 7:0 | | | | DATAO | | | | | | 0x01B6 | PMDOUT2 | 15:8 | | | | DATAOU | | | | | | OXOTEO | TWDOOTZ | 7:0 | | | | DATAOU | | | | | | 0x01B8 | PMDIN1 | 15:8 | | DATAIN[15:8] | | | | | | | | OXOTEO | T MOINT | 7:0 | | | | DATAI | | | | | | 0x01BA | PMDIN2 | 15:8 | | DATAIN[31:24] | | | | | | | | ONG IBIT | | 7:0 | | DATAIN[23:16] | | | | | | | | 0x01BC | | 15:8 | PTEN[15:14] PTEN[15:10] | | | | 30.000 -000 | | | | | | | 7:0 | | | PTEN | N[9:4] | | | PTEN | N[1:0] | | 0x01BE<br><br>0x01BF | Reserved | | | | | | | | | | | 0x01C0 | PMSTAT | 15:8 | IBF | IBOV | | | | IB[3:0]F | | | | UXUTCU | PIVISTAT | 7:0 | OBE | OBUF | | | | OB[ | 3:0]E | | | 0x01C2<br><br>0x01C3 | Reserved | | | | | | | | | | | 0x01C4 | PMWADDR(2) | 15:8 | WCS2/<br>WADDR15 | WCS1/<br>WADDR14 | | | WADD | R[13:0] | | | | | | 7:0 | | | | WADD | R[13:0] | | | | | 0x01C6<br><br>0x01CB | Reserved | | | | | | | | | | | 0x01CC | PMRDIN(1) | 15:8 | | | | RDATA | | | | | | UXUTCC | PINIKDIIN(1) | 7:0 | | | | RDATA | JN[7:0] | | | | ## 19.1.1 PMP Control Register Name: PMCON Offset: 0x1A8 #### Note: 1. These bits have no effect when their corresponding pins are used as address lines. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|--------|------|------|---------|--------|--------|--------| | | ON | | SIDL | ADRM | UX[1:0] | PMPTTL | PTWREN | PTRDEN | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CS | F[1:0] | ALP | CS2P | CS1P | | WRSP | RDSP | | Access | R/W | R/W | R/W | R/W | R/W | | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | #### Bit 15 - ON Parallel Main Port Enable bit | Value | Description | |-------|--------------------------------------------------| | 1 | PMP is enabled | | 0 | PMP is disabled, no off-chip access is performed | #### Bit 13 - SIDL PMP Stop in Idle Mode bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation when device enters Idle mode | #### Bits 12:11 - ADRMUX[1:0] Address/Data Multiplexing Selection bits | Value | Description | |-------|--------------------------------------------------------------------------------------------------------| | 11 | All 16 bits of address are multiplexed with the 16 bits of data (PMPA[15:0]/PMPD[15:0]) using two | | | phases | | 10 | All 16 bits of address are multiplexed with the lower 8 bits of data (PMPA[15:8]/PMPA[7:0]/ PMPD[7:0]) | | | using three phases | | 01 | Lower 8 bits of address are multiplexed with the lower 8 bits of data (PMPA[7:0]/PMPD[7:0]) | | 00 | Address and data appear on separate pins | #### Bit 10 - PMPTTL PMP Module TTL Input Buffer Select bit | Value | Description | |-------|-----------------------------------------------| | 1 | PMP module uses TTL input buffers | | 0 | PMP module uses Schmitt Trigger input buffers | #### Bit 9 - PTWREN PMP Write Strobe Port Enable bit | Value | Description | |-------|-----------------------------| | 1 | PMWR/PMENB port is enabled | | 0 | PMWR/PMENB port is disabled | ## Bit 8 - PTRDEN PMP Read/Write Strobe Port Enable bit | Value | Description | |-------|----------------------------| | 1 | PMRD/PMWR port is enabled | | 0 | PMRD/PMWR port is disabled | # Bits 7:6 - CSF[1:0] Chip Select Function bits(1) | Value | Description | |-------|-----------------------------------------| | 11 | Reserved | | 10 | PMCS2 and PMCS1 function as Chip Select | **Parallel Main Port (PMP)** | Value | Description | |-------|----------------------------------------------------------------| | 01 | PMCS2 functions as Chip Select, PMCS1 functions as address bit | | 00 | PMCS2 and PMCS1 function as address bits | #### Bit 5 - ALP Address Latch Polarity bit(1) | Value | Description | |-------|-------------------------------| | 1 | Active-high (PMALL and PMALH) | | 0 | Active-low (PMALL and PMALH) | #### Bit 4 - CS2P Chip Select 2 Polarity bit(1) | Value | Description | |-------|-------------| | 1 | Active-high | | 0 | Active-low | #### Bit 3 – CS1P Chip Select 1 Polarity bit<sup>(1)</sup> | Value | Description | |-------|-------------| | 1 | Active-high | | 0 | Active-low | #### Bit 1 - WRSP Write Strobe Polarity bit For Client Modes and Host Mode 2 (MODE[1:0] (PMMODE[9:8]) = 00, 01, 10): - 1 = Write strobe is active-high (PMWR) - 0 = Write strobe is active-low (PMWR) For Host Mode 1 (MODE[1:0] (PMMODE[9:8]) = 11): - 1 = Enables strobe active-high (PMENB) - 0 = Enables strobe active-low (PMENB) | Value | Description | |-------|----------------------------| | 1 | PMRD/PMWR port is enabled | | 0 | PMRD/PMWR port is disabled | #### Bit 0 - RDSP Read Strobe Polarity bit For Client Modes and Host Mode 2 (MODE[1:0] (PMMODE[9:8]) = 00, 01, 10): - 1 = Read strobe is active-high (PMRD) - 0 = Read strobe is active-low (PMRD) For Host Mode 1 (MODE[1:0] (PMMODE[9:8]) = 11): - 1 = Read/write strobe is active-high (PMRD/\overline{PMWR}) - 0 = Read/write strobe is active-low (PMRD/PMWR) | Value | Description | |-------|----------------------------| | 1 | PMRD/PMWR port is enabled | | 0 | PMRD/PMWR port is disabled | **Parallel Main Port (PMP)** # 19.1.2 PMP Control High Register Name: PMCONH Offset: 0x1AA #### Note: 1. This bit is cleared by HW at the end of the read cycle when BUSY (PMMODE[15]) = 0. Legend: HC = Hardware Clearable bit #### Bit 7 - RDSTART Start a Read on PMP Bus bit(1) | Value | Description | |-------|------------------------------------| | 1 | Starts a read cycle on the PMP bus | | 0 | No effect | #### Bit 1 - DUALBUF PMP Dual Read/Write Buffers Enable bit (valid in Host mode only) | Value | Description | |-------|--------------------------------------------------------------------------------------| | 1 | PMP uses separate registers for reads and writes (PMRADDR, PMDINx, PMWADDR, PMDOUTx) | | 0 | PMP uses legacy registers (PMADDR, PMDINx) | #### 19.1.3 PMP Mode Register Name: PMMODE Offset: 0x1AC #### Notes: - 1. When WAITM[3:0] = 0000, the WAITBx and WAITEx bits are ignored and forced to 1 $T_P$ (peripheral clock) cycle for a write operation; WAITBx = 1 $T_P$ cycle, WAITEx = 0 $T_P$ cycles for a read operation. - 2. Address bits, A15 and A14, are not subject to auto-increment/decrement if configured as Chip Selects, CS2 and CS1. - 3. These pins are active when MODE16 = 1 (16-bit mode). - 4. The PMADDR register is always incremented/decremented by one, regardless of the transfer data width. Legend: HC = Hardware Clearable bit; HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|--------|--------|------|--------|--------|------|--------| | | BUSY | IRQN | 1[1:0] | INCA | 1[1:0] | MODE16 | MOD | E[1:0] | | Access | R/HS/HC | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | WAIT | B[1:0] | | WAIT | M[3:0] | | WAIT | E[1:0] | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - BUSY Busy bit (Host mode only) | Value | Description | |-------|------------------| | 1 | Port is busy | | 0 | Port is not busy | #### Bits 14:13 - IRQM[1:0] Interrupt Request Mode bits | Value | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 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 | #### Bits 12:11 - INCM[1:0] Increment Mode bits | Value | Description | | | |-------|---------------------------------------------------------------------------------------|--|--| | 11 | Client mode read and write buffers auto-increment (MODE[1:0] (PMMODE[9:8]) = 00 only) | | | | 10 | Decrements ADDR[15:0] by one every read/write cycle <sup>(2,4)</sup> | | | | 01 | Increments ADDR[15:0] by one every read/write cycle <sup>(2,4)</sup> | | | | 00 | No increment or decrement of address | | | #### Bit 10 - MODE16 8/16-Bit Mode bit | Value | Description | |-------|------------------------------------------------------------------------------------| | 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 | #### Bits 9:8 - MODE[1:0] PMP Mode Select bits | Value | Description | |-------|--------------------------------------------------------------------------------------| | 11 | Host Mode 1 (PMCSx, PMRD, PMWR, PMENB, PMA[x:0], PMD[7:0], PMD[8:15]) <sup>(3)</sup> | | 10 | Host Mode 2 (PMCSx, PMRD, PMWR, PMA[x:0], PMD[7:0] and PMD[8:15]) <sup>(3)</sup> | | 01 | Enhanced Client mode, controls signals (PMRD, PMWR, PMCS, PMD[7:0] and PMA[1:0]) | | 00 | Legacy Parallel Client Port mode, controls signals (PMRD, PMWR, PMCS and PMD[7:0]) | **Parallel Main Port (PMP)** ## Bits 7:6 - WAITB[1:0] Data Setup to Read/Write Strobe Wait States bits(1) | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 11 | Data Wait of 4 T <sub>P</sub> ; multiplexed address phase of 4 T <sub>P</sub> | | 10 | Data Wait of 3 T <sub>P</sub> ; multiplexed address phase of 3 T <sub>P</sub> | | 01 | Data Wait of 2 T <sub>P</sub> ; multiplexed address phase of 2 T <sub>P</sub> | | 00 | Data Wait of 1 T <sub>P</sub> ; multiplexed address phase of 1 T <sub>P</sub> (default) | #### Bits 5:2 - WAITM[3:0] Data Read/Write Strobe Wait States bits(1) | | AND STATES AND | |-------|----------------------------------------------------| | Value | Description | | 1111 | Wait of 16 T <sub>P</sub> | | | | | 0001 | Wait of 2 T <sub>P</sub> | | 0000 | Wait of 1 T <sub>P</sub> (default) | ## Bits 1:0 - WAITE[1:0] Data Hold After Read/Write Strobe Wait States bits(1) - 11 = Wait of 4 T<sub>P</sub> - 10 = Wait of 3 T<sub>P</sub> - 01 = Wait of 2 T<sub>P</sub> - 00 = Wait of 1 Tp (default) #### For Read Operations: - 11 = Wait of 3 T<sub>P</sub> - $10 = Wait of 2 T_P$ - $01 = Wait of 1 T_P$ - 00 = Wait of 0 Tp (default) **Parallel Main Port (PMP)** # 19.1.4 PMP Address Register Name: PMADDR Offset: 0x1AA #### Note: 1. The use of these pins as PMA15/PMA14 or CS2/CS1 is selected by the CSF[1:0] bits (PMCON[7:6]). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|------------|-----|------|--------|--------|-----|-----| | | CS2/ADDR15 | CS1/ADDR14 | | | ADDR | [13:0] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | ADDF | [13:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 15 - CS2/ADDR15 Chip Select 2/Target Read Address bit 15(1) | Value | Description | |-------|---------------------------------------------------------| | 1 | Chip Select 2 is active | | 0 | Chip Select 2 is inactive (ADDR15 function is selected) | ## Bit 14 - CS1/ADDR14 Chip Select 1/Target Read Address bit 14(1) | Value | Description | |-------|---------------------------------------------------------| | 1 | Chip Select 1 is active | | 0 | Chip Select 1 is inactive (ADDR14 function is selected) | Bits 13:0 - ADDR[13:0] Target Read Address bits **Parallel Main Port (PMP)** # 19.1.5 PMP Data Output Low Register Name: PMDOUT1 Offset: 0x1B4 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|----------|-----|-----|-----| | | | | | DATAOL | JT[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DATAO | UT[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - DATAOUT[15:0] Output Data Port bits These bits are for 8-bit read operations in Client mode and write operations for Dual Buffer Host mode. Parallel Main Port (PMP) # 19.1.6 PMP Data Output High Register Name: PMDOUT2 Offset: 0x1B6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|-----------|-----|-----|-----| | | | | | DATAOL | JT[31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DATAOL | JT[23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 – DATAOUT[31:16] Output Data Port bits These bits are for 8-bit write operations in Client mode. **Parallel Main Port (PMP)** # 19.1.7 PMP Data Input/Output Low Register Name: PMDIN1 Offset: 0x1B8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|---------|-----|-----|-----| | | | | | DATAII | N[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DATAI | IN[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - DATAIN[15:0] Input/Output Data Port bits These bits are for 8-bit or 16-bit read/write operations in Host mode and are the input data port for 8-bit write operations in Client mode. Parallel Main Port (PMP) # 19.1.8 PMP Data Input/Output High Register Name: PMDIN2 Offset: 0x1BA | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|--------|----------|-----|-----|-----| | | | | | DATAIN | I[31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DATAIN | I[23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Bits 15:0 – DATAIN[31:16]** Input/Output Data Port bits These bits are for 8-bit write operations in Client mode. **Parallel Main Port (PMP)** ## 19.1.9 PMP Pin Enable Register Name: PMAEN Ox1BC #### Notes: - 1. The use of these pins as address or Chip Select lines 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. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------------------|---------|-----|-----|------|---------|--------|-----| | | PTEN | [15:14] | | | PTEN | [15:10] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PTEN[9:4] PTEN[1:0] | | | | | | V[1:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 15:14 - PTEN[15:14] PMCSx Strobe Enable bits | Value | Description | |-------|---------------------------------------------------------------------------------| | 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/Os | ## Bits 13:2 - PTEN[13:2] PMP Address Port Enable bits | Value | Description | |-------|-----------------------------------------| | 1 | PMA[13:2] function as PMP address lines | | 0 | PMA[13:2] function as port I/Os | ## Bits 1:0 - PTEN[1:0] PMALH/PMALL Strobe Enable bits | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | PMA1 and PMA0 function as either PMA[1:0] or PMALH and PMALL <sup>(2)</sup> | | 0 | PMA1 and PMA0 pads function as port I/Os | ## 19.1.10 PMP Status Register (Client Modes Only) Name: PMSTAT Offset: 0x1C0 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|------|----|----|----|------|-------|---| | | IBF | IBOV | | | | IB[3 | :0]F | | | Access | R | R/W | | | R | R | R | R | | Reset | 0 | 0 | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | OBE | OBUF | | | | OB[3 | 5:0]E | | | Access | R | R/W | | | R | R | R | R | | Reset | 1 | 0 | | | 1 | 1 | 1 | 1 | #### Bit 15 - IBF Input Buffer Full Status bit | Value | Description | |-------|--------------------------------------------------------------| | 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 This bit is set (= 1) in hardware; it can only be cleared (= 0) in software. | Value | Description | |-------|------------------------------------------------------------------------------------| | 1 | A write attempt to a full input byte buffer occurred (must be cleared in software) | | 0 | No overflow occurred | #### Bits 11:8 - IB[3:0]F Input Buffer x Status Full bits | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1 | Input buffer contains data that have 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 | Value | Description | |-------|--------------------------------------------------------------| | 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 This bit is set (= 1) in hardware; it can only be cleared (= 0) in software. | Value | Description | |-------|--------------------------------------------------------------------------------| | 1 | A read occurred from an empty output byte buffer (must be cleared in software) | | 0 | No underflow occurred | ## Bits 3:0 - OB[3:0]E Output Buffer x Status Empty bits | Value | Description | |-------|-------------------------------------------------------------------------| | 1 | Output buffer is empty (writing data to the buffer will clear this bit) | | 0 | Output buffer contains data that have not been transmitted | **Parallel Main Port (PMP)** ## 19.1.11 PMP Write Address Register Name: PMWADDR<sup>(2)</sup> Offset: 0x1C4 #### Notes: 1. The use of these pins as PMA15/PMA14 or WCS2/WCS1 is selected by the CSF[1:0] bits (PMCON[7:6]). 2. This register is only used when the DUALBUF bit (PMCONH[1]) is set to '1'. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|---------|---------|-----|-------------|-----|-----|-----|-----|--| | | WCS2/ | WCS1/ | | WADDR[13:0] | | | | | | | | WADDR15 | WADDR14 | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | WADDR[13:0] | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit 15 - WCS2/WADDR15 Chip Select 2 bit/Target Write Address bit 15<sup>(1)</sup> | Value | Description | |-------|----------------------------------------------------------| | 1 | Chip Select 2 is active | | 0 | Chip Select 2 is inactive (WADDR15 function is selected) | ## Bit 14 - WCS1/WADDR14 Chip Select 1 bit/Target Write Address bit 14<sup>(1)</sup> | Value | Description | |-------|----------------------------------------------------------| | 1 | Chip Select 1 is active | | 0 | Chip Select 1 is inactive (WADDR14 function is selected) | Bits 13:0 - WADDR[13:0] Target Write Address bits Parallel Main Port (PMP) ## 19.1.12 PMP Read Address Register Name: PMRADDR<sup>(2)</sup> Offset: 0x1AA #### Notes: 1. The use of these pins as PMA15/PMA14 or RCS2/RCS1 is selected by the CSF[1:0] bits (PMCON[7:6]). 2. This register is only used when the DUALBUF bit (PMCONH[1]) is set to '1'. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |-----------------|-------|-------|-----|-------------|-----|-----|-----|-----|--| | | RCS2/ | RCS1/ | | RADDR[13:0] | | | | | | | RADDR15 RADDR14 | | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RADDR[13:0] | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit 15 - RCS2/RADDR15 Chip Select 2/Target Read Address bit 15<sup>(1)</sup> | Value | Description | |-------|----------------------------------------------------------| | 1 | Chip Select 2 is active | | 0 | Chip Select 2 is inactive (RADDR15 function is selected) | ## Bit 14 - RCS1/RADDR14 Chip Select 1/Target Read Address bit 14<sup>(1)</sup> | Value | Description | |-------|----------------------------------------------------------| | 1 | Chip Select 1 is active | | 0 | Chip Select 1 is inactive (RADDR14 function is selected) | Bits 13:0 - RADDR[13:0] Target Read Address bits **Parallel Main Port (PMP)** # 19.1.13 PMP Read Input Data Register Name: PMRDIN<sup>(1)</sup> Offset: 0x1CC #### Notes: 1. This register is only used when the DUALBUF bit (PMCONH[1]) is set to '1' and exclusively for reads. If the DUALBUF bit is '0', the PMDIN1 register is used for reads instead of PMRDIN. 2. Only used when MODE16 = 1. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------------|-----|-----|-----|-----|-----|-----|-----| | | RDATAIN[15:8] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RDATAIN[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bits 15:0 - RDATAIN[15:0] Port Read Input Data bits(2) | Value | Description | |-------|------------------------------------| | 1 | Starts a read cycle on the PMP bus | | 0 | No effect | # 20. Single-Edge Nibble Transmission (SENT) **Note:** This data sheet summarizes the features of this group of dsPIC33CK512MP608 family devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Single-Edge Nibble Transmission (SENT) Module" (www.microchip.com/DS70005145) in the "dsPIC33/PIC24 Family Reference Manual". The Single-Edge Nibble Transmission (SENT) module is based on the SAE J2716, "SENT – Single-Edge Nibble Transmission for Automotive Applications". The SENT protocol is a one-way, single wire, time-modulated serial communication based on successive falling edges. It is intended for use in applications where high-resolution sensor data need to be communicated from a sensor to an Engine Control Unit (ECU). The SENTx module has the following major features: - · Selectable Transmit or Receive mode - Synchronous or Asynchronous Transmit modes - · Automatic Data Rate Synchronization - · Optional Automatic Detection of CRC Errors in Receive mode - Optional Hardware Calculation of CRC in Transmit mode - · Support for Optional Pause Pulse Period - · Data Buffering for One Message Frame - Selectable Data Length for Transmit/Receive, Up to Six Nibbles - · Automatic Detection of Framing Errors SENT protocol timing is based on a predetermined time unit, $T_{TICK}$ . Both the transmitter and receiver must be preconfigured for $T_{TICK}$ , which can vary from 3 to 90 $\mu$ s. A SENT message frame starts with a Sync pulse. The purpose of the Sync pulse is to allow the receiver to calculate the data rate of the message encoded by the transmitter. The SENT specification allows messages to be validated with up to a 20% variation in $T_{TICK}$ . This allows for the transmitter and receiver to run from different clocks that may be inaccurate, and drift with time and temperature. The data nibbles are four bits in length and are encoded as the data value + 12 ticks. This yields a 0 value of 12 ticks and the maximum value, 0xF, of 27 ticks. A SENT message consists of the following: - · A synchronization/calibration period of 56 tick times - A status nibble of 12-27 tick times - Up to six data nibbles of 12-27 tick times - A CRC nibble of 12-27 tick times - · An optional pause pulse period of 12-768 tick times Figure 20-1 shows a block diagram of the SENTx module. Figure 20-2 shows the construction of a typical 6-nibble data frame, with the numbers representing the minimum or maximum number of tick times for each section. Figure 20-1. SENTx Module Block Diagram Figure 20-2. SENTx Protocol Data Frames #### 20.1 Transmit Mode By default, the SENTx module is configured for transmit operation. The module can be configured for continuous asynchronous message frame transmission, or alternatively, for Synchronous mode triggered by software. When enabled, the transmitter will send a Sync, followed by the appropriate number of data nibbles, an optional CRC and optional pause pulse. The tick period used by the SENTx transmitter is set by writing a value to the TICKTIME[15:0] (SENTxCON2[15:0]) bits. The tick period calculations are shown in Equation 20-1. #### Equation 20-1. Tick Period Calculation $$TICKTIME[15:0] = \frac{TTICK}{TCLK} - 1$$ An optional pause pulse can be used in Asynchronous mode to provide a fixed message frame time period. The frame period used by the SENTx transmitter is set by writing a value to the FRAMETIME[15:0] (SENTxCON3[15:0]) bits. The formulas used to calculate the value of frame time are shown in Equation 20-2. Single-Edge Nibble Transmission (SENT) #### **Equation 20-2. Frame Time Calculations** FRAMETIME[15:0] = TTICK/TFRAME FRAMETIME[15:0] $\geq 122 + 27N$ FRAMETIME[15:0] $\geq 848 + 12N$ #### Where: TFRAME = Total time of the message from ms N = The number of data nibbles in message, 1-6 **Note:** The module will not produce a pause period with less than 12 ticks, regardless of the FRAMETIME[15:0] value. FRAMETIME[15:0] values beyond 2047 will have no effect on the length of a data frame. #### 20.1.1 Transmit Mode Configuration #### 20.1.1.1 Initializing the SENTx Module Perform the following steps to initialize the module: - 1. Write RCVEN (SENTxCON1[11]) = 0 for Transmit mode. - 2. Write TXM (SENTxCON1[10]) = 0 for Asynchronous Transmit mode or TXM = 1 for Synchronous mode. - 3. Write NIBCNT[2:0] (SENTxCON1[2:0]) for the desired data frame length. - 4. Write CRCEN (SENTxCON1[8]) for hardware or software CRC calculation. - 5. Write PPP (SENTxCON1[7]) for optional pause pulse. - 6. If PPP = 1, write TFRAME to SENTxCON3. - 7. Write SENTxCON2 with the appropriate value for the desired tick period. - 8. Enable interrupts and set interrupt priority. - 9. Write initial status and data values to SENTxDATH/L. - 10. If CRCEN = 0, calculate CRC and write the value to CRC[3:0] (SENTxDATL[3:0]). - 11. Set the SNTEN (SENTxCON1[15]) bit to enable the module. User software updates to SENTxDATH/L must be performed after the completion of the CRC and before the next message frame's status nibble. The recommended method is to use the message frame completion interrupt to trigger data writes. The data should be read from the SENTxDATL/H registers after the completion of the CRC and before the next message frame's status nibble. The recommended method is to use the message frame completion interrupt trigger. #### 20.2 Receive Mode The module can be configured for receive operation by setting the RCVEN (SENTxCON1[11]) bit. The time between each falling edge is compared to SYNCMIN[15:0] (SENTxCON3[15:0]) and SYNCMAX[15:0] (SENTxCON2[15:0]), and if the measured time lies between the minimum and maximum limits, the module begins to receive data. The validated Sync time is captured in the SENTxSYNC register and the tick time is calculated. Subsequent falling edges are verified to be within the valid data width and the data are stored in the SENTxDATL/H registers. An interrupt event is generated at the completion of the message and the user software should read the SENTx Data registers before the reception of the next nibble. The equation for SYNCMIN[15:0] and SYNCMAX[15:0] is shown in Equation 20-3. Single-Edge Nibble Transmission (SENT) #### Equation 20-3. SYNCMIN[15:0] and SYNCMAX[15:0] Calculations $TTICK = TCLK \bullet (TICKTIME[15:0] + 1)$ FRAMETIME[15:0] = TTICK/TFRAME $SyncCount = 8 \times FRCV \times TTICK$ $SYNCMIN[15:0] = 0.8 \times SyncCount$ $SYNCMAX[15:0] = 1.2 \times SyncCount$ $FRAMETIME[15:0] \ge 122 + 27N$ $FRAMETIME[15:0] \ge 848 + 12N$ #### Where: $\mathit{TFRAME}$ = Total time of the message from ms N = The number of data nibbles in message, 1-6 $\mathit{FRCV}$ = FCY x Prescaler $\mathit{TCLK}$ = FCY/Prescaler For $T_{TICK} = 3.0 \mu s$ and $F_{CLK} = 4 MHz$ , SYNCMIN[15:0] = 76. **Note:** To ensure a Sync period can be identified, the value written to SYNCMIN[15:0] must be less than the value written to SYNCMAX[15:0]. #### 20.2.1 Initializing the SENTx Module Perform the following steps to initialize the module: - 1. Write RCVEN (SENTxCON1[11]) = 1 for Receive mode. - 2. Write NIBCNT[2:0] (SENTxCON1[2:0]) for the desired data frame length. - 3. Write CRCEN (SENTxCON1[8]) for hardware or software CRC validation. - 4. Write PPP (SENTxCON1[7]) = 1 if pause pulse is present. - 5. Write SENTxCON2 with the value of SYNCMAXx (Nominal Sync Period + 20%). - 6. Write SENTxCON3 with the value of SYNCMINx (Nominal Sync Period 20%). - 7. Enable interrupts and set interrupt priority. - 8. Set the SNTEN (SENTxCON1[15]) bit to enable the module. The data should be read from the SENTxDATL/H registers after the completion of the CRC and before the next message frame's status nibble. The recommended method is to use the message frame completion interrupt trigger. # 20.3 SENT Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------|-------|----------|----|------------|--------|-------------|----------| | 000 | OFNITACONIA | 15:8 | SNTEN | | SNTSIDL | | RCVEN | TXM | TXPOL | CRCEN | | 08x0 | SENT1CON1 | 7:0 | PPP | SPCEN | | PS | | | NIBCNT[2:0] | | | 0x82 | | | | | | | | | | | | <br>0x83 | Reserved | | | | | | | | | | | 0x84 | SENT2CON1 | 15:8 | SNTEN | | SNTSIDL | | RCVEN | TXM | TXPOL | CRCEN | | NOTE OF STREET | SENTZOON | 7:0 | PPP | SPCEN | | PS | | | NIBCNT[2:0] | | | 0x86 | | | | | | | | | | | | 0x87 | Reserved | | | | | | | | | | | 0x88 | SENT3CON1 | 15:8 | SNTEN | | SNTSIDL | | RCVEN | TXM | TXPOL | CRCEN | | UXOO | SENTSCONT | 7:0 | PPP | SPCEN | | PS | | | NIBCNT[2:0] | | | A8x0 | | | | | | | | | | | | <br>0x8B | Reserved | | | | | | | | | | | 0x8C | SENT1STAT | 15:8 | | | | | | | | | | | SENTISTAL | 7:0 | PAUSE | | NIB[2:0] | | CRCERR | FRMERR | RXIDLE | SYNCTXEN | | 0x8E<br><br>0x93 | Reserved | | | | | | | | | | | | The state of s | 15:8 | | DATA | A4[3:0] | | | DATA | .5[3:0] | | | 0x94 | SENT1DATAL(1) | 7:0 | | | (6[3:0] | | | | [3:0] | | | 000 | OENITAD ATALL(4) | 15:8 | STAT[3:0] | | | | DATA1[3:0] | | | | | 0x96 | SENT1DATAH(1) | 7:0 | | DATA | (2[3:0] | | | DATA | 3[3:0] | | | 0x98<br><br>0xA3 | Reserved | | | | | | | | | | | 0xA4 | SENT2STAT | 15:8 | | | | | | | | | | UXA4 | SENTZSTAT | 7:0 | PAUSE | | NIB[2:0] | | CRCERR | FRMERR | RXIDLE | SYNCTXEN | | 0xA6 | | | | | | | | | | | | <br>0xAB | Reserved | | | | | | | | | | | 0xAC | SENT2DATAL(1) | 15:8 | | | 4[3:0] | | DATA5[3:0] | | | | | UXAC | SENTZUATAL(T) | 7:0 | | DATA | (6[3:0] | | | CRO | [3:0] | | | 0xAE | SENT2DATAH(1) | 15:8 | | STA | T[3:0] | | | | 1[3:0] | | | UXAE | OLIVIZDAIAII(I) | 7:0 | | DATA | (2[3:0] | | | DATA | 3[3:0] | | # **Single-Edge Nibble Transmission (SENT)** #### 20.3.1 SENTx Control Register 1 Name: SENTxCON1 Offset: 0x080, 0x084, 0x088 #### Notes: - 1. This bit has no function in Receive mode (RCVEN = 1). - 2. This bit has no function in Transmit mode (RCVEN = 0). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|---------|-----|-------|-----|-------------|-------| | | SNTEN | | SNTSIDL | | RCVEN | TXM | TXPOL | CRCEN | | Access | R/W | | R/W | | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PPP | SPCEN | | PS | | | NIBCNT[2:0] | | | Access | R/W | R/W | | R/W | | R/W | R/W | R/W | | Reset | 0 | 0 | | 0 | | 0 | 0 | 0 | #### Bit 15 - SNTEN SENTx Enable bit | Value | Description | |-------|-------------------| | 1 | SENTx is enabled | | 0 | SENTx is disabled | #### Bit 13 - SNTSIDL SENTx Stop in Idle Mode bit | Value | Description | |-------|----------------------------------------------------------------| | 1 | Discontinues module operation when the device enters Idle mode | | 0 | Continues module operation in Idle mode | #### Bit 11 - RCVEN SENTx Receive Enable bit | | to Lit of the total tota | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Description | | 1 | SENTx operates as a receiver | | 0 | SENTx operates as a transmitter (sensor) | ## Bit 10 - TXM SENTx Transmit Mode bit(1) | Value | Description | |-------|------------------------------------------------------------------------------| | 1 | SENTx transmits data frame only when triggered using the SYNCTXEN status bit | | 0 | SENTx transmits data frames continuously while SNTEN = 1 | #### Bit 9 - TXPOL SENTx Transmit Polarity bit(1) | Value | Description | |-------|-------------------------------------------------| | 1 | SENTx data output pin is low in the Idle state | | 0 | SENTx data output pin is high in the Idle state | #### Bit 8 - CRCEN CRC Enable bit #### Module in Receive Mode (RCVEN = 1): - $_{ m 1}$ = SENTx performs CRC verification on received data using the preferred J2716 method - 0 = SENTx does not perform CRC verification on received data # Module in Transmit Mode (RCVEN = 1): - 1 = SENTx automatically calculates CRC using the preferred J2716 method - 0 = SENTx does not calculate CRC #### Bit 7 - PPP Pause Pulse Present bit | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | SENTx is configured to transmit/receive SENT messages with pause pulse | | 0 | SENTx is configured to transmit/receive SENT messages without pause pulse | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 748 Single-Edge Nibble Transmission (SENT) ## Bit 6 - SPCEN Short PWM Code Enable bit(2) | Value | Description | |-------|----------------------------------------------| | 1 | SPC control from external source is enabled | | 0 | SPC control from external source is disabled | #### Bit 4 - PS SENTx Module Clock Prescaler (divider) bit | Value | Description | |-------|-------------| | 1 | Divide-by-4 | | 0 | Divide-by-1 | #### Bits 2:0 - NIBCNT[2:0] Nibble Count Control bits | Value | Description | |-------|--------------------------------------------------------------------| | 111 | Reserved; do not use | | 110 | Module transmits/receives six data nibbles in a SENT data pocket | | 101 | Module transmits/receives five data nibbles in a SENT data pocket | | 100 | Module transmits/receives four data nibbles in a SENT data pocket | | 011 | Module transmits/receives three data nibbles in a SENT data pocket | | 010 | Module transmits/receives two data nibbles in a SENT data pocket | | 001 | Module transmits/receives one data nibble in a SENT data pocket | | 000 | Reserved; do not use | #### 20.3.2 SENTx Status Register Name: SENTxSTAT Offset: 0x08C, 0x0A4 Note: Ac R 1. In Receive mode (RCVEN = 1), the SYNCTXEN bit is read-only. Legend: C = Clearable bit, HC = Hardware Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |-------|----|----|----|----|----|----|---|---|--| | | | | | | | | | | | | ccess | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PAUSE NIB[2:0] CRCERR FRMERR RXIDLE SYNCTXEN R R/C R/W/HC R R R Access R R 0 0 0 0 0 0 0 0 Reset #### Bit 7 - PAUSE Pause Period Status bit | Value | Description | |-------|---------------------------------------------------------| | 1 | The module is transmitting/receiving a pause period | | 0 | The module is not transmitting/receiving a pause period | #### Bits 6:4 - NIB[2:0] Nibble Status bits #### Module in Transmit Mode (RCVEN = 0): - 111 = Module is transmitting a CRC nibble - 110 = Module is transmitting Data Nibble 6 - 101 = Module is transmitting Data Nibble 5 - 100 = Module is transmitting Data Nibble 4 - 011 = Module is transmitting Data Nibble 3 - 010 = Module is transmitting Data Nibble 2 - 001 = Module is transmitting Data Nibble 1 - 000 = Module is transmitting a status nibble or pause period, or is not transmitting #### Module in Receive Mode (RCVEN = 1): - 111 = Module is receiving a CRC nibble or was receiving this nibble when an error occurred - 110 = Module is receiving Data Nibble 6 or was receiving this nibble when an error occurred - 101 = Module is receiving Data Nibble 5 or was receiving this nibble when an error occurred - 100 = Module is receiving Data Nibble 4 or was receiving this nibble when an error occurred - 011 = Module is receiving Data Nibble 3 or was receiving this nibble when an error occurred - 010 = Module is receiving Data Nibble 2 or was receiving this nibble when an error occurred - 001 = Module is receiving Data Nibble 1 or was receiving this nibble when an error occurred - 000 = Module is receiving a status nibble or waiting for Sync #### Bit 3 - CRCERR CRC Status bit (Receive mode only) | Value | Description | |-------|------------------------------------------------------------------| | 1 | A CRC error has occurred for the 1-6 data nibbles in SENTxDATL/H | | 0 | A CRC error has not occurred | ## Bit 2 - FRMERR Framing Error Status bit (Receive mode only) | Value | Description | | |-------|-------------------------------------------------------------------------------------------|--| | 1 | A data nibble was received with less than 12 tick periods or greater than 27 tick periods | | | 0 | Framing error has not occurred | | ## Bit 1 - RXIDLE SENTx Receiver Idle Status bit (Receive mode only) # Single-Edge Nibble Transmission (SENT) | Value | Description | |-------|----------------------------------------------------------------------------------| | 1 | The SENTx data bus has been Idle (high) for a period of SYNCMAX[15:0] or greater | | 0 | The SENTx data bus is not Idle | # **Bit 0 – SYNCTXEN** SENTx Synchronization Period Status/Transmit Enable bit<sup>(1)</sup> Module in Receive Mode (RCVEN = 1): - 1 = A valid synchronization period was detected; the module is receiving nibble data - 0 = No synchronization period has been detected; the module is not receiving nibble data Module in Asynchronous Transmit Mode (RCVEN = 0, TXM = 0): The bit always reads as '1' when the module is enabled, indicating the module transmits SENTx data frames continuously. The bit reads '0' when the module is disabled. Module in Synchronous Transmit Mode (RCVEN = 0, TXM = 1): - 1 = The module is transmitting a SENTx data frame - 0 = The module is not transmitting a data frame, user software may set SYNCTXEN to start another data frame transmission © 2021 Microchip Technology Inc. Datasheet 70005452B-page 751 Single-Edge Nibble Transmission (SENT) # 20.3.3 SENTx Receive Data Register Low Name: SENTxDATAL<sup>(1)</sup> Offset: 0x094, 0x0AC #### Note: 1. Register bits are read-only in Receive mode (RCVEN = 1). In Transmit mode, the CRC[3:0] bits are read-only when automatic CRC calculation is enabled (RCVEN = 0, CRCEN = 1). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----|------|--------|-----|------------|-----|-----|-----|--|--| | | | DATA | 4[3:0] | | DATA5[3:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DATA | 6[3:0] | | CRC[3:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:12 - DATA4[3:0] Data Nibble 4 Data bits Bits 11:8 - DATA5[3:0] Data Nibble 5 Data bits Bits 7:4 - DATA6[3:0] Data Nibble 6 Data bits Bits 3:0 - CRC[3:0] CRC Nibble Data bits Single-Edge Nibble Transmission (SENT) # 20.3.4 SENTx Receive Data Register High Name: SENTxDATAH<sup>(1)</sup> Offset: 0x096, 0x0AE #### Note: 1. Register bits are read-only in Receive mode (RCVEN = 1). In Transmit mode, the CRC[3:0] bits are read-only when automatic CRC calculation is enabled (RCVEN = 0, CRCEN = 1). | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----|------|--------|-----|------------|------|--------|-----|--|--| | | | STA | Γ[3:0] | | DATA1[3:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DATA | 2[3:0] | | | DATA | 3[3:0] | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:12 - STAT[3:0] Status Nibble Data bits Bits 11:8 - DATA1[3:0] Data Nibble 1 Data bits Bits 7:4 - DATA2[3:0] Data Nibble 2 Data bits Bits 3:0 - DATA3[3:0] Data Nibble 3 Data bits # 21. Timer1 #### Notes: - This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Timers" (www.microchip.com/DS70362) in the "dsPIC33/PIC24 Family Reference Manual", which is available from the Microchip website (www.microchip.com/). - Some registers and associated bits described in this section may not be available on all devices. Refer to Memory Organization in this data sheet for device-specific register and bit information. The Timer1 module is a 16-bit timer that can operate as a free-running interval timer/counter. The Timer1 module has the following unique features over other timers: - · Can be Operated in Asynchronous Counter mode - · Asynchronous Timer - · Operational during CPU Sleep mode - Software Selectable Prescalers 1:1, 1:8, 1:64 and 1:256 - External Clock Selection Control - The Timer1 External Clock Input (T1CK) can Optionally be Synchronized to the Internal Device Clock and the Clock Synchronization is Performed after the Prescaler If Timer1 is used for SCCP, the timer should be running in Synchronous mode. The Timer1 module can operate in one of the following modes: - Timer mode - Gated Timer mode - · Synchronous Counter mode - · Asynchronous Counter mode A block diagram of Timer1 is shown in Figure 21-1. Figure 21-1. 16-Bit Timer1 Module Block Diagram Timer1 # 21.1 Timer1 Control Register | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|----------|-------|---|------|---------|-------|-------|------|--------| | 0x0100 | T1CON | 15:8 | TON | | SIDL | TMWDIS | TMWIP | PRWIP | TECS | S[1:0] | | | | 7:0 | TGATE | | TCKP | 'S[1:0] | | TSYNC | TCS | | ## 21.1.1 Timer1 Control Register Name: T1CON Offset: 0x100 #### Note: 1. When Timer1 is enabled in External Synchronous Counter mode (TCS = 1, TSYNC = 1, TON = 1), any attempts by user software to write to the TMR1 register are ignored. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|----|------|--------|-------|-------|------|--------| | | TON | | SIDL | TMWDIS | TMWIP | PRWIP | TECS | S[1:0] | | Access | R/W | | R/W | R/W | R | R | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TGATE | | TCKP | S[1:0] | | TSYNC | TCS | | | Access | R/W | | R/W | R/W | | R/W | R/W | | | Reset | 0 | | 0 | 0 | | 0 | 0 | | # Bit 15 - TON Timer1 On bit(1) | Value | Description | |-------|----------------------| | 1 | Starts 16-bit Timer1 | | 0 | Stops 16-bit Timer1 | #### Bit 13 - SIDL Timer1 Stop in Idle Mode bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation in Idle mode | #### Bit 12 - TMWDIS Asynchronous Timer1 Write Disable bit | | Amirio de Programa de al maria a fina e locale de a | |-------|---------------------------------------------------------------------------------------------------------------| | Value | Description | | 1 | Timer writes are ignored while a posted write to TMR1 or PR1 is synchronized to the asynchronous clock domain | | 0 | Back-to-back writes are enabled in Asynchronous mode | #### Bit 11 - TMWIP Asynchronous Timer1 Write in Progress bit | Value | Description | |-------|-----------------------------------------------------| | 1 | Write to the timer in Asynchronous mode is pending | | 0 | Write to the timer in Asynchronous mode is complete | #### Bit 10 - PRWIP Asynchronous Period Write in Progress bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Write to the Period register in Asynchronous mode is pending | | 0 | Write to the Period register in Asynchronous mode is complete | #### Bits 9:8 - TECS[1:0] Timer1 Extended Clock Select bits | Value | Description | |-------|----------------------------------------| | 11 | FRC clock | | 10 | 2 T <sub>CY</sub> | | 01 | T <sub>CY</sub> | | 00 | External Clock comes from the T1CK pin | #### Bit 7 - TGATE Timer1 Gated Time Accumulation Enable bit When TCS = 1: This bit is ignored. When TCS = 0: Timer1 | Value | Description | |-------|-------------------------------------| | 1 | Gated time accumulation is enabled | | 0 | Gated time accumulation is disabled | #### Bits 5:4 - TCKPS[1:0] Timer1 Input Clock Prescale Select bits | Value | Description | |-------|-------------| | 11 | 1:256 | | 10 | 1:64 | | 01 | 1:8 | | 00 | 1:1 | #### Bit 2 - TSYNC Timer1 External Clock Input Synchronization Select bit(1) When TCS = 0: This bit is ignored. When TCS = 1: | Value | Description | |-------|-----------------------------------------------| | 1 | Synchronizes the External Clock input | | 0 | Does not synchronize the External Clock input | #### Bit 1 - TCS Timer1 Clock Source Select bit(1) | Value | Description | |-------|---------------------------------------------| | 1 | External Clock source selected by TECS[1:0] | | 0 | Internal peripheral clock (F <sub>P</sub> ) | ### 22. Capture/Compare/PWM/Timer Modules (SCCP) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Capture! Compare!PWM/Timer (MCCP and SCCP)" (www.microchip.com/DS30003035) in the "dsPIC33/PIC24 Family Reference Manual". dsPIC33CK512MP608 family devices include several Capture/Compare/PWM/Timer base modules, which provide the functionality of three different peripherals from earlier PIC24F devices. The module can operate in one of three major modes: - General Purpose Timer - · Input Capture - · Output Compare/PWM Single CCP output modules (SCCPs) provide only one PWM output. The SCCP module can be operated only in one of the three major modes at any time. The other modes are not available unless the module is reconfigured for the new mode. A conceptual block diagram for the module is shown in Figure 22-1. All three modes share a time base generator and a common Timer register pair (CCPxTMRH/L); other shared hardware components are added as a particular mode requires. Each module has a total of six control and status registers: - CCPxCON1L - CCPxCON1H - CCPxCON2L - CCPxCON2H - CCPxCON3H - CCPxSTATL Each module also includes eight buffer/counter registers that serve as Timer Value registers or data holding buffers: - CCPxTMRH/CCPxTMRL (CCPx Timer High/Low Counters) - CCPxPRH/CCPxPRL (CCPx Timer Period High/Low) - CCPxRA (CCPx Primary Output Compare Data Buffer) - CCPxRB (CCPx Secondary Output Compare Data Buffer) - CCPxBUFH/CCPxBUFL (CCPx Input Capture High/Low Buffers) Figure 22-1. SCCPx Conceptual Block Diagram #### 22.1 Time Base Generator The Timer Clock Generator (TCG) generates a clock for the module's internal time base, using one of the clock signals already available on the microcontroller. This is used as the time reference for the module in its three major modes. The internal time base is shown in Figure 22-2. There are eight inputs available to the clock generator, which are selected using the CLKSEL[2:0] bits (CCPxCON1L[10:8]). Available sources include the FRC, the Secondary Oscillator and the TCLKI External Clock inputs. The system clock is the default source (CLKSEL[2:0] = 000). Figure 22-2. Timer Clock Generator Note 1: Gating is available in Timer modes only. ### 22.2 General Purpose Timer Timer mode is selected when CCSEL = 0 and MOD[3:0] = 0000. The timer can function as a 32-bit timer or a dual 16-bit timer, depending on the setting of the T32 bit (Table 22-1). Table 22-1. Timer Operation Mode | T32 (CCPxCON1L[5]) | Operating Mode | |--------------------|--------------------------| | 0 | Dual Timer Mode (16-bit) | | 1 | Timer Mode (32-bit) | Dual 16-Bit Timer mode provides a simple timer function with two independent 16-bit timer/counters. The primary timer uses CCPxTMRL and CCPxPRL. Only the primary timer can interact with other modules on the device. It generates the SCCPx Sync out signals for use by other SCCP modules. It can also use the SYNC[4:0] bits' signal generated by other modules. The secondary timer uses CCPxTMRH and CCPxPRH. It is intended to be used only as a periodic interrupt source for scheduling CPU events. It does not generate an output Sync/trigger signal like the primary time base. In Dual Timer mode, the CCPx Secondary Timer Period register, CCPxPRH, generates the SCCP compare event (CCPxIF) used by many other modules on the device. The 32-Bit Timer mode uses the CCPxTMRL and CCPxTMRH registers, together, as a single 32-bit timer. When CCPxTMRL overflows, CCPxTMRH increments by one. This mode provides a simple timer function when it is important to track long time periods. Note that the T32 bit (CCPxCON1L[5]) should be set before the CCPxTMRL or CCPxPRH registers are written to initialize the 32-bit timer. #### 22.3 Output Compare Mode Output Compare mode compares the Timer register value with the value of one or two Compare registers, depending on its mode of operation. The Output Compare x module, on compare match events, has the ability to generate a single output transition or a train of output pulses. Like most PIC® MCU peripherals, the Output Compare x module can also generate interrupts on a compare match event. Table 22-2 shows the various modes available in Output Compare modes. Table 22-2. Output Compare x/PWMx Modes | MOD[3:0] (CCPxCON1L[3:0]) | T32 (CCPxCON1L[5]) | Operating Mode | | |---------------------------|--------------------|-------------------------------------|------------------| | 0001 | 0 | Output High on Compare (16-bit) | Single Edge Mode | | 0001 | 1 | Output High on Compare (32-bit) | | | 0010 | 0 | Output Low on Compare (16-bit) | | | 0010 | 1 | Output Low on Compare (32-bit) | | | 0011 | 0 | Output Toggle on Compare (16-bit) | | | 0011 | 1 | Output Toggle on Compare (32-bit) | | | 0100 | 0 | Dual Edge Compare (16-bit) | Dual Edge Mode | | 0101 | 0 | Dual Edge Compare (16-bit buffered) | PWM Mode | Figure 22-3. Output Compare x Block Diagram #### 22.4 Input Capture Mode Input Capture mode is used to capture a timer value from an independent timer base, upon an event, on an input pin or other internal trigger source. The input capture features are useful in applications requiring frequency (time period) and pulse measurement. Figure 22-4 depicts a simplified block diagram of Input Capture mode. Input Capture mode uses a dedicated 16/32-bit, synchronous, up counting timer for the capture function. The timer value is written to the FIFO when a capture event occurs. The internal value may be read (with a synchronization delay) using the CCPxTMRH/L registers. To use Input Capture mode, the CCSEL bit (CCPxCON1L[4]) must be set. The T32 and the MOD[3:0] bits are used to select the proper Capture mode, as shown in Table 22-3. Table 22-3. Input Capture x Modes | MOD[3:0] (CCPxCON1L[3:0]) | T32 (CCPxCON1L[5]) | Operating Mode | |---------------------------|--------------------|--------------------------------| | 0000 | 0 | Edge Detect (16-bit capture) | | 0000 | 1 | Edge Detect (32-bit capture) | | 0001 | 0 | Every Rising (16-bit capture) | | 0001 | 1 | Every Rising (32-bit capture) | | 0010 | 0 | Every Falling (16-bit capture) | | continued | | | | | | | | | | |---------------------------|--------------------|---------------------------------------|--|--|--|--|--|--|--| | MOD[3:0] (CCPxCON1L[3:0]) | T32 (CCPxCON1L[5]) | Operating Mode | | | | | | | | | 0010 | 1 | Every Falling (32-bit capture) | | | | | | | | | 0011 | 0 | Every Rising/Falling (16-bit capture) | | | | | | | | | 0011 | 1 | Every Rising/Falling (32-bit capture) | | | | | | | | | 0100 | 0 | Every 4th Rising (16-bit capture) | | | | | | | | | 0100 | 1 | Every 4th Rising (32-bit capture) | | | | | | | | | 0101 | 0 | Every 16th Rising (16-bit capture) | | | | | | | | | 0101 | 1 | Every 16th Rising (32-bit capture) | | | | | | | | Figure 22-4. Input Capture x Block Diagram ### 22.5 Auxiliary Output The SCCPx modules have an auxiliary (secondary) output that provides other peripherals access to internal module signals. The auxiliary output is intended to connect to other SCCP modules, or other digital peripherals, to provide these types of functions: - · Time Base Synchronization - · Peripheral Trigger and Clock Inputs - · Signal Gating The type of output signal is selected using the AUXOUT[1:0] control bits (CCPxCON2H[4:3]). The type of output signal is also dependent on the module operating mode. Table 22-4. Auxiliary Output | AUXOUT[1:0] | CCSEL | MOD[3:0] | Comments | Signal Description | |-------------|-------|----------|---------------------------|-------------------------------------| | 00 | x | xxxx | Auxiliary output disabled | No Output | | 01 | 0 | 0000 | Time Base modes | Time Base Period Reset or Rollover | | 10 | | | | Special Event Trigger Output | | 11 | | | | No Output | | 01 | 0 | 0001 | Output Compare modes | Time Base Period Reset or Rollover | | 10 | | through | | Output Compare Event Signal | | 11 | | 1111 | | Output Compare Signal | | 01 | 1 | xxxx | Input Capture modes | Time Base Period Reset or Rollover | | 10 | | | | Reflects the Value of the ICDIS bit | | 11 | | | | Input Capture Event Signal | ## 22.6 SCCP Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|---------|------------|--------|----------|-----------|-------------|----------|--| | 0x0950 | CCP1CON1L | 15:8 | CCPON | | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | | 0x0950 | CCPTCONTE | 7:0 | TMRF | PS[1:0] | T32 | CCSEL | | | D[3:0] | | | | 0x0952 | CCP1CON1H | 15:8 | OPSSRC | RTRGEN | | | | OPS3[3:0] | | | | | 0x0952 | CCFICONIA | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | | SYNC[4:0] | | | | | 0x0954 | CCP1CON2L | 15:8 | PWMRSEN | ASDGM | | SSDG | | | | | | | 080954 | CCFTCONZL | 7:0 | | | | ASD | G[7:0] | | | | | | 0x0956 | CCP1CON2H | 15:8 | OENSYNC | | | | | | | OCAEN | | | 0,0000 | OUT TOURSTT | 7:0 | ICGS | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | | | | 0x0958 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0959 | | | | | | | | | | | | | 0x095A | CCP1CON3H | 15:8 | OETRIG | | OSCNT[2:0] | | | | | | | | | | 7:0 | | | POLACE | | PSSAC | CE[1:0] | PSSBI | DF[1:0] | | | 0x095C | CCP1STATL | 15:8 | | | | | | | | | | | | sans mercana | 7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | 0x095E | | | | | | | | | | | | | 0x095F | Reserved | | | | | | | | | | | | 00000 | CODATMOL | 15:8 | | , | , | TMRL | _[15:8] | , | | | | | 0x0960 | CCP1TMRL | 7:0 | | | | TMR | MRL[7:0] | | | | | | 0,,0000 | CCD4TMDU | 15:8 | | | | TMRH | [31:24] | | | | | | 0x0962 | CCP1TMRH | 7:0 | | | | TMRH | H[23:16] | | | | | | 0,00064 | CCD4DDI | 15:8 | | | | PRL | [15:8] | | | | | | 0x0964 | CCP1PRL | 7:0 | | | | PRL | .[7:0] | | | | | | 00000 | OOD4DDU | 15:8 | PRH[31:24] | | | | | | | | | | 0x0966 | CCP1PRH | 7:0 | | | | | 23:16] | | | | | | 00000 | 000404 | 15:8 | | | | CMP | [15:8] | | | | | | 0x0968 | CCP1RA | 7:0 | | | | CMF | P[7:0] | | | | | | 0x096A | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x096B | | | | | | | | | | | | | 0x096C | CCP1RB | 15:8 | | | | CMP | [15:8] | | | | | | Охоооо | OOI III | 7:0 | | | | CMF | P[7:0] | | | | | | 0x096E | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x096F | | | | | | | | | | | | | 0x0970 | CCP1BUFL | 15:8 | | | | | [15:8] | | | | | | 100 april ap | | 7:0 | | | | | [7:0] | | | | | | 0x0972 | CCP1BUFH | 15:8 | | | | | 31:24] | | | | | | | ASSESSED TO SERVICE STORY | 7:0 | | | | | 23:16] | 1 | | | | | 0x0974 | CCP2CON1L | 15:8 | CCPON | 2014.03 | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | | | | 7:0 | | PS[1:0] | T32 | CCSEL | | MOE | 0[3:0] | | | | 0x0974 | CCP2CON2L | 15:8 | PWMRSEN | ASDGM | | SSDG | 017.01 | | | | | | | - Control of the Cont | 7:0 | 000 | | | ASD | G[7:0] | | ara ar | | | | 0x0976 | CCP2CON1H | 15:8 | OPSSRC | RTRGEN | ALTOVALO | | | | 3[3:0] | | | | | | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | | SYNC[4:0] | | 001511 | | | 0x0976 | CCP2CON2H | 15:8 | OENSYNC | 1414 01 | | | LITT 01 | | 10012 21 | OCAEN | | | | the fact artifacts progress of | 7:0 | ICGS | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | | | | 0x0978 | Deers | | | | | | | | | | | | 0x097D | Reserved | | | | | | | | | | | | 0,0010 | | 15:8 | OETRIG | | OSCNT[2:0] | | | | | | | | 0x097E | CCP2CON3H | 7:0 | OLING | | POLACE | | PSSAC | E[1:0] | Deedi | DF[1:0] | | | | | 15:8 | | | TOLAGE | | FOGAC | J_[1.0] | FOODL | J. [1.0] | | | 0x0980 | CCP2STATL | 7:0 | CCPTRIC | TRSET | TROLD | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | | | 7.0 | COLIKIC | IRSEI | TRCLR | ASEVT | SUEVI | ICDIS | 1000 | ICRINE | | | conti | inued | | | | | | | | | | | |----------------|------------------------------------------|-------------|------------|-----------------------|----------------------|---------|---------|-----------|-------------|----------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Ivalile | BILFUS. | , | • | | | | | <u>'</u> | | | | 0x0982 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0983 | | 45.0 | | | | TMD | | | | | | | 0x0984 | CCP2TMRL | 15:8 | | | | | [15:8] | | | | | | | | 7:0 | | | | | L[7:0] | | | | | | 0x0986 | CCP2TMRH | 15:8<br>7:0 | | TMRH[31:24] | | | | | | | | | | | 15:8 | | TMRH[23:16] | | | | | | | | | 0x0988 | CCP2PRL | 7:0 | | PRL[15:8]<br>PRL[7:0] | | | | | | | | | | | 15:8 | | | | PRH[: | | | | | | | 0x098A | CCP2PRH | 7:0 | | | | PRH[: | | | | | | | | | 15:8 | | | | СМР | | | | | | | 0x098C | CCP2RA | 7:0 | | | | | P[7:0] | | | | | | 0x098E | | 7.0 | | | | CIVIE | [7.0] | | | | | | | Reserved | | | | | | | | | | | | 0x098F | 1,0001704 | | | | | | | | | | | | | and the second second | 15:8 | | | | CMP | [15:8] | | | | | | 0x0990 | CCP2RB | 7:0 | | | | | P[7:0] | | | | | | 0x0992 | | | | | | | | | | | | | *** | Reserved | | | | | | | | | | | | 0x0993 | | | | | | | | | | | | | 0x0994 | CCP2BUFL | 15:8 | | | | BUF | [15:8] | | | | | | 000004 | COLZDOLE | 7:0 | | | | | [7:0] | | | | | | 0x0996 | CCP2BUFH | 15:8 | BUF[31:24] | | | | | | | | | | 0,0990 | CCF2B0111 | 7:0 | | | | | 23:16] | | | | | | 0x0998 | CCP3CON1L | 15:8 | CCPON | | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | | OXOCCO | 001 0001112 | 7:0 | TMRF | | T32 | CCSEL | | | D[3:0] | | | | 0x099A | CCP3CON1H | 15:8 | OPSSRC | RTRGEN | | | | | 3[3:0] | | | | OXOGOT | 001 00011111 | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | | SYNC[4:0] | | | | | 0x099C | CCP3CON2L | 15:8 | PWMRSEN | ASDGM | | SSDG | | | | | | | | | 7:0 | | | | ASD | G[7:0] | | | | | | 0x099E | CCP3CON2H | 15:8 | OENSYNC | | | | | | | OCAEN | | | | , | 7:0 | ICGS | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | | | | 0x09A0 | | | | | | | | | | | | | 0x09A1 | Reserved | | | | | | | | | | | | UXU9AT | | 15.0 | OETRIG | | OCCNITIO:01 | | | | | | | | 0x09A2 | CCP3CON3H | 15:8<br>7:0 | OETRIG | | OSCNT[2:0]<br>POLACE | | Deev | CE[1:0] | Deedi | DF[1:0] | | | | | 15:8 | | | FULACE | | POOA | JL[1.0] | POSBI | J. [1.0] | | | 0x09A4 | CCP3STATL | 7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | 0x09A6 | | 7.0 | JOI TING | TAULT | INOLIN | , OLV I | SOLVI | 10010 | 1000 | IODIAL | | | | Reserved | | | | | | | | | | | | 0x09A7 | 110001104 | | | | | | | | | | | | | (1) (***) (1) (************************* | 15:8 | | | | TMRL | .[15:8] | | | | | | 0x09A8 | CCP3TMRL | 7:0 | | | | | L[7:0] | | | | | | 100 O 10 W 100 | AS DECEMBER AND A | 15:8 | | | | | [31:24] | | | | | | 0x09AA | CCP3TMRH | 7:0 | | | | | [23:16] | | | | | | | 000000 | 15:8 | | | | | 15:8] | | | | | | 0x09AC | CCP3PRL | 7:0 | | | | | [7:0] | | | | | | 0.0015 | 0.00000011 | 15:8 | | | | | 31:24] | | | | | | 0x09AE | CCP3PRH | 7:0 | | | | | 23:16] | | | | | | 0,400,00 | CCP2P4 | 15:8 | | | | | [15:8] | | | | | | 0x09B0 | CCP3RA | 7:0 | | | | | P[7:0] | | | | | | 0x09B2 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x09B3 | | | | | | | | | | | | | 0x09B4 | CCP3RB | 15:8 | | | | | [15:8] | | | | | | 0,000 | COLOND | 7:0 | | | | CMF | [/:0] | | | | | | | | | Sim [rio] | | | | | | | | | | contin | nued | | | | | | | | | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------|------------------|----------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------|---------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | J 33. | · | | , | | | | | _ | | | 0x09B6 | Reserved | | | | | | | | | | | | 0x09B7 | Neserveu | | | | | | | | | | | | | | 15:8 | | BUF[15:8] | | | | | | | | | 0x09B8 | CCP3BUFL | 7:0 | | BUF[7:0] | | | | | | | | | | | 15:8 | | | | | 31:24] | | | | | | 0x09BA | CCP3BUFH | 7:0 | | | | | 23:16] | | | | | | | Control of the Contro | 15:8 | CCPON | | | | | | | | | | 0x09BC | CCP4CON1L | 7:0 | TMRP | S[1:0] | T32 | CCSEL | | MOI | D[3:0] | | | | | Segressian | 15:8 | OPSSRC | RTRGEN | 3 th (3874) 37 | 100000000000000000000000000000000000000 | | | 3[3:0] | | | | 0x09BE | CCP4CON1H | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | I. | SYNC[4:0] | | | | | | | 15:8 | PWMRSEN | | | | | | | | | | 0x09C0 | CCP4CON2L | 7:0 | A. 0.0000 9-0000 | SOMEONE SERVE | | 200, 00000 000 | G[7:0] | | J. | I | | | DETTERMINE WINDS | Title Month of a titles 1975 Title 201 | 15:8 | OENSYNC | | | | | | | OCAEN | | | 0x09C2 | CCP4CON2H | 7:0 | ICGSI | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | | | | 0x09C4 | | 742 TA | 200 500 500 | 20 - 10 10 0 - 1 | | × 80 145 | | | | | | | | Reserved | | | | | | | | | | | | 0x09C5 | | | | | | | | | | | | | 00000 | 000400101 | 15:8 | OETRIG | | OSCNT[2:0] | | | | | | | | 0x09C6 | CCP4CON3H | 7:0 | | | POLACE | | PSSAC | DE[1:0] | PSSBI | DF[1:0] | | | 0,0000 | CODACTATI | 15:8 | | | | | | | | | | | 0x09C8 | CCP4STATL | 7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | 0x09CA | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x09CB | | | | | | | | | | | | | 0x09CC | CCP4TMRL | 15:8 | | | | | _[15:8] | | | | | | 0.00000 | COPATIVINE | 7:0 | | | | TMR | L[7:0] | | | | | | 0x09CE | CCP4TMRH | 15:8 | | | | TMRH | [31:24] | | | | | | UXUSCE | CCF41WKH | 7:0 | | | | TMRH | [23:16] | | | | | | 0x09D0 | CCP4PRL | 15:8 | | | | | [15:8] | | | | | | OXOODO | 001 11 112 | 7:0 | | | | | [7:0] | | | | | | 0x09D2 | CCP4PRH | 15:8 | | | | | 31:24] | | | | | | UNUUD L | | 7:0 | | | | | 23:16] | | | | | | 0x09D4 | CCP4RA | 15:8 | | | | | [15:8] | | | | | | | | 7:0 | | | | CMF | P[7:0] | | 1 | | | | 0x09D6 | | | | | | | | | | | | | <br>000D7 | Reserved | | | | | | | | | | | | 0x09D7 | | 45.0 | | | | OMD | [45.0] | | | | | | 0x09D8 | CCP4RB | 15:8 | | | | | [15:8] | | | | | | 0x09DA | | 7:0 | | | | CIVIE | P[7:0] | | | | | | | Reserved | | | | | | | | | | | | 0x09DB | Reserved | | | | | | | | | | | | | Congress to a contract | 15:8 | | | | BUF | [15:8] | | | | | | 0x09DC | CCP4BUFL | 7:0 | | | | | [7:0] | | | | | | | Control of the Control | 15:8 | | | | | 31:24] | | | | | | 0x09DE | CCP4BUFH | 7:0 | | | | | 23:16] | | | | | | 0.0055 | 000500:::: | 15:8 | CCPON | | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | | 0x09E0 | CCP5CON1L | 7:0 | TMRP | S[1:0] | T32 | CCSEL | A STATE OF THE STA | MOI | D[3:0] | | | | 0.00=0 | 000505000 | 15:8 | OPSSRC | RTRGEN | | | | | 3[3:0] | | | | 0x09E2 | CCP5CON1H | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | 1 | SYNC[4:0] | | | | | 0.00=: | CODECCUS | 15:8 | PWMRSEN | ASDGM | | SSDG | | • | | | | | 0x09E4 | CCP5CON2L | 7:0 | | | | | G[7:0] | | 1 | | | | 0.0055 | 000500::::: | 15:8 | OENSYNC | | | | | | | OCAEN | | | 0x09E6 | CCP5CON2H | 7:0 | ICGSI | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | | | | | | 10000 | | | | 1 No. 6 To 1 April 10 | - | | | | | | 0x09E8 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | conti | nued | | | | | | | | | | | |-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------|--------------------|------------------|-------------|---------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0x09EA | CCP5CON3H | 15:8<br>7:0 | OETRIG | | OSCNT[2:0] POLACE | | PSSAG | DE[1:0] | PSSBI | DF[1:0] | | | 0x09EC | CCP5STATL | 15:8<br>7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | 0x09EE | Reserved | | | | | | | 1900 000 0000000 | | | | | 0x09EF | reconved | 45.0 | | | | T140 | | | | | | | 0x09F0 | CCP5TMRL | 15:8<br>7:0 | | TMRL[15:8] TMRL[7:0] | | | | | | | | | 0x09F2 | CCP5TMRH | 15:8<br>7:0 | | | | TMRH<br>TMRH | | | | | | | 0x09F4 | CCP5PRL | 15:8<br>7:0 | | | | PRL[<br>PRL | [15:8]<br>[7:0] | | | | | | 0x09F6 | CCP5PRH | 15:8 | | | | PRH[ | 31:24] | | | | | | | | 7:0<br>15:8 | | | | PRH[: | | | | | | | 0x09F8 | CCP5RA | 7:0 | | | | | P[7:0] | | | | | | 0x09FA<br><br>0x09FB | Reserved | | | | | | | | | | | | 0x09FC | CCP5RB | 15:8<br>7:0 | | CMP[15:8]<br>CMP[7:0] | | | | | | | | | 0x09FE<br><br>0x09FF | Reserved | | | | | | [] | | | | | | 0x0A00 | CCP5BUFL | 15:8<br>7:0 | | BUF[15:8]<br>BUF[7:0] | | | | | | | | | 0x0A02 | CCP5BUFH | 15:8 | | | | BUF[ | 31:24] | | | | | | 000700000000000000000000000000000000000 | Sacrificación de constituido cons | 7:0 | CODON | | CODOIDI | | 23:16] | CLKSELID:01 | | | | | 0x0A04 | CCP6CON1L | 15:8<br>7:0 | | CCPON CCPSIDL CCPSLP TMRSYNC CLKSEL[2 TMRPS[1:0] T32 CCSEL MOD[3:0] | | | | | CLKSEL[2:0] | | | | | | 15:8 | OPSSRC | RTRGEN | 102 | OGGEE | | | 3[3:0] | | | | 0x0A06 | CCP6CON1H | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | | SYNC[4:0] | 0[0.0] | | | | 00400 | OODGOONGI | 15:8 | PWMRSEN | ASDGM | | SSDG | | | | | | | 80A0x0 | CCP6CON2L | 7:0 | | | | ASD | 3[7:0] | | , | | | | 0x0A0A | CCP6CON2H | 15:8<br>7:0 | OENSYNC<br>ICGSI | M[1:0] | | AUXO | JT[1:0] | | ICS[2:0] | OCAEN | | | 0x0A0C | Reserved | 1.5 | 1000 | [1.0] | | 7,67,6 | 7 [1.0] | | ioo[E.o] | | | | 0x0A0D | Neserveu | | | | | | | | | | | | 0x0A0E | CCP6CON3H | 15:8<br>7:0 | OETRIG | | OSCNT[2:0] POLACE | | PSSAC | DE[1:0] | PSSBI | DF[1:0] | | | 0x0A10 | CCP6STATL | 15:8<br>7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | 0x0A12<br><br>0x0A13 | Reserved | | | | | | | | | | | | | CODOTAD | 15:8 | | | | TMRL | .[15:8] | | | | | | 0x0A14 | 14 CCP6TMRL 7:0 TMRL[7:0] | | | | | | | | | | | | 0x0A16 | CCP6TMRH | 15:8<br>7:0 | | | | TMRH<br>TMRH | [31:24]<br>[23:16] | | | | | | 0x0A18 | CCP6PRL | 15:8<br>7:0 | | | | PRL[ | [15:8]<br>[7:0] | | | | | | 0x0A1A | CCP6PRH | 15:8 | | | | PRH[ | 31:24] | | | | | | 0x0A1C | CCP6RA | 7:0<br>15:8 | | | | CMP | 23:16]<br>[15:8] | | | | | | CAUATIO | | 7:0 | | | | CMF | P[7:0] | | | | | | conti | nued | | | | | | | | | | | |------------|----------------------|-------------|---------|--------------------------|----------------------------|---------------|---------|-----------|-------------|---------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0x0A1E | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0A1F | | | | | | | | | | | | | 0x0A20 | CCP6RB | 15:8 | | | | CMP | | | | | | | | 001 0115 | 7:0 | | | | CMF | P[7:0] | | | | | | 0x0A22 | - | | | | | | | | | | | | <br>0x0A23 | Reserved | | | | | | | | | | | | UXUAZS | | 15:8 | | | | BLIF | [15:8] | | | | | | 0x0A24 | CCP6BUFL | 7:0 | | | | BUF | - | | | | | | | | 15:8 | | | | | 31:24] | | | | | | 0x0A26 | CCP6BUFH | 7:0 | | | | BUF[ | | | | | | | | 120222000 | 15:8 | CCPON | | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | | 0x0A28 | CCP7CON1L | 7:0 | TMRF | PS[1:0] | T32 | CCSEL | | MOE | 0[3:0] | | | | 00404 | OOD7OONALI | 15:8 | OPSSRC | RTRGEN | | | | | 3[3:0] | | | | 0x0A2A | CCP7CON1H | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | | SYNC[4:0] | | | | | 0x0A2C | CCP7CON2L | 15:8 | PWMRSEN | ASDGM | | SSDG | | | | | | | 370/120 | OCI TOOINEE | 7:0 | | | | ASD | G[7:0] | | | | | | 0x0A2E | CCP7CON2H | 15:8 | OENSYNC | | | | | | | OCAEN | | | | CSOSILIOS ISSOSSILIA | 7:0 | ICGS | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | | | | 0x0A30 | Doggrad | | | | | | | | | | | | 0x0A31 | Reserved | | | | | | | | | | | | UNUAST | | 15:8 | OETRIG | | OSCNT[2:0] | | | | | | | | 0x0A32 | CCP7CON3H | 7:0 | OETHIO | | POLACE | | PSSAC | DE[1:0] | PSSBI | DF[1:0] | | | | | 15:8 | | | | | | . , | | į. | | | 0x0A34 | CCP7STATL | 7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | 0x0A36 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0A37 | | | | | | | | | | | | | 0x0A38 | CCP7TMRL | 15:8 | | | | TMRL | | | | | | | | | 7:0 | | | | TMR | | | | | | | 0x0A3A | CCP7TMRH | 15:8 | | | TMRH[31:24]<br>TMRH[23:16] | | | | | | | | | | 7:0<br>15:8 | | | | PRL | | | | | | | 0x0A3C | CCP7PRL | 7:0 | | | | PRL | | | | | | | | Brown St. | 15:8 | | | | | | | | | | | 0x0A3E | CCP7PRH | 7:0 | | PRH[31:24]<br>PRH[23:16] | | | | | | | | | 00440 | 000704 | 15:8 | | | | CMP | | | | | | | 0x0A40 | CCP7RA | 7:0 | | | | CMF | [7:0] | | | | | | 0x0A42 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0A43 | | 45.0 | | | | 01.15 | [45.0] | | | | | | 0x0A44 | CCP7RB | 15:8 | | | | | [15:8] | | | | | | 0x0A46 | | 7:0 | | | | CMF | P[7:0] | | | | | | | Reserved | | | | | | | | | | | | 0x0A47 | recoured | | | | | | | | | | | | | CODZDUE | 15:8 | | | | BUF | [15:8] | | | | | | 0x0A48 | CCP7BUFL | 7:0 | | | | | [7:0] | | | | | | 0×0 4 4 4 | CCP7BUFH | 15:8 | | | | | 31:24] | | | | | | 0x0A4A | CCP/BUFH | 7:0 | | | | BUF[ | | | | | | | 0x0A4C | CCP8CON1L | 15:8 | CCPON | | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | | 3,0,140 | COLOGONIE | 7:0 | TMRF | | T32 | CCSEL | | | 0[3:0] | | | | 0x0A4E | CCP8CON1H | 15:8 | OPSSRC | RTRGEN | | | | | 3[3:0] | | | | V.I | | 7:0 | TRIGEN | ONESHOT | ALTSYNC | - 1- 1-20 BL9 | | SYNC[4:0] | | | | | 0x0A50 | CCP8CON2L | 15:8 | PWMRSEN | ASDGM | | SSDG | 21 (-01 | | | | | | | | 1:0 | | | | ASD | [0:1]د | | | | | | conti | inued | | | | | | | | | | | |---------|-----------------------|-------------|--------------------------|-----------------------|------------|--------------|-----------------------------------------|-----------|---------------|------------------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Oliser | rvanie | | | | | | | | · · | | | | 0x0A52 | CCP8CON2H | 15:8<br>7:0 | OENSYNC<br>ICGS | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | OCAEN | | | 0x0A54 | | | | | | | | | | | | | 0x0A55 | Reserved | | | | | | | | | | | | 0x0A56 | CCP8CON3H | 15:8 | OETRIG | | OSCNT[2:0] | | | | | | | | | | 7:0<br>15:8 | | | POLACE | | PSSA | CE[1:0] | PSSB | DF[1:0] | | | 0x0A58 | CCP8STATL | 7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | 0x0A5A | Reserved | | | | | | | | | | | | 0x0A5F | Reserved | | | | | | | | | | | | 0x0A60 | CCP8PRL | 15:8<br>7:0 | | | | | [15:8] | | | | | | | | | | | | | [7:0] | | | | | | 0x0A62 | CCP8PRH | 15:8<br>7:0 | | | | PRH[<br>PRH[ | | | | | | | | | 15:8 | | | | | | | | | | | 0x0A64 | CCP8RA | 7:0 | | | | | [15:8]<br>P[7:0] | | | | | | 0x0A66 | | | | | | | 100 | | | | | | 0x0A67 | Reserved | | | | | | | | | | | | 0x0A68 | CCP8RB | 15:8 | | CMP[15:8] | | | | | | , | | | 0x0A6A | | 7:0 | | | | CMF | P[7:0] | | 1 | | | | | Reserved | | | | | | | | | | | | 0x0A6B | | | | | | | | | | | | | 0x0A6C | CCP8BUFL | 15:8 | | BUF[15:8] | | | | | | | | | | | 7:0 | BUF[7:0] | | | | | | | | | | 0x0A6E | CCP8BUFH | 15:8<br>7:0 | BUF[31:24]<br>BUF[23:16] | | | | | | | | | | | | 15:8 | CCPON | | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | | 0x0A70 | CCP9CON1L | 7:0 | TMRPS[1:0] T32 CCSEL M | | | | | | D[3:0] | | | | | | 15:8 | OPSSRC RTRGEN OPS3[3:0] | | | | | | | | | | 0x0A72 | CCP9CON1H | 7:0 | TRIGEN | ONESHOT | ALTSYNC | | | SYNC[4:0] | | | | | 0x0A74 | CCP9CON2L | 15:8 | PWMRSEN | ASDCM | | SSDC | | | | | | | 0,0,1,1 | OUI OUGHLEE | 7:0 | | | | ASD | G[7:0] | | | | | | 0x0A74 | CCP9CON3H | 15:8 | OETRIG | | OSCNT[2:0] | | 2001 | | 2002 | | | | | | 7:0<br>15:8 | OENSYNC | | POLACE | | PSSA | CE[1:0] | PSSB | DF[1:0]<br>OCAEN | | | 0x0A76 | CCP9CON2H | 7:0 | ICGS | M[1:0] | | AUXO | UT[1:0] | | ICS[2:0] | COALIV | | | 0x0A78 | | | | | | | | | | | | | 0x0A7B | Reserved | | | | | | | | | | | | 0x0A7C | CCP9STATL | 15:8 | | | | | _ = =================================== | | V 50-52-00-70 | | | | 0x0A7E | | 7:0 | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | | | Reserved | | | | | | | | | | | | 0x0A83 | | 15:8 | | | | DDI | 15-81 | | | | | | 0x0A84 | CCP9PRL | 7:0 | PRL[15:8] PRL[7:0] | | | | | | | | | | | (160, 200, 200, 200) | 15:8 | | | | | | | | | | | 0x0A86 | CCP9PRH | 7:0 | | PRH[31:24] PRH[23:16] | | | | | | | | | 0x0A88 | CCP9RA | 15:8 | | | | | [15:8] | | | | | | 0x0A8A | toprocess de 100 tota | 7:0 | | | | CMF | P[7:0] | | | | | | | Reserved | | | | | | | | | | | | 0x0A8B | | 15:8 | | | | CNAD | [15:8] | | | | | | 0x0A8C | CCP9RB | 7:0 | | | | | [15:8]<br>P[7:0] | | | | | | | | 1000000 | Omi [r.0] | | | | | | | | | | continued | | | | | | | | | | | |------------|----------|----------|-----------|------------|---|-------|--------|---|---|---| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0A8E | | | | | | | | | | | | <br>0x0A8F | Reserved | | | | | | | | | | | 0x0A90 | CCP9BUFL | 15:8 | BUF[15:8] | | | | | | | | | UNUASU | COLABOLE | 7:0 | BUF[7:0] | | | | | | | | | 0x0A92 | CCP9BUFH | 15:8 | | BUF[31:24] | | | | | | | | UXUA92 | ССРЭВОГН | 7:0 | | | | BUF[: | 23:16] | | | | ## Capture/Compare/PWM/Timer Modules (SCCP) #### 22.6.1 CCPx Control 1 Low Register Name: CCPxCON1L **Offset:** 0x950, 0x974, 0x998, 0x9BC, 0x9E0, 0xA04, 0xA28, 0xA4C, 0xA70 #### Note: 1. Only available on the MCCP. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|---------|---------|--------|---------|-----|-------------|-----| | | CCPON | | CCPSIDL | CCPSLP | TMRSYNC | | CLKSEL[2:0] | | | Access | R/W | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TMRF | PS[1:0] | T32 | CCSEL | | MOD | [3:0] | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - CCPON CCPx Module Enable bit | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | Module is enabled with an operating mode specified by the MOD[3:0] control bits | | 0 | Module is disabled | #### Bit 13 - CCPSIDL CCPx Stop in Idle Mode Bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation in Idle mode | #### Bit 12 - CCPSLP CCPx Sleep Mode Enable bit | Value | Description | |-------|--------------------------------------------| | 1 | Module continues to operate in Sleep modes | | 0 | Module does not operate in Sleep modes | #### Bit 11 - TMRSYNC Time Base Clock Synchronization bit | Value | Description | |-------|--------------------------------------------------------------------------------------------------------------------| | 1 | Asynchronous module time base clock is selected and synchronized to the internal system clocks (CLKSEL[2:0] ≠ 000) | | 0 | Synchronous module time base clock is selected and does not require synchronization (CLKSEL[2:0] = 000) | #### Bits 10:8 - CLKSEL[2:0] CCPx Time Base Clock Select bits(1) | | OCINCEL[2:0] COLX TIME Base Glock Collect bits | |-------|------------------------------------------------| | Value | Description | | 111 | External CCP TCKIx | | 110 | CLC4 | | 101 | CLC3 | | 100 | CLC2 | | 011 | CLC1 | | 010 | F <sub>OSC</sub> | | 001 | Reference Clock (REFCLKO) | | 000 | F <sub>OSC</sub> /2 (F <sub>P</sub> ) | #### Bits 7:6 - TMRPS[1:0] Time Base Prescale Select bits | DIL3 7.0 - | its 7.0 - Thirti S[1.0] Time base i rescale Gelectibits | | | | | | | | |------------|---------------------------------------------------------|--|--|--|--|--|--|--| | Value | Description | | | | | | | | | 11 | 1:64 Prescaler | | | | | | | | | 10 | 1:16 Prescaler | | | | | | | | | 01 | 1:4 Prescaler | | | | | | | | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 771 ## Capture/Compare/PWM/Timer Modules (SCCP) | Value | Description | |-------|---------------| | 00 | 1:1 Prescaler | #### Bit 5 - T32 32-Bit Time Base Select bit | Value | Description | |-------|---------------------------------------------------------------------------------------| | 1 | Uses 32-bit time base for timer, single edge output compare or input capture function | | 0 | Uses 16-bit time base for timer, single edge output compare or input capture function | #### Bit 4 - CCSEL Capture/Compare Mode Select bit | Value | Description | |-------|---------------------------------------------------------------------------------------| | 1 | Input Capture peripheral | | 0 | Output Compare/PWM/Timer peripheral (exact function is selected by the MOD[3:0] bits) | #### Bits 3:0 - MOD[3:0] CCPx Mode Select bits For CCSEL = 1 (Input Capture modes): | Value | Description | | | | | | |-------|----------------------------------------------------------|--|--|--|--|--| | 1xxx | Reserved | | | | | | | 011x | Reserved | | | | | | | 0101 | Capture every 16th rising edge | | | | | | | 0100 | Capture every 4th rising edge | | | | | | | 0011 | Capture every rising and falling edge | | | | | | | 0010 | Capture every falling edge | | | | | | | 0001 | Capture every rising edge | | | | | | | 0000 | Capture every rising and falling edge (Edge Detect mode) | | | | | | #### For CCSEL = 0 (Output Compare/Timer modes): | Value | Description | |-------|----------------------------------------------------------------------------------| | 1111 | External Input mode: Pulse generator is disabled, source is selected by ICS[2:0] | | 1110 | Reserved | | 110x | Reserved | | 10xx | Reserved | | 0111 | Variable Frequency Pulse mode <sup>(1)</sup> | | 0110 | Center Aligned Pulse Compare mode, buffered <sup>(1)</sup> | | 0101 | Dual Edge Compare mode, buffered | | 0100 | Dual Edge Compare mode | | 0011 | 16-Bit/32-Bit Single Edge mode, toggles output on compare match | | 0010 | 16-Bit/32-Bit Single Edge mode, drives output low on compare match | | 0001 | 16-Bit/32-Bit Single Edge mode, drives output high on compare match | | 0000 | 16-Bit/32-Bit Timer mode, output functions are disabled | ### Capture/Compare/PWM/Timer Modules (SCCP) #### 22.6.2 CCPx Control 1 High Register Name: CCPxCON1H **Offset:** 0x952, 0x976, 0x99A, 0x9BE, 0x9E2, 0xA06, 0xA2A, 0xA4E, 0xA72 #### Notes: - 1. This control bit has no function in Input Capture modes. - 2. This control bit has no function when TRIGEN = 0. - 3. Output postscale settings, from 1:5 to 1:16 (0100-1111), will result in a FIFO buffer overflow for Input Capture modes. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|--------|---------|---------|-----|-----------|-----|-----|-----|--| | | OPSSRC | RTRGEN | | | OPS3[3:0] | | | | | | Access | R/W | R/W | | | R/W | R/W | R/W | R/W | | | Reset | 0 | 0 | | | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TRIGEN | ONESHOT | ALTSYNC | | SYNC[4:0] | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | #### Bit 15 - OPSSRC Output Postscaler Source Select bit(1) | Value | Description | | | | | |-------|-------------------------------------------------------|--|--|--|--| | 1 | Output postscaler scales module trigger output events | | | | | | 0 | Output postscaler scales time base interrupt events | | | | | #### Bit 14 - RTRGEN Retrigger Enable bit(2) | Value | Description | |-------|------------------------------------------------------| | 1 | Time base can be retriggered when TRIGEN bit = 1 | | 0 | Time base may not be retriggered when TRIGEN bit = 1 | #### Bits 11:8 - OPS3[3:0] CCPx Interrupt Output Postscale Select bits<sup>(3)</sup> | Value | Description | |-------|-----------------------------------------------------------------------| | 1111 | Interrupt every 16th time base period match | | 1110 | Interrupt every 15th time base period match | | | | | 0100 | Interrupt every 5th time base period match | | 0011 | Interrupt every 4th time base period match or 4th input capture event | | 0010 | Interrupt every 3rd time base period match or 3rd input capture event | | 0001 | Interrupt every 2nd time base period match or 2nd input capture event | | 0000 | Interrupt after each time base period match or input capture event | #### Bit 7 - TRIGEN CCPx Trigger Enable bit | Value | Description | | |-------|--------------------------------------------|--| | 1 | Trigger operation of time base is enabled | | | 0 | Trigger operation of time base is disabled | | #### Bit 6 - ONESHOT One-Shot Trigger Mode Enable bit | Value | Description | |-------|-------------------------------------------------------------------------| | 1 | One-Shot Trigger mode is enabled; trigger duration is set by OSCNT[2:0] | | 0 | One-Shot Trigger mode is disabled | #### Bit 5 - ALTSYNC CCPx Clock Select bits | Value | Description | |-------|--------------------------------------------------------------------------------| | 1 | An alternate signal is used as the module synchronization output signal | | 0 | The module synchronization output signal is the Time Base Reset/rollover event | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 773 Capture/Compare/PWM/Timer Modules (SCCP) **Bits 4:0 – SYNC[4:0]** CCPx Synchronization Source Select bits See 22.6.15 Synchronization Sources for the definition of inputs. #### 22.6.3 CCPx Control 2 Low Register Name: CCPxCON2L **Offset:** 0x954, 0x974, 0x99C, 0x9C0, 0x9E4, 0xA08, 0xA2C, 0xA50, 0xA74 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|-------|-----|------|-----|-----|-----|-----| | | PWMRSEN | ASDGM | | SSDG | | | | | | Access | R/W | R/W | | R/W | | | | | | Reset | 0 | 0 | | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ASDG[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - PWMRSEN CCPx PWM Restart Enable bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------------| | 1 | ASEVT bit clears automatically at the beginning of the next PWM period, after the shutdown input has ended | | 0 | ASEVT bit must be cleared in software to resume PWM activity on output pins | #### Bit 14 - ASDGM CCPx Auto-Shutdown Gate Mode Enable bit | Value | Description | |-------|------------------------------------------------------------------------| | 1 | Waits until the next Time Base Reset or rollover for shutdown to occur | | 0 | Shutdown event occurs immediately | #### Bit 12 - SSDG CCPx Software Shutdown/Gate Control bit | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 1 | Manually forces auto-shutdown, timer clock gate or input capture signal gate event (setting of ASDGM | | | bit still applies) | | 0 | Normal module operation | #### Bits 7:0 - ASDG[7:0] CCPx Auto-Shutdown/Gating Source Enable bits | Value | Description | |-------|--------------------------------------------------------------------------------------------| | 1 | ASDGx Source n is enabled (see 22.6.16 Auto-Shutdown and Gating Sources for auto-shutdown/ | | | gating sources) | | 0 | ASDGx Source n is disabled | ## Capture/Compare/PWM/Timer Modules (SCCP) #### 22.6.4 CCPx Control 2 High Register Name: CCPxCON2H **Offset:** 0x956, 0x976, 0x99E, 0x9C2, 0x9E6, 0xA0A, 0xA2E, 0xA52, 0xA76 #### Bit 15 - OENSYNC Output Enable Synchronization bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Update by output enable bits occurs on the next Time Base Reset or rollover | | 0 | Update by output enable bits occurs immediately | #### Bit 8 - OCAEN Output Enable/Steering Control bit | Value | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------| | 1 | OCx pin is controlled by the CCPx module and produces an output compare or PWM signal | | 0 | OCx pin is not controlled by the CCPx module; the pin is available to the port logic or another peripheral multiplexed on the pin | #### Bits 7:6 - ICGSM[1:0] Input Capture Gating Source Mode Control bits | Value | Description | |-------|-----------------------------------------------------------------------------------------------------------| | 11 | Reserved | | 10 | One-Shot mode: Falling edge from gating source disables future capture events (ICDIS = 1) | | 01 | One-Shot mode: Rising edge from gating source enables future capture events (ICDIS = 0) | | 00 | Level-Sensitive mode: A high level from gating source will enable future capture events; a low level will | | | disable future capture events | #### Bits 4:3 - AUXOUT[1:0] Auxiliary Output Signal on Event Selection bits | Value | Description | |-------|-------------------------------------------------------------------------------| | 11 | Input capture or output compare event; no signal in Timer mode | | 10 | Signal output is defined by module operating mode (see 22.5 Auxiliary Output) | | 01 | Time base rollover event (all modes) | | 00 | Disabled | #### Bits 2:0 - ICS[2:0] Input Capture Source Select bits | Value | Description | |-------|--------------------------------------| | 111 | CLC4 | | 110 | CLC3 | | 101 | CLC2 | | 100 | CLC1 | | 011 | Comparator 3 | | 010 | Comparator 2 | | 001 | Comparator 1 | | 000 | SCCP Input Capture x (ICx) pin (PPS) | © 2021 Microchip Technology Inc. and its subsidiaries ## Capture/Compare/PWM/Timer Modules (SCCP) #### 22.6.5 CCPx Control 3 High Register Name: CCPxCON3H Offset: 0x95A, 0x97E, 0x9A2, 0x9C6, 0x9EA, 0xA0E, 0xA32, 0xA56, 0xA74 #### Bit 15 - OETRIG CCPx Dead-Time Select bit | Value | Description | |-------|--------------------------------------------------------------------------------------------| | 1 | For Triggered mode (TRIGEN = 1): Module does not drive enabled output pins until triggered | | 0 | Normal output pin operation | #### Bits 14:12 - OSCNT[2:0] One-Shot Event Count bits | Value | Description | |-------|---------------------------------------------------------------------------| | 111 | Extends one-shot event by 7 time base periods (8 time base periods total) | | 110 | Extends one-shot event by 6 time base periods (7 time base periods total) | | 101 | Extends one-shot event by 5 time base periods (6 time base periods total) | | 100 | Extends one-shot event by 4 time base periods (5 time base periods total) | | 011 | Extends one-shot event by 3 time base periods (4 time base periods total) | | 010 | Extends one-shot event by 2 time base periods (3 time base periods total) | | 001 | Extends one-shot event by 1 time base period (2 time base periods total) | | 000 | Does not extend one-shot trigger event | #### Bit 5 - POLACE CCPx Output Pins, OCxA, OCxC and OCxE, Polarity Control bit | Value | Description | |-------|------------------------------------| | 1 | Output pin polarity is active-low | | 0 | Output pin polarity is active-high | #### Bits 3:2 - PSSACE[1:0] PWMx Output Pins, OCxA, OCxC and OCxE, Shutdown State Control bits | Value | Description | |-------|-----------------------------------------------------------------| | 11 | Pins are driven active when a shutdown event occurs | | 10 | Pins are driven inactive when a shutdown event occurs | | 0x | Pins are in a high-impedance state when a shutdown event occurs | #### Bits 1:0 - PSSBDF[1:0] PWMx Output Pins, OCMxB, OCMxD and OCMxF, Shutdown State Control bits | Value | Description | |------------|-----------------------------------------------------------------| | 11 | Pins are driven active when a shutdown event occurs | | 10 | Pins are driven inactive when a shutdown event occurs | | 0 <b>x</b> | Pins are in a high-impedance state when a shutdown event occurs | ### Capture/Compare/PWM/Timer Modules (SCCP) #### 22.6.6 CCPx Status Register Name: CCPxSTATL **Offset:** 0x95C, 0x980, 0x9A4, 0x9C8, 0x9EC, 0xA10, 0xA34, 0xA58, 0xA7C Legend: C = Clearable bit; W1 = Write '1' Only bit Access Reset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|-------|-------|-------|-------|-------|------|-------| | | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | Access | R | W1 | W1 | R/C | R/C | R/C | R/C | R/C | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 7 - CCPTRIG CCPx Trigger Status bit | Value | Description | |-------|---------------------------------------------------| | 1 | Timer has been triggered and is running | | 0 | Timer has not been triggered and is held in Reset | #### Bit 6 - TRSET CCPx Trigger Set Request bit Writes '1' to this location to trigger the timer when TRIGEN = 1 (location always reads as '0'). #### Bit 5 - TRCLR CCPx Trigger Clear Request bit Writes '1' to this location to cancel the timer trigger when TRIGEN = 1 (location always reads as '0'). #### Bit 4 - ASEVT CCPx Auto-Shutdown Event Status/Control bit | Value | Description | |-------|-------------------------------------------------------------------------| | 1 | A shutdown event is in progress; CCPx outputs are in the shutdown state | | 0 | CCPx outputs operate normally | ### Bit 3 - SCEVT Single Edge Compare Event Status bit | Value | Description | |-------|----------------------------------------------| | 1 | A single edge compare event has occurred | | 0 | A single edge compare event has not occurred | #### Bit 2 - ICDIS Input Capture x Disable bit | Value | Description | |-------|----------------------------------------------------------------------| | 1 | Event on Input Capture x pin (ICx) does not generate a capture event | | 0 | Event on Input Capture x pin will generate a capture event | #### Bit 1 - ICOV Input Capture x Buffer Overflow Status bit | Value | Description | |-------|----------------------------------------------------| | 1 | The Input Capture x FIFO buffer has overflowed | | 0 | The Input Capture x FIFO buffer has not overflowed | #### Bit 0 - ICBNE Input Capture x Buffer Status bit | | BILE Impat Captaro X Barror Ctatao Sit | | |-------|-------------------------------------------|--| | Value | Description | | | 1 | Input Capture x buffer has data available | | | 0 | Input Capture x buffer is empty | | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 778 ## Capture/Compare/PWM/Timer Modules (SCCP) ### 22.6.7 CCPx Time Base Register Low Name: CCPxTMRL **Offset:** 0x960, 0x984, 0x9A8, 0x9CC, 0x9F0, 0xA14, 0xA38, A5C, A80 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|------------|----|----|----|----|----|---|---|--|--|--| | | TMRL[15:8] | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TMRL[7:0] | | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:0 - TMRL[15:0] CCPx 16-Bit Time Base Value bits ## Capture/Compare/PWM/Timer Modules (SCCP) ### 22.6.8 CCPx Time Base High Register Name: CCPxTMRH **Offset:** 0x962, 0x986, 0x9AA, 0x9CE, 0x9F2, 0xA16, 0xA3A, A5E, A82 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | TMRH[31:24] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | TMRH[23:16] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - TMRH[31:16] CCPx 16-Bit Time Base Value bits ## Capture/Compare/PWM/Timer Modules (SCCP) ### 22.6.9 CCPx Period Low Register Name: CCPxPRL **Offset:** 0x964, 0x988, 0x9AC, 0x9D0, 0x9F4, 0xA18, 0xA3C, 0xA60, 0xA84 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-----------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PRL[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PRL[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 15:0 - PRL[15:0] CCPx Period Low Register bits ## Capture/Compare/PWM/Timer Modules (SCCP) ## 22.6.10 CCPx Period High Register Name: CCPxPRH **Offset:** 0x966, 0x98A, 0x9AE, 0x9D2, 0x9F6, 0xA1A, 0xA3E, 0xA62, 0xA86 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-----|------------|-----|------|--------|-----|-----|-----|--|--|--|--| | | | PRH[31:24] | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | PRH[ | 23:16] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - PRH[31:16] CCPx Period High Register bits ## Capture/Compare/PWM/Timer Modules (SCCP) ### 22.6.11 CCPx Primary Compare Register (Timer/Compare Modes Only) Name: CCPxRA **Offset:** 0x968, 0x98C, 0x9B0, 0x9D4, 0x9F8, 0xA1C, 0xA40, 0xA64, 0xA88 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-----|-----------|-----|-----|--------|-----|-----|-----|--|--|--|--| | | | CMP[15:8] | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | CMF | P[7:0] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | **Bits 15:0 – CMP[15:0]** CCPx Primary Compare Value bits The 16-bit value to be compared against the CCP time base. ## Capture/Compare/PWM/Timer Modules (SCCP) ### 22.6.12 CCPx Secondary Compare Register (Timer/Compare Modes Only) Name: CCPxRB **Offset:** 0x96C, 0x990, 0x9B4, 0x9D8, 0x9FC, 0xA20, 0xA44, 0xA68, 0xA8C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----|-----------|-----|-----|-------|-----|-----|-----|--|--|--| | | | CMP[15:8] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | CMF | [7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | **Bits 15:0 – CMP[15:0]** CCPx Secondary Compare Value bits The 16-bit value to be compared against the CCP time base. ## Capture/Compare/PWM/Timer Modules (SCCP) ### 22.6.13 CCPx Capture Buffer Register Low (Capture Modes Only) Name: CCPxBUFL **Offset:** 0x970, 0x994, 0x9B8, 0x9DC, 0xA00, 0xA24, 0xA48, 0xA6C, 0xA90 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-----|-----------|-----|-----|-------|-----|-----|-----|--|--|--|--| | | | BUF[15:8] | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | BUF | [7:0] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 – BUF[15:0] CCPx Compare Buffer Value bits Indicates the oldest captured time base value in the FIFO. ### 22.6.14 CCPx Capture Buffer High Register (Capture Modes Only) Name: CCPxBUFH **Offset:** 0x972, 0x996, 0x9BA, 0x9DE, 0xA02, 0xA26, 0xA4A, 0xA6E, 0xA92 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|--------|-----|-----|-----| | | | | | BUF[ | 31:24] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | BUF[2 | 23:16] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - BUF[31:16] CCPx Compare Buffer Value bits #### 22.6.15 Synchronization Sources ### Table 22-5. Synchronization Sources | SYNC[4:0] | Synchronization Source | |-----------|----------------------------------------------------| | 00000 | None; Timer with Rollover on CCPxPR Match or FFFFh | | 00001 | Module's Own Timer Sync Out | | 00010 | Sync Output SCCP2 | | 00011 | Sync Output SCCP3 | | 00100 | Sync Output SCCP4 | | 00101 | Sync Output SCCP5 | | 00110 | Sync Output SCCP6 | | 00111 | Sync Output SCCP7 | | 01000 | Sync Output SCCP8 | | 01001 | INTO | | 01010 | INT1 | | 01011 | INT2 | | 01100 | UART1 RX Edge Detect | | 01101 | UART1 TX Edge Detect | | 01110 | UART2 RX Edge Detect | | 01111 | UART2 TX Edge Detect | | 10000 | CLC1 Output | | 10001 | CLC2 Output | | 10010 | CLC3 Output | | 10011 | CLC4 Output | | 10100 | UART3 RX Edge Detect | | 10101 | UART3 TX Edge Detect | Capture/Compare/PWM/Timer Modules (SCCP) | continued | | |-------------|------------------------------------------------| | SYNC[4:0] | Synchronization Source | | 10110 | Sync Output MCCP9 | | 10111 | Comparator 1 Output | | 11000 | Comparator 2 Output | | 11001 | Comparator 3 Output | | 11010-11110 | Reserved | | 11111 | None; Timer with Auto-Rollover (FFFFh → 0000h) | ### 22.6.16 Auto-Shutdown and Gating Sources Table 22-6. Auto-Shutdown and Gating Sources | ASDG[x] | | | | Auto-Shu | ıtdown/Gat | ing Source | | | | | | |----------------------------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--|--| | Bit | SCCP1 | SCCP2 | SCCP3 | SCCP4 | SCCP5 | SCCP6 | SCCP7 | SCCP8 | МССР9 | | | | 0 | | Comparator 1 Output | | | | | | | | | | | 1 | | Comparator 2 Output | | | | | | | | | | | 2 | | OCFC | | | | | | | | | | | 3 | | OCFD | | | | | | | | | | | 4 | ICM1 <sup>(1)</sup> | ICM2 <sup>(1)</sup> | ICM3 <sup>(1)</sup> | ICM4 <sup>(1)</sup> | ICM5 <sup>(1)</sup> | ICM6 <sup>(1)</sup> | ICM7 <sup>(1)</sup> | ICM8 <sup>(1)</sup> | ICM9 <sup>(1)</sup> | | | | 5 | | | | | CLC1 <sup>(1)</sup> | | | | | | | | 6 | | | | | OCFA <sup>(1)</sup> | | | | | | | | 7 | | | | | OCFB <sup>(1)</sup> | | | | | | | | Note: 1. Selected by Peripheral Pin Select (PPS). | | | | | | | | | | | | ## 23. Configurable Logic Cell (CLC) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. For more information, refer to "**Configurable Logic Cell (CLC)**" (www.microchip.com/DS70005298) in the "dsPIC33/PIC24 Family Reference Manual". The information in this data sheet supersedes the information in the FRM. The Configurable Logic Cell (CLC) module allows the user to specify combinations of signals as inputs to a logic function and to use the logic output to control other peripherals or I/O pins. This provides greater flexibility and potential in embedded designs, since the CLC module can operate outside the limitations of software execution, and supports a vast amount of output designs. There are four input gates to the selected logic function. These four input gates select from a pool of up to 32 signals that are selected using four data source selection multiplexers. Figure 23-1 shows the details of the data source multiplexers and Figure 23-2 shows the logic input gate connections. Figure 23-1. CLCx Module Figure 23-2. CLCx Logic Function Combinatorial Options Data Selection Input 0 Input 1 -Data Gate 1 Input 2 -G1D1T Data 1 Noninverted Input 3 Input 4 -Data 1 Input 5 Inverted G1D1N Input 6 Input 7 G1D2T DS1x (CLCxSEL[2:0]) G1D2N -Gate 1 Input 8 -Input 9 G1D3T G1POL Input 10 -Data 2 Noninverted (CLCxCONH[0]) Input 11 -G1D3N Input 12 Data 2 Inverted Input 13 G1D4T Input 14 Input 15 -DS2x (CLCxSEL[6:4]) G1D4N Input 16 -Data Gate 2 Input 17 -Input 18 --Gate 2 Input 19 Data 3 Noninverted (Same as Data Gate 1) Input 20 Data 3 Inverted Input 21 -Data Gate 3 Input 22 Input 23 -Gate 3 DS3x (CLCxSEL[10:8]) (Same as Data Gate 1) Data Gate 4 Input 24 -Input 25 -Gate 4 Input 26 (Same as Data Gate 1) Data 4 Noninverted Input 27 -Input 28 -Data 4 Inverted Input 29 Input 30 Input 31 DS4x (CLCxSEL[14:12]) | Figure 23-3. CLCx Input Source Selection Diagram Note: All controls are undefined at power-up. ## 23.1 Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------------------------------------------------|-------------|----------------|----------------|-------------------|----------------|----------------|----------------|----------------------|----------------| | 0,,00 | CL C4CONU | 15:8 | | | | | | | | | | 0xC2 | CLC1CONH | 7:0 | | | | | G4POL | G3POL | G2POL | G1POL | | 0,404 | CL C4CONI | 15:8 | LCEN | | | | INTP | INTN | | | | 0xC4 | CLC1CONL | 7:0 | LCOE | LCOUT | LCPOL | | | | MODE[2:0] | | | 0xC6 | | | | | | | | | | | | ••• | Reserved | | | | | | | | | | | 0xC7 | | | | | | | | | | | | 0xC8 | CLC1SEL | 15:8 | | | DS4[2:0] | | | | DS3[2:0] | | | UXO0 | OLOTOLL | 7:0 | | | DS2[2:0] | | | | DS1[2:0] | | | 0xC8 | CLC1GLSL | 15:8 | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | UNO U | OLOTOLOL | 7:0 | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | 0xCA | CLC1GLSH | 15:8 | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | | 020102011 | 7:0 | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | 0xCC | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0xCD | | | | | | | | | | | | 0xCE | CLC2CONH | 15:8 | | | | | | | | 21221 | | | | 7:0 | 1.0511 | | | | G4POL | G3POL | G2POL | G1POL | | 0xD0 | CLC2CONL | 15:8 | LCEN | LOCUE | 1.0001 | | INTP | INTN | MODERA | | | 0::D0 | 20 S. A. S. | 7:0 | LCOE | LCOUT | LCPOL | | | | MODE[2:0] | | | 0xD2 | Desaminal | | | | | | | | | | | 0xD3 | Reserved | | | | | | | | | | | UXD3 | | 15:8 | | | D64[3:0] | | | | D63[3·0] | | | 0xD4 | CLC2SEL | 7:0 | | | DS4[2:0] | | | | DS3[2:0]<br>DS1[2:0] | | | | | 15:8 | G2D4T | G2D4N | DS2[2:0]<br>G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | 0xD4 | CLC2GLSL | | | G2D4N<br>G1D4N | | | | | | | | | | 7:0<br>15:8 | G1D4T<br>G4D4T | G4D4N | G1D3T<br>G4D3T | G1D3N<br>G4D3N | G1D2T<br>G4D2T | G1D2N<br>G4D2N | G1D1T<br>G4D1T | G1D1N<br>G4D1N | | 0xD6 | <b>CLC2GLSH</b> | 7:0 | G3D4T | G3D4N | G3D3T | G3D3N | G4D2T<br>G3D2T | G3D2N | G3D1T | G3D1N | | 0xD8 | | 7.0 | G3D41 | G3D4N | GSDST | GSDSN | GSDZ1 | GSDZN | GSD11 | GSD IN | | | Reserved | | | | | | | | | | | 0xD9 | reserved | | | | | | | | | | | | | 15:8 | | | | | | | | | | 0xDA | CLC3CONH | 7:0 | | | | | G4POL | G3POL | G2POL | G1POL | | | 17.221115.7412.21116.01 | 15:8 | LCEN | | | | INTP | INTN | | | | 0xDC | CLC3CONL | 7:0 | LCOE | LCOUT | LCPOL | | | | MODE[2:0] | | | 0xDE | | | | | | | | | | | | *** | Reserved | | | | | | | | | | | 0xDF | | | | | | | | | | | | 0.50 | 01 00051 | 15:8 | | | DS4[2:0] | , | | | DS3[2:0] | | | 0xE0 | CLC3SEL | 7:0 | | | DS2[2:0] | | | | DS1[2:0] | | | 0,50 | 01.0301.01 | 15:8 | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | 0xE0 | CLC3GLSL | 7:0 | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | 0vE2 | CLC3CLCL | 15:8 | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | 0xE2 | CLC3GLSH | 7:0 | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | 0xE4 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0xE5 | | | | | | | | | | | | 0xE6 | CLC4CONH | 15:8 | | | | | | | | | | | 222.001111 | 7:0 | | | | | G4POL | G3POL | G2POL | G1POL | | 0xE8 | CLC4CONL | 15:8 | LCEN | | | | INTP | INTN | | | | | | 7:0 | LCOE | LCOUT | LCPOL | | | | MODE[2:0] | | | 0xEA | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0xFR | | 45.5 | | | DO 11 | | | | D.00-1 | | | 0xEC | CLC4SEL | 15:8 | | | DS4[2:0] | | | | DS3[2:0] | | | | | 7:0 | | | DS2[2:0] | | | | DS1[2:0] | | Configurable Logic Cell (CLC) | continued | | | | | | | | | | | | |---------------|------|----------|-------|-------|-------|-------|-------|-------|-------|-------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | OVEC | 0.50 | 15:8 | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | | 0xEC CLC4GLSL | 7:0 | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | | | 0xEE CLC4GLSH | 15:8 | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | | | | 7:0 | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | | ## 23.1.1 CLCx Control Register Low Name: CLCxCONL **Offset:** 0x0C4, 0x0D0, 0x0DC, 0x0E8 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|-------|-------|-----|------|------|-----------|-----| | | LCEN | | | | INTP | INTN | | | | Access | R/W | | | 300 | R/W | R/W | , | | | Reset | 0 | | | | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | LCOE | LCOUT | LCPOL | | | | MODE[2:0] | | | Access | R | R | R/W | | | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | | | 0 | 0 | 0 | #### Bit 15 - LCEN CLCx Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | CLCx is enabled and mixing input signals | | 0 | CLCx is disabled and has logic zero outputs | #### Bit 11 - INTP CLCx Positive Edge Interrupt Enable bit | Value | Description | |-------|----------------------------------------------------------------| | 1 | Interrupt will be generated when a rising edge occurs on LCOUT | | 0 | Interrupt will not be generated | #### Bit 10 - INTN CLCx Negative Edge Interrupt Enable bit | Value | Description | |-------|-----------------------------------------------------------------| | 1 | Interrupt will be generated when a falling edge occurs on LCOUT | | 0 | Interrupt will not be generated | #### Bit 7 - LCOE CLCx Port Enable bit | Value | Description | |-------|----------------------------------| | 1 | CLCx port pin output is enabled | | 0 | CLCx port pin output is disabled | #### Bit 6 - LCOUT CLCx Data Output Status bit | Value | Description | |-------|------------------| | 1 | CLCx output high | | 0 | CLCx output low | #### Bit 5 - LCPOL CLCx Output Polarity Control bit | Value | Description | |-------|------------------------------------------| | 1 | The output of the module is inverted | | 0 | The output of the module is not inverted | ## Bits 2:0 - MODE[2:0] CLCx Mode bits | Value | Description | |-------|---------------------------------------------| | 111 | Single input transparent latch with S and R | | 110 | JK flip-flop with R | | 101 | Two-input D flip-flop with R | | 100 | Single input D flip-flop with S and R | | 011 | SR latch | | 010 | Four-input AND | | 001 | Four-input OR-XOR | | 000 | Four-input AND-OR | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 793 **Configurable Logic Cell (CLC)** ## 23.1.2 CLCx Control Register High Name: CLCxCONH **Offset:** 0x0C2, 0x0CE, 0x0DA, 0x0E6 ## Bit 3 - G4POL Gate 4 Polarity Control bit | Value | Description | |-------|-------------------------------------------------------------------| | 1 | Channel 4 logic output is inverted when applied to the logic cell | | 0 | Channel 4 logic output is not inverted | #### Bit 2 - G3POL Gate 3 Polarity Control bit | Value | Description | |-------|-------------------------------------------------------------------| | 1 | Channel 3 logic output is inverted when applied to the logic cell | | 0 | Channel 3 logic output is not inverted | #### Bit 1 - G2POL Gate 2 Polarity Control bit | Value | Description | |-------|-------------------------------------------------------------------| | 1 | Channel 2 logic output is inverted when applied to the logic cell | | 0 | Channel 2 logic output is not inverted | ## Bit 0 - G1POL Gate 1 Polarity Control bit | Value | Description | |-------|-------------------------------------------------------------------| | 1 | Channel 1 logic output is inverted when applied to the logic cell | | 0 | Channel 1 logic output is not inverted | # 23.1.3 CLCx Input MUX Select Register Name: CLCxSEL **Offset:** 0x0C8, 0x0D4, 0x0E0, 0x0EC | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|-----|----------|-----|----|-----|----------|-----| | | | | DS4[2:0] | | | | DS3[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 0 | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DS2[2:0] | | | | DS1[2:0] | | | Access | | R/W | R/W | R/W | | R/W | R/W | R/W | | Reset | | 0 | 0 | 0 | | 0 | 0 | 0 | ## Bits 14:12 - DS4[2:0] Data Selection MUX 4 Signal Selection bits | Value | Description | |-------|---------------------| | 111 | SCCP3 auxiliary out | | 110 | SCCP1 auxiliary out | | 101 | CLCIND RP pin | | 100 | Reserved | | 011 | SPI1 Input (SDIx) | | 010 | Comparator 3 out | | 001 | CLC2 output | | 000 | PWM Event A | ## Bits 10:8 - DS3[2:0] Data Selection MUX 3 Signal Selection bits | Value | Description | |-------|---------------------| | 111 | SCCP4 OC out | | 110 | SCCP3 OC out | | 101 | CLC4 out | | 100 | UART1 RX | | 011 | SPI1 Output (SDOx) | | 010 | Comparator 2 output | | 001 | CLC1 output | | 000 | CLCINC I/O pin | #### Bits 6:4 - DS2[2:0] Data Selection MUX 2 Signal Selection bits | DIG U.T | Doz[2.0] Data colocion Mox 2 cignal colocion bito | |---------|---------------------------------------------------| | Value | Description | | 111 | SCCP2 OC out | | 110 | SCCP1 OC out | | 101 | Comparator 6 output | | 100 | Comparator 5 output | | 011 | UART1 TX | | 010 | Comparator 1 output | | 001 | Comparator 4 Output | | 000 | CLCINB I/O pin | | | | ## Bits 2:0 - DS1[2:0] Data Selection MUX 1 Signal Selection bits | Value | Description | |-------|-------------------------| | 111 | SCCP4 auxiliary out | | 110 | SCCP2 auxiliary out | | 101 | Reserved | | 100 | REFCLKO output | | 011 | INTRC/LPRC clock source | Configurable Logic Cell (CLC) | Value | Description | |-------|---------------------------------| | 010 | CLC3 out | | 001 | System clock (F <sub>CY</sub> ) | | 000 | CLCINA I/O pin | ## 23.1.4 CLCx Gate Logic Input Select Low Register Name: CLCxGLSL **Offset:** 0x0C8, 0x0D4, 0x0E0, 0x0EC | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - G2D4T Gate 2 Data Source 4 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 4 signal is enabled for Gate 2 | | 0 | Data Source 4 signal is disabled for Gate 2 | #### Bit 14 - G2D4N Gate 2 Data Source 4 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 4 inverted signal is enabled for Gate 2 | | 0 | Data Source 4 inverted signal is disabled for Gate 2 | #### Bit 13 - G2D3T Gate 2 Data Source 3 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 3 signal is enabled for Gate 2 | | 0 | Data Source 3 signal is disabled for Gate 2 | ## Bit 12 - G2D3N Gate 2 Data Source 3 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 3 inverted signal is enabled for Gate 2 | | 0 | Data Source 3 inverted signal is disabled for Gate 2 | #### Bit 11 - G2D2T Gate 2 Data Source 2 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 2 signal is enabled for Gate 2 | | 0 | Data Source 2 signal is disabled for Gate 2 | #### Bit 10 - G2D2N Gate 2 Data Source 2 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 2 inverted signal is enabled for Gate 2 | | 0 | Data Source 2 inverted signal is disabled for Gate 2 | ### Bit 9 - G2D1T Gate 2 Data Source 1 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 1 signal is enabled for Gate 2 | | 0 | Data Source 1 signal is disabled for Gate 2 | ## Bit 8 - G2D1N Gate 2 Data Source 1 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 1 inverted signal is enabled for Gate 2 | | 0 | Data Source 1 inverted signal is disabled for Gate 2 | © 2021 Microchip Technology Inc. and its subsidiaries **Configurable Logic Cell (CLC)** #### Bit 7 - G1D4T Gate 1 Data Source 4 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 4 signal is enabled for Gate 1 | | 0 | Data Source 4 signal is disabled for Gate 1 | #### Bit 6 - G1D4N Gate 1 Data Source 4 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 4 inverted signal is enabled for Gate 1 | | 0 | Data Source 4 inverted signal is disabled for Gate 1 | #### Bit 5 - G1D3T Gate 1 Data Source 3 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 3 signal is enabled for Gate 1 | | 0 | Data Source 3 signal is disabled for Gate 1 | #### Bit 4 - G1D3N Gate 1 Data Source 3 Negated Enable bit | V | alue | Description | |---|------|------------------------------------------------------| | 1 | | Data Source 3 inverted signal is enabled for Gate 1 | | 0 | | Data Source 3 inverted signal is disabled for Gate 1 | #### Bit 3 - G1D2T Gate 1 Data Source 2 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 2 signal is enabled for Gate 1 | | 0 | Data Source 2 signal is disabled for Gate 1 | #### Bit 2 - G1D2N Gate 1 Data Source 2 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 2 inverted signal is enabled for Gate 1 | | 0 | Data Source 2 inverted signal is disabled for Gate 1 | ## Bit 1 - G1D1T Gate 1 Data Source 1 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 1 signal is enabled for Gate 1 | | 0 | Data Source 1 signal is disabled for Gate 1 | ### Bit 0 - G1D1N Gate 1 Data Source 1 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 1 inverted signal is enabled for Gate 1 | | 0 | Data Source 1 inverted signal is disabled for Gate 1 | ## 23.1.5 CLCx Gate Logic Input Select High Register Name: CLCxGLSH **Offset:** 0x0CA, 0x0D6, 0x0E2, 0x0EE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 15 - G4D4T Gate 4 Data Source 4 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 4 signal is enabled for Gate 4 | | 0 | Data Source 4 signal is disabled for Gate 4 | #### Bit 14 - G4D4N Gate 4 Data Source 4 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 4 inverted signal is enabled for Gate 4 | | 0 | Data Source 4 inverted signal is disabled for Gate 4 | #### Bit 13 - G4D3T Gate 4 Data Source 3 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 3 signal is enabled for Gate 4 | | 0 | Data Source 3 signal is disabled for Gate 4 | ## Bit 12 - G4D3N Gate 4 Data Source 3 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 3 inverted signal is enabled for Gate 4 | | 0 | Data Source 3 inverted signal is disabled for Gate 4 | #### Bit 11 - G4D2T Gate 4 Data Source 2 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 2 signal is enabled for Gate 4 | | 0 | Data Source 2 signal is disabled for Gate 4 | #### Bit 10 - G4D2N Gate 4 Data Source 2 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 2 inverted signal is enabled for Gate 4 | | 0 | Data Source 2 inverted signal is disabled for Gate 4 | ### Bit 9 - G4D1T Gate 4 Data Source 1 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 1 signal is enabled for Gate 4 | | 0 | Data Source 1 signal is disabled for Gate 4 | ### Bit 8 - G4D1N Gate 4 Data Source 1 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 1 inverted signal is enabled for Gate 4 | | 0 | Data Source 1 inverted signal is disabled for Gate 4 | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 799 **Configurable Logic Cell (CLC)** #### Bit 7 - G3D4T Gate 3 Data Source 4 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 4 signal is enabled for Gate 3 | | 0 | Data Source 4 signal is disabled for Gate 3 | #### Bit 6 - G3D4N Gate 3 Data Source 4 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 4 inverted signal is enabled for Gate 3 | | 0 | Data Source 4 inverted signal is disabled for Gate 3 | #### Bit 5 - G3D3T Gate 3 Data Source 3 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 3 signal is enabled for Gate 3 | | 0 | Data Source 3 signal is disabled for Gate 3 | #### Bit 4 - G3D3N Gate 3 Data Source 3 Negated Enable bit | Valu | e Description | |------|------------------------------------------------------| | 1 | Data Source 3 inverted signal is enabled for Gate 3 | | 0 | Data Source 3 inverted signal is disabled for Gate 3 | #### Bit 3 - G3D2T Gate 3 Data Source 2 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 2 signal is enabled for Gate 3 | | 0 | Data Source 2 signal is disabled for Gate 3 | #### Bit 2 - G3D2N Gate 3 Data Source 2 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 2 inverted signal is enabled for Gate 3 | | 0 | Data Source 2 inverted signal is disabled for Gate 3 | ## Bit 1 - G3D1T Gate 3 Data Source 1 True Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | Data Source 1 signal is enabled for Gate 3 | | 0 | Data Source 1 signal is disabled for Gate 3 | ### Bit 0 - G3D1N Gate 3 Data Source 1 Negated Enable bit | Value | Description | |-------|------------------------------------------------------| | 1 | Data Source 1 inverted signal is enabled for Gate 3 | | 0 | Data Source 1 inverted signal is disabled for Gate 3 | # 24. Peripheral Trigger Generator (PTG) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**Peripheral Trigger Generator (PTG)**" (www.microchip.com/DS70000669) in the "dsPIC33/PIC24 Family Reference Manual". The dsPIC33CK512MP608 family Peripheral Trigger Generator (PTG) module is a user-programmable sequencer that is capable of generating complex trigger signal sequences to coordinate the operation of other peripherals. The PTG module is designed to interface with other modules, such as an Analog-to-Digital Converter (ADC), output compare and PWM modules, timers and interrupt controllers. #### 24.1 Features - Behavior is Step Command Driven: - Step commands are eight bits wide - · Commands are Stored in a Step Queue: - Queue depth is up to 32 entries - Programmable Step execution time (Step delay) - · Supports the Command Sequence Loop: - Can be nested one-level deep - Conditional or unconditional loop - Two 16-bit loop counters - 15 Hardware Input Triggers: - Sensitive to either positive or negative edges, or a high or low level - · One Software Input Trigger - Generates up to 32 Unique Output Trigger Signals - · Generates Two Types of Trigger Outputs: - Individual - Broadcast - Strobed Output Port for Literal Data Values: - 5-bit literal write (literal part of a command) - 16-bit literal write (literal held in the PTGL0 register) - · Generates up to Ten Unique Interrupt Signals - Two 16-Bit General Purpose Timers - · Flexible Self-Contained Watchdog Timer (WDT) to Set an Upper Limit to Trigger Wait Time - · Single-Step Command Capability in Debug mode - Selectable Clock (System, Pulse-Width Modulator (PWM) or ADC) - · Programmable Clock Divider Figure 24-1. PTG Block Diagram #### Note: 1. This is a dedicated Watchdog Timer for the PTG module and is independent of the device Watchdog Timer. # 24.2 PTG Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------------------------------------------|-------------|---------|-------------|---------|---------|--------------------------|-------------|-------------|---------| | 0x0900 | PTGCST | 15:8 | PTGEN | | PTGSIDL | PTGTOGL | | PTGSWT | PTGSSEN | PTGIVIS | | 0,0000 | 110001 | 7:0<br>15:8 | PTGSTRT | PTGWDTO | PTGBUSY | | | | PTGI | TM[1:0] | | 0x0902 | 0x0902 PTGCON | | | PTGCLK[2:0] | | | | PTGDIV[4:0] | | | | | | | | PTGPV | VD[3:0] | | | | PTGWDT[2:0] | | | 0x0904 | PTGBTEL(1) | 15:8 | | | | | TE[15:8] | | | | | | | 7:0<br>15:8 | | | | | TE[7:0]<br>E[31:24] | | | | | 0x0906 | PTGBTEH(1) | 7:0 | | | | | E[31.24]<br>PTGBTE[23:17 | 71 | | | | | V22 411 C 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 15:8 | | | | | LD[15:8] | 1 | | | | 0x0908 | PTGHOLD(1) | 7:0 | | | | | DLD[7:0] | | | | | 0x090A | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x090B | | | | | | | | | | | | 0x090C | PTGT0LIM(1) | 15:8 | | | | | _IM[15:8] | | | | | | A 1 - 10 | 7:0 | | 1 | la . | PTGT0 | LIM[7:0] | | 1c | 1 | | 0x090E | Decembed | | | | | | | | | | | 0x090F | Reserved | | | | | | | | | | | | | 15:8 | | | | PTGT1I | _<br>_IM[15:8] | | ļ. | | | 0x0910 | PTGT1LIM(1) | 7:0 | | | | | LIM[7:0] | | | | | 0x0912 | | 1,115 | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0913 | | | | | | | | | | | | 0x0914 | PTGSDLIM(1) | 15:8 | | | | | LIM[15:8] | | | | | | 110002(1) | 7:0 | | | | PTGSD | LIM[7:0] | | | | | 0x0916 | | | | | | | | | | | | 0x0917 | Reserved | | | | | | | | | | | 0.0917 | *** *** | 15:8 | | | | PTGC0I | _<br>_IM[15:8] | | | | | 0x0918 | PTGC0LIM(1) | 7:0 | | | | | LIM[7:0] | | | | | 0x091A | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x091B | | | | | | | | | | | | 0x091C | PTGC1LIM(1) | 15:8 | | | | | _IM[15:8] | | | | | | | 7:0 | | | | PTGC1 | LIM[7:0] | | 1 | | | 0x091E | Reserved | | | | | | | | | | | 0x091F | Reserved | | | | | | | | | | | | 120732100.0000.0000.0000 | 15:8 | | | | PTGAE | DJ[15:8] | | | | | 0x0920 | PTGADJ(1) | 7:0 | | | | PTGA | DJ[7:0] | | | | | 0x0922 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0923 | | | | | | | | | | | | 0x0924 | PTGL0(1,2) | 15:8 | | | | | 0[15:8] | | | | | | | 7:0 | | | | PTGL | _0[7:0] | | | | | 0x0926 | Reserved | | | | | | | | | | | 0x0927 | Reserved | | | | | | | | | | | | | 15:8 | | | | | | | | | | 0x0928 | PTGQPTR(1) | 7:0 | | | | | | PTGQPTR[4:0 | ] | | | 0x092A | | | | | | | | | | | | *** | Reserved | | | | | | | | | | | 0x092F | | | | | | | | | | | | 0x0930 | PTGQUE0(1) | 15:8 | | | | | 0+1[7:0] | | | | | | and the second second | 7:0 | | | | STEP | 20[7:0] | | | | Peripheral Trigger Generator (PTG) | conti | inued | | | | | | | | | | |----------------------|------------|-------------|---|------------------------------|---|---|---------------------|---|---|---| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0932<br><br>0x0933 | Reserved | | | | | | | | | | | 0x0934 | PTGQUE1(1) | 15:8<br>7:0 | | | | | n+1[7:0]<br>2n[7:0] | | | | | 0x0936<br><br>0x0937 | Reserved | | | | | | | | | | | 0x0938 | PTGQUE2(1) | 15:8<br>7:0 | | | | | 2+1[7:0]<br>22[7:0] | | | | | 0x093A<br><br>0x093B | Reserved | | | | | | | | | | | 0x093C | PTGQUE3(1) | 15:8<br>7:0 | | STEP23+1[7:0]<br>STEP23[7:0] | | | | | | | | 0x093E<br><br>0x093F | Reserved | | | | | | | | | | | 0x0940 | PTGQUE4(1) | 15:8<br>7:0 | | STEP24+1[7:0]<br>STEP24[7:0] | | | | | | | | 0x0942<br><br>0x0943 | Reserved | | | | | | | | | | | 0x0944 | PTGQUE5(1) | 15:8<br>7:0 | | | , | | 5+1[7:0]<br>25[7:0] | | | • | | 0x0946<br><br>0x0947 | Reserved | | | | | | | | | | | 0x0948 | PTGQUE6(1) | 15:8<br>7:0 | | | | | 6+1[7:0]<br>26[7:0] | | | | | 0x094A<br><br>0x094B | Reserved | | | | | | | | | | | 0x094C | PTGQUE7(1) | 15:8<br>7:0 | | | | | 7+1[7:0]<br>27[7:0] | | | | ## 24.2.1 PTG Control/Status Low Register Name: PTGCST Offset: 0x900 #### Notes: - 1. These bits apply to the PTGWHI and PTGWLO commands only. - 2. This bit is only used with the PTGCTRL Step command software trigger option. - 3. The PTGSSEN bit may only be written when in Debug mode. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|---------|---------|---------|---------|----|--------|---------|---------| | | PTGEN | | PTGSIDL | PTGTOGL | | PTGSWT | PTGSSEN | PTGIVIS | | Access | R/W | | R/W | R/W | | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PTGSTRT | PTGWDTO | PTGBUSY | | | | PTGIT | M[1:0] | | Access | R/W | R/W | R/W | | | | R/W | R/W | | Reset | 0 | 0 | 0 | | | | 0 | 0 | #### Bit 15 - PTGEN PTG Broadcast Trigger Enable bit | Value | Description | |-------|-----------------| | 1 | PTG is enabled | | 0 | PTG is disabled | #### Bit 13 - PTGSIDL PTG Freeze in Debug Mode bit | Value | Description | |-------|---------------------------------------------| | 1 | Halts PTG operation when device is Idle | | 0 | PTG operation continues when device is Idle | ## Bit 12 - PTGTOGL PTG Toggle Trigger Output bit | Value | Description | |-------|-------------------------------------------------------------| | 1 | Toggles state of TRIG output for each execution of PTGTRIG | | 0 | Generates a single TRIG pulse for each execution of PTGTRIG | #### Bit 10 - PTGSWT PTG Software Trigger bit<sup>(2)</sup> | Value | Description | |-------|-------------------------------------------------------------------------------------| | 1 | If the PTG state machine is executing the "Wait for software trigger" Step command | | | (OPTION[3:0] = 1010 or 1011), the command will complete and execution will continue | | 0 | No action other than to clear the bit | ## Bit 9 - PTGSSEN PTG Single-Step Command bit(3) | Value | Description | |-------|----------------------------------------| | 1 | Enables single Step when in Debug mode | | 0 | Disables single Step | ## Bit 8 - PTGIVIS PTG Counter/Timer Visibility bit | Value | Description | |-------|------------------------------------------------------------------------------------------------| | 1 | Reading the PTGSDLIM, PTGCxLIM or PTGTxLIM register returns the current values of their | | | corresponding Counter/Timer registers (PTGSDLIM, PTGCxLIM and PTGTxLIM) | | 0 | Reading the PTGSDLIM, PTGCxLIM or PTGTxLIM register returns the value of these Limit registers | #### Bit 7 - PTGSTRT PTG Start Sequencer bit | Value | Description | |-------|---------------------------------------------------------------| | 1 | Starts to sequentially execute the commands (Continuous mode) | | 0 | Stops executing the commands | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 805 **Peripheral Trigger Generator (PTG)** ## Bit 6 - PTGWDTO PTG Watchdog Timer Time-out Status bit | Value | Description | |-------|--------------------------------------| | 1 | PTG Watchdog Timer has timed out | | 0 | PTG Watchdog Timer has not timed out | ## Bit 5 - PTGBUSY PTG State Machine Busy bit | Value | Description | |-------|------------------------------------------------------------------------------------------| | 1 | PTG is running on the selected clock source; no SFR writes are allowed to PTGCLK[2:0] or | | | PTGDIV[4:0] | | 0 | PTG state machine is not running | ## Bits 1:0 – PTGITM[1:0] PTG Input Trigger Operation Selection bits<sup>(1)</sup> | Value | Description | |-------|---------------------------------------------------------------------------------------------------| | 11 | Single-level detect with Step delay not executed on exit of command (regardless of the PTGCTRL | | | command) (Mode 3) | | 10 | Single-level detect with Step delay executed on exit of command (Mode 2) | | 01 | Continuous edge detect with Step delay not executed on exit of command (regardless of the PTGCTRL | | | command) (Mode 1) | | 00 | Continuous edge detect with Step delay executed on exit of command (Mode 0) | ## 24.2.2 PTG Control/Status Register Name: PTGCON Offset: 0x902 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|-------------|-------|---------|-----|-------------|-----|-------------|-----|--| | | PTGCLK[2:0] | | | | PTGDIV[4:0] | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PTGPV | VD[3:0] | | | | PTGWDT[2:0] | | | | Access | R/W | R/W | R/W | R/W | | R/W | R/W | R/W | | | Reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | ## Bits 15:13 - PTGCLK[2:0] PTG Module Clock Source Selection bits | Value | Description | |-------|-----------------------------------| | 111 | CLC1 output | | 110 | F <sub>VCO</sub> /4 | | 101 | Reserved | | 100 | Reserved | | 011 | Input from Timer1 Clock pin, T1CK | | 010 | ADC clock | | 001 | F <sub>CY</sub> | | 000 | F <sub>P</sub> | ### Bits 12:8 - PTGDIV[4:0] PTG Module Clock Prescaler (Divider) bits | Value | Description | |-------|--------------| | 11111 | Divide-by-32 | | 11110 | Divide-by-31 | | | | | 00001 | Divide-by-2 | | 00000 | Divide-by-1 | ## Bits 7:4 - PTGPWD[3:0] PTG Trigger Output Pulse-Width (in PTG clock cycles) bits | Value | Description | |-------|--------------------------------------------------| | 1111 | All trigger outputs are 16 PTG clock cycles wide | | 1110 | All trigger outputs are 15 PTG clock cycles wide | | | | | 0001 | All trigger outputs are 2 PTG clock cycles wide | | 0000 | All trigger outputs are 1 PTG clock cycle wide | #### Bits 2:0 - PTGWDT[2:0] PTG Watchdog Timer Time-out Selection bits | Value | Description | |-------|---------------------------------------------------| | 111 | Watchdog Timer will time out after 512 PTG clocks | | 110 | Watchdog Timer will time out after 256 PTG clocks | | 101 | Watchdog Timer will time out after 128 PTG clocks | | 100 | Watchdog Timer will time out after 64 PTG clocks | | 011 | Watchdog Timer will time out after 32 PTG clocks | | 010 | Watchdog Timer will time out after 16 PTG clocks | | 001 | Watchdog Timer will time out after 8 PTG clocks | | 000 | Watchdog Timer is disabled | **Peripheral Trigger Generator (PTG)** ## 24.2.3 PTG Broadcast Trigger Enable Register Low Name: PTGBTEL<sup>(1)</sup> Offset: 0x904 #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-------|---------|-----|-----|-----| | | | | | PTGBT | E[15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PTGB | TE[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bits 15:0 - PTGBTE[15:0] PTG Broadcast Trigger Enable bits | Value | Description | | | | | | |-------|------------------------------------------------------------------|--|--|--|--|--| | 1 | Generates trigger when the broadcast command is executed | | | | | | | 0 | Does not generate trigger when the broadcast command is executed | | | | | | **Peripheral Trigger Generator (PTG)** ## 24.2.4 PTG Broadcast Trigger Enable Low Register Name: PTGBTEH<sup>(1)</sup> Offset: 0x906 #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-----|---------------|-----|-----|---------------|-----|-----|-----|--|--|--| | | | PTGBTE[31:24] | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | PTGBTE[23:17] | | | | | | | | Access | | R/W | | | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | ## Bits 15:8 - PTGBTE[31:24] PTG Broadcast Trigger Enable bits | Value | Description | |-------|------------------------------------------------------------------| | 1 | Generates trigger when the broadcast command is executed | | 0 | Does not generate trigger when the broadcast command is executed | ## Bits 6:0 - PTGBTE[23:17] PTG Broadcast Trigger Enable bits | Value | Description | |-------|------------------------------------------------------------------| | 1 | Generates trigger when the broadcast command is executed | | 0 | Does not generate trigger when the broadcast command is executed | **Peripheral Trigger Generator (PTG)** ## 24.2.5 PTG Hold Register Name: PTGHOLD<sup>(1)</sup> Offset: 0x908 #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|---------------|-----|-----|-------|----------|-----|-----|-----|--|--| | | PTGHOLD[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PTGHO | DLD[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | ## Bits 15:0 - PTGHOLD[15:0] PTG General Purpose Hold Register bits This register holds the user-supplied data to be copied to the PTGTxLIM, PTGCxLIM, PTGSDLIM or PTGL0 register using the PTGCOPY command. Peripheral Trigger Generator (PTG) ## 24.2.6 PTG Timer0 Limit Register Name: PTGT0LIM<sup>(1)</sup> Offset: 0x90C #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|-------|----------|-----|-----|-----|--|--| | | PTGT0LIM[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PTGT0 | LIM[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | **Bits 15:0 – PTGT0LIM[15:0]** PTG Timer0 Limit Register bits General Purpose Timer0 Limit register. Peripheral Trigger Generator (PTG) # 24.2.7 PTG Timer1 Limit Register Name: PTGT1LIM<sup>(1)</sup> Offset: 0x910 #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----------------|-----|-----|-------|----------|-----|-----|-----|--|--|--| | | PTGT1LIM[15:8] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | PTGT1 | LIM[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | **Bits 15:0 – PTGT1LIM[15:0]** PTG Timer1 Limit Register bits General Purpose Timer1 Limit register. **Peripheral Trigger Generator (PTG)** ## 24.2.8 PTG Step Delay Limit Register Name: PTGSDLIM<sup>(1)</sup> Offset: 0x914 #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--|--| | | PTGSDLIM[15:8] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PTGSDLIM[7:0] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | ## Bits 15:0 - PTGSDLIM[15:0] PTG Step Delay Limit Register bits This register holds a PTG Step delay value representing the number of additional PTG clocks between the start of a Step command and the completion of a Step command. **Peripheral Trigger Generator (PTG)** ## 24.2.9 PTG Counter 0 Limit Register Name: PTGC0LIM<sup>(1)</sup> Offset: 0x918 #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--| | | PTGC0LIM[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PTGC0LIM[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | ## Bits 15:0 - PTGC0LIM[15:0] PTG Counter 0 Limit Register bits This register is used to specify the loop count for the PTGJMPC0 Step command or as a Limit register for the General Purpose Counter 0. **Peripheral Trigger Generator (PTG)** ## 24.2.10 PTG Counter 1 Limit Register Name: PTGC1LIM<sup>(1)</sup> Offset: 0x91C #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|----------------|-----|-----|-----|-----|-----|-----|-----|--|--|--| | | PTGC1LIM[15:8] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | PTGC1LIM[7:0] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | ## Bits 15:0 - PTGC1LIM[15:0] PTG Counter 1 Limit Register bits This register is used to specify the loop count for the PTGJMPC1 Step command or as a Limit register for the General Purpose Counter 1. **Peripheral Trigger Generator (PTG)** # 24.2.11 PTG Adjust Register Name: PTGADJ<sup>(1)</sup> Offset: 0x920 #### Note: 1. These bits are read-only when the module is executing Step commands. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|--------------|-----|-----|-------|---------|-----|-----|-----|--|--| | | PTGADJ[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PTGAI | DJ[7:0] | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | ## Bits 15:0 - PTGADJ[15:0] PTG Adjust Register bits This register holds the user-supplied data to be added to the PTGTxLIM, PTGCxLIM, PTGSDLIM or PTGL0 register using the PTGADD command. **Peripheral Trigger Generator (PTG)** ## 24.2.12 PTG Literal 0 Register Name: PTGL0<sup>(1,2)</sup> Offset: 0x924 #### Notes: 1. These bits are read-only when the module is executing Step commands. 2. The PTG strobe output is typically connected to the ADC Channel Select register. This allows the PTG to directly control ADC channel switching. See the specific device data sheet for connections of the PTG output. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|-------------|-----|-----|------|---------|-----|-----|-----|--|--|--| | | PTGL0[15:8] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | PTGL | .0[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:0 - PTGL0[15:0] PTG Literal 0 Register bits This register holds the 6-bit value to be written to the CNVCHSEL[5:0] bits (ADCON3L[5:0]) with the PTGCTRL Step command. **Peripheral Trigger Generator (PTG)** ## 24.2.13 PTG Step Queue Pointer Register Name: PTGQPTR<sup>(1)</sup> Offset: 0x928 #### Note: 1. These bits are read-only when the module is executing Step commands. Bits 4:0 - PTGQPTR[4:0] PTG Step Queue Pointer Register bits This register points to the currently active Step command in the Step queue. ## 24.2.14 PTG Step Queue n Pointer Register (n = 0-15) Name: PTGQUEn<sup>(1)</sup> **Offset:** 0x930, 0x934, 0x938, 0x93C, 0x940, 0x944, 0x948, 0x94C #### Notes: - 1. These bits are read-only when the module is executing Step commands. - 2. Refer to Table 24-1 for the Step command encoding. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|---------------|-----|-----|------|---------|-----|-----|-----|--|--|--| | | STEP2n+1[7:0] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | STEP | 2n[7:0] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | #### Bits 15:8 - STEP2n+1[7:0] PTG Command 2n+1 bits(2) A queue location for storage of the STEP2n+1 command byte, where 'n' is from PTGQUEn. ## Bits 7:0 - STEP2n[7:0] PTG Command 2n bits(2) A queue location for storage of the STEP2n command byte, where 'n' is the odd numbered Step Queue Pointers. ## 24.3 PTG Step Commands Table 24-1. PTG Step Command Format and Description | Step Command Byte | | | | | |-------------------|-------|---------|-------|--| | STEPx[7:0] | | | | | | CME | [3:0] | OPTION[ | 3:0] | | | bit 7 | bit 4 | bit 3 | bit 0 | | #### **Table 24-2. PTG Command Options** | bit 7-4 | Step Command | CMD[3:0] | Command Description | |---------|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PTGCTRL | 0000 | Execute the control command as described by the OPTION[3:0] bits. | | | PTGADD | 0001 | Add contents of the PTGADJ register to the target register as described by the OPTION[3:0] bits. | | | PTGCOPY | | Copy contents of the PTGHOLD register to the target register as described by the OPTION[3:0] bits. | | | PTGSTRB | 001x | Copy the values contained in the bits, CMD[0]:OPTION[3:0], to the strobe output bits[4:0]. | | | PTGWHI | 0100 | Wait for a low-to-high edge input from a selected PTG trigger input as described by the OPTION[3:0] bits. | | | PTGWLO | 0101 | Wait for a high-to-low edge input from a selected PTG trigger input as described by the OPTION[3:0] bits. | | | _ | 0110 | Reserved; do not use. <sup>(1)</sup> | | | PTGIRQ | 0111 | Generate individual interrupt request as described by the OPTION[3:0] bits. | | | PTGTRIG | 100x | Generate individual trigger output as described by the bits, CMD[0]:OPTION[3:0]. | | | PTGJMP | 101x | Copy the values contained in the bits, CMD[0]:OPTION[3:0], to the PTGQPTR register and jump to that Step queue. | | | PTGJMPC0 | PTGJMPC0 110x | PTGC0 = PTGC0LIM: Increment the PTGQPTR register. | | | | | PTGC0 ≠ PTGC0LIM: Increment Counter 0 (PTGC0) and copy the values contained in the bits, CMD[0]:OPTION[3:0], to the PTGQPTR register, and jump to that Step queue. | | | PTGJMPC1 | 111x | PTGC1 = PTGC1LIM: Increment the PTGQPTR register. | | | | | PTGC1 ≠ PTGC1LIM: Increment Counter 1 (PTGC1) and copy the values contained in the bits, CMD[0]:OPTION[3:0], to the PTGQPTR register, and jump to that Step queue. | # Peripheral Trigger Generator (PTG) | PTGCTRL(1) | 0000 | NOP. | |------------------------|------|--------------------------------------------------------------------------------------| | | 0001 | Reserved; do not use. | | | 0010 | Disable Step delay timer (PTGSD). | | | 0011 | Reserved; do not use. | | | 0100 | Reserved; do not use. | | | 0101 | Reserved; do not use. | | | 0110 | Enable Step delay timer (PTGSD). | | | 0111 | Reserved; do not use. | | | 1000 | Start and wait for the PTG Timer0 to match the PTGT0LIM register. | | | 1001 | Start and wait for the PTG Timer1 to match the PTGT1LIM register. | | | 1010 | Wait for the software trigger (level, PTGSWT = 1). | | | 1011 | Wait for the software trigger (positive edge, PTGSWT = 0 to 1). | | | 1100 | | | | | Copy the PTGC0LIM register contents to the strobe output. | | | 1101 | Copy the PTGC1LIM register contents to the strobe output. | | | 1110 | Copy the PTGL0 register contents to the strobe output. | | (1) | 1111 | Generate the triggers indicated in the PTGBTE register. | | PTGADD(1) | 0000 | Add the PTGADJ register contents to the PTGC0LIM register. | | | 0001 | Add the PTGADJ register contents to the PTGC1LIM register. | | _ | 0010 | Add the PTGADJ register contents to the PTGT0LIM register. | | | 0011 | Add the PTGADJ register contents to the PTGT1LIM register. | | _ | 0100 | Add the PTGADJ register contents to the PTGSDLIM register. | | | 0101 | Add the PTGADJ register contents to the PTGL0 register. | | _ | 0110 | Reserved; do not use. | | 10 | 0111 | Reserved; do not use. | | PTGCOPY(1) | 1000 | Copy the PTGHOLD register contents to the PTGC0LIM register. | | | 1001 | Copy the PTGHOLD register contents to the PTGC1LIM register. | | | 1010 | Copy the PTGHOLD register contents to the PTGT0LIM register. | | | 1011 | Copy the PTGHOLD register contents to the PTGT1LIM register. | | | 1100 | Copy the PTGHOLD register contents to the PTGSDLIM register. | | | 1101 | Copy the PTGHOLD register contents to the PTGL0 register. | | | 1110 | Reserved; do not use. | | | 1111 | Reserved; do not use. | | PTGWHI(1) or PTGWLO(1) | 0000 | PTGI0 (see Table 24-3 for input assignments). | | | ••• | <b></b> | | | 1111 | PTGI15 (see Table 24-3 for input assignments). | | PTGIRQ(1) | 0000 | Generate PTG Interrupt 0. | | | ••• | | | | 0111 | Generate PTG Interrupt 7. | | | 1000 | Reserved; do not use. | | | | | | - | | | | | | Reserved; do not use. | | PTGTRIG | | PTG00 (see Table 24-4 for input assignments). | | | | PTGO1 (see Table 24-4 for input assignments). | | | ••• | ••• | | | 1110 | PTGO30 (see Table 24-4 for input assignments). | | | 1111 | PTGO31 (see Table 24-4 for input assignments). | | PTGWHI(1) or PTGWLO(1) | 0000 | PTGI0 (see specific device data sheet for interrupt assignments). | | | ••• | | | | 1111 | PTGI15 (see specific device data sheet for interrupt assignments). | | PTGIRQ(1) | 0000 | Generate PTG Interrupt 0 (see specific device data sheet for interrupt assignments). | | | ••• | | | | 2444 | | | | 0111 | Generate PTG Interrupt 7 (see specific device data sheet for interrupt assignments). | | | 1000 | Reserved; do not use. | | | ••• | | | | 1111 | Reserved; do not use. | | PTGTRIG | 0000 | PTG00 (see specific device data sheet for interrupt assignments). | | | 0001 | PTGO1 (see specific device data sheet for interrupt assignments). | © 2021 Microchip Technology Inc. and its subsidiaries Table 24-3. PTG Input Descriptions | PTG Input Number | PTG Input Description | |----------------------|----------------------------------------| | PTG Trigger Input 0 | Trigger Input from PWM1 ADC Trigger 2 | | PTG Trigger Input 1 | Trigger Input from PWM2 ADC Trigger 2 | | PTG Trigger Input 2 | Trigger Input from PWM3 ADC Trigger 2 | | PTG Trigger Input 3 | Trigger Input from PWM4 ADC Trigger 2 | | PTG Trigger Input 4 | Trigger Input from PWM5 ADC Trigger 2 | | PTG Trigger Input 5 | Trigger Input from PWM6 ADC Trigger 2 | | PTG Trigger Input 6 | Trigger Input from PWM7 ADC Trigger 2 | | PTG Trigger Input 7 | Trigger Input from SCCP4 | | PTG Trigger Input 8 | Trigger Input from SCCP4 | | PTG Trigger Input 9 | Trigger Input from Comparator 1 | | PTG Trigger Input 10 | Trigger Input from Comparator 2 | | PTG Trigger Input 11 | Trigger Input from Comparator 3 | | PTG Trigger Input 12 | Trigger Input from CLC1 | | PTG Trigger Input 13 | Trigger Input ADC Done Group Interrupt | | PTG Trigger Input 14 | Trigger Input from CLC2 | | PTG Trigger Input 15 | Trigger Input from INT2 PPS | Table 24-4. PTG Output Descriptions | PTG Output Number | PTG Output Description | |-------------------|------------------------| | PTGO0 to PTGO11 | Reserved | | PTGO12 | ADC TRGSRC[30] | | PTGO13 to PTGO23 | Reserved | | PTGO24 | PPS Output RP46 | | PTGO25 | PPS Output RP47 | | PTGO26 | PPS Input RP6 | | PTGO27 | PPS Input RP7 | | PTGO28 to PTGO31 | Reserved | # 25. 32-Bit Programmable Cyclic Redundancy Check (CRC) Generator **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. For more information, refer to "32-Bit Programmable Cyclic Redundancy Check (CRC)" (www.microchip.com/ DS30009729) in the "dsPIC33/PIC24 Family Reference Manual". The 32-bit programmable CRC generator provides a hardware implemented method of quickly generating checksums for various networking and security applications. It offers the following features: - · User-Programmable CRC Polynomial Equation, Up to 32 Bits - · Programmable Shift Direction (little or big-endian) - · Independent Data and Polynomial Lengths - · Configurable Interrupt Output - Data FIFO Figure 25-1 displays a simplified block diagram of the CRC generator. Figure 25-1. CRC Module Block Diagram 32-Bit Programmable Cyclic Redundancy Check ... # 25.1 CRC Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|--------------|----------|--------|--------|---------|------------------|----------|-----------|---|---|--| | 000 | CRCCONL | 15:8 | CRCEN | | CSIDL | CSIDL VWORD[4:0] | | | | | | | 0xB0 | CRCCONL | 7:0 | CRCFUL | CRCMPT | CRCISEL | CRCGO | LENDIAN | MOD | | | | | 0xB2 | CRCCONH | 15:8 | | | | DWIDTH[4:0] | | | | | | | | CRCCONH | 7:0 | | | | | | PLEN[4:0] | | | | | 0xB4 | CRCXORL | 15:8 | | | | X[1 | 5:8] | | | | | | 0.004 | CROXORL | 7:0 | | X[7:1] | | | | | | | | | 0xB6 | 0xB6 CRCXORH | 15:8 | | | | | X[31:24] | | | | | | | CROXORH | 7:0 | | | | X[23:16] | | | | | | # 32-Bit Programmable Cyclic Redundancy Check ... ## 25.1.1 CRC Control Register Low Name: CRCCONL Offset: 0x0B0 Legend: HC = Hardware Clearable bit, HSC = Hardware Settable/Clearable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|---------|--------|---------|------------|-------|-------| | | CRCEN | | CSIDL | | | VWORD[4:0] | | | | Access | R/W | | R/W | HSC/R | HSC/R | HSC/R | HSC/R | HSC/R | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CRCFUL | CRCMPT | CRCISEL | CRCGO | LENDIAN | MOD | | | | Access | HSC/R | HSC/R | R/W | HC/R/W | R/W | R/W | | | | Reset | 0 | 1 | 0 | 0 | 0 | 0 | | | #### Bit 15 - CRCEN CRC Enable bit | Val | lue | Description | |-----|-----|-----------------| | 1 | | Enables module | | 0 | | Disables module | #### Bit 13 - CSIDL CRC Stop in Idle Mode bit | Value | Description | |-------|------------------------------------------------------------| | 1 | Discontinues module operation when device enters Idle mode | | 0 | Continues module operation in Idle mode | ## Bits 12:8 - VWORD[4:0] Pointer Value bits Indicates the number of valid words in the FIFO. Has a maximum value of 8 when PLEN[4:0] $\geq$ 7 or 16 when PLEN[4:0] $\leq$ 7. #### Bit 7 - CRCFUL CRC FIFO Full bit | Value | Description | |-------|------------------| | 1 | FIFO is full | | 0 | FIFO is not full | ## Bit 6 - CRCMPT CRC FIFO Empty bit | Dit 0 - Oi | Bit 0 - OROMI T OROTH O Empty bit | | | | | |------------|-----------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | FIFO is empty | | | | | | 0 | FIFO is not empty | | | | | #### Bit 5 - CRCISEL CRC Interrupt Selection bit | Value | Description | |-------|--------------------------------------------------------------------------------------| | 1 | Interrupt on FIFO is empty; the final word of data is still shifting through the CRC | | 0 | Interrupt on shift is complete and results are ready | ## Bit 4 - CRCGO CRC Start bit | Value | Description | |-------|----------------------------------| | 1 | Starts CRC serial shifter | | 0 | CRC serial shifter is turned off | ### Bit 3 - LENDIAN Data Shift Direction Select bit | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | Data word is shifted into the FIFO, starting with the LSb (little-endian) | | 0 | Data word is shifted into the FIFO, starting with the MSb (big-endian) | © 2021 Microchip Technology Inc. Datasheet 70005452B-page 824 32-Bit Programmable Cyclic Redundancy Check ... | Dit 2 | MOD | <b>CRC Calculation Mode</b> | hit | |---------|-----|-----------------------------|-----| | DIL Z - | MOD | CRC Calculation Wode | DIL | | Value | Description | |-------|-----------------| | 1 | Alternate mode | | 0 | Legacy mode bit | 32-Bit Programmable Cyclic Redundancy Check ... ## 25.1.2 CRC Control Register High Name: CRCCONH Offset: 0x0B2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-------------|-----|-----------|-----|-----| | | | | | DWIDTH[4:0] | | | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | PLEN[4:0] | | | | Access | | | | R/W | R/W | R/W | R/W | R/W | | Reset | | | | 0 | 0 | 0 | 0 | 0 | **Bits 12:8 – DWIDTH[4:0]** Data Word Width Configuration bits Configures the width of the data word (Data Word Width – 1). **Bits 4:0 – PLEN[4:0]** Polynomial Length Configuration bits Configures the length of the polynomial (Polynomial Length – 1). 32-Bit Programmable Cyclic Redundancy Check ... ## 25.1.3 CRC XOR Polynomial Register, Low Byte Name: CRCXORL Offset: 0x0B4 | Bit_ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|---------|-----|-----|--------|-----|-----|-----|-----|--|--| | | X[15:8] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Γ | | | | X[7:1] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bits 15:8 – X[15:8] XOR of Polynomial Term x<sup>n</sup> Enable bits Bits 7:1 – X[7:1] XOR of Polynomial Term x<sup>n</sup> Enable bits 32-Bit Programmable Cyclic Redundancy Check ... # 25.1.4 CRC XOR Polynomial Register, High Byte Name: CRCXORH Offset: 0x0B6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|----------|-----|-----|-----|-----|-----|-----|-----|--| | | X[31:24] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | X[23:16] | | | | | | | | | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bits 15:0 - X[31:16] XOR of Polynomial Term x<sup>n</sup> Enable bits **Current Bias Generator (CBG)** ## 26. Current Bias Generator (CBG) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Current Bias Generator (CBG)" (www.microchip.com/DS70005253) in the "dsPIC33/PIC24 Family Reference Manual". The Current Bias Generator (CBG) consists of two classes of current sources: 10 $\mu$ A and 50 $\mu$ A sources. The major features of each current source are: - 10 μA Current Sources: - Current sourcing only - Up to four independent sources - 50 µA Current Sources: - Selectable current sourcing or sinking - Selectable current mirroring for sourcing and sinking Table 26-1. CBG Channel Availability | Package Type | ISRCx | IBIASx | |--------------|---------|---------| | 48-Pin | 0,1,2,3 | 0,1,2,3 | | 64-Pin | 0,1,2,3 | 0,1,2,3 | | 80-Pin | 0,1,2,3 | 0,1,2,3 | **Current Bias Generator (CBG)** A simplified block diagram of the CBG module is shown in Figure 26-1. Figure 26-1. Constant-Current Source Module Block Diagram<sup>(2)</sup> #### Notes: - 1. RESD is typically 300 Ohms. - 2. The ADC analog input is shown only for clarity. Each analog peripheral connected to the pin has a separate Electrostatic Discharge (ESD) resistor. **Current Bias Generator (CBG)** ## 26.1 Current Bias Generator Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------|----------|----|---|-----------|-----------|-----------|-----------|--------|--------| | 0x08F0 | BIASCON | 15:8 | ON | | | | | | | | | UXUOFU | BIASCON | 7:0 | | | | | I10EN3 | I10EN2 | I10EN1 | I10EN0 | | 0x08F2 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x08F3 | | | | | | | | | | | | 0x08F4 | IBIASCON0L | 15:8 | | | SHRSRCEN1 | SHRSNKEN1 | GENSRCEN1 | GENSNKEN1 | SRCEN1 | SNKEN1 | | 000014 | IBIAGCONUL | 7:0 | | | SHRSRCEN0 | SHRSNKEN0 | GENSRCEN0 | GENSNKEN0 | SRCEN0 | SNKEN0 | | 0x08F6 | IBIASCON0H | 15:8 | | | SHRSRCEN3 | SHRSNKEN3 | GENSRCEN3 | GENSNKEN3 | SRCEN3 | SNKEN3 | | UXUOF6 | IBIASCONUR | 7:0 | | | SHRSRCEN2 | SHRSNKEN2 | GENSRCEN2 | GENSNKEN2 | SRCEN2 | SNKEN2 | **Current Bias Generator (CBG)** ## 26.1.1 Current Bias Generator Control Register Name: BIASCON Offset: 0x8F0 #### Bit 15 - ON Current Bias Module Enable bit | Value | Description | |-------|--------------------| | 1 | Module is enabled | | 0 | Module is disabled | ### Bit 3 - I10EN3 10 µA Enable for Output 3 bit | Value | Description | |-------|--------------------------| | 1 | 10 μA output is enabled | | 0 | 10 µA output is disabled | ### Bit 2 - I10EN2 10 µA Enable for Output 2 bit | Value | Description | |-------|--------------------------| | 1 | 10 μA output is enabled | | 0 | 10 µA output is disabled | ## Bit 1 – I10EN1 10 μA Enable for Output 1 bit | Value | Description | |-------|--------------------------| | 1 | 10 μA output is enabled | | 0 | 10 μA output is disabled | ## Bit 0 – I10EN0 10 μA Enable for Output 0 bit | Value | Description | |-------|--------------------------| | 1 | 10 μA output is enabled | | 0 | 10 μA output is disabled | **Current Bias Generator (CBG)** ## 26.1.2 Current Bias Generator 50 μA Current Source Control Low Register Name: IBIASCON0L Offset: 0x8F4 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----------|-----------|-----------|-----------|--------|--------| | | | | SHRSRCEN1 | SHRSNKEN1 | GENSRCEN1 | GENSNKEN1 | SRCEN1 | SNKEN1 | | Access | | , | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SHRSRCEN0 | SHRSNKEN0 | GENSRCEN0 | GENSNKEN0 | SRCEN0 | SNKEN0 | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 13 - SHRSRCEN1 Share Source Enable for Output #1 bit | Value | Description | |-------|------------------------------------------------------------------------------| | 1 | Sourcing Current Mirror mode is enabled (uses reference from another source) | | 0 | Sourcing Current Mirror mode is disabled | ### Bit 12 - SHRSNKEN1 Share Sink Enable for Output #1 bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Sinking Current Mirror mode is enabled (uses reference from another source) | | 0 | Sinking Current Mirror mode is disabled | ## Bit 11 - GENSRCEN1 Generated Source Enable for Output #1 bit | Value | Description | |-------|--------------------------------------------------------------| | 1 | Source generates the current source mirror reference | | 0 | Source does not generate the current source mirror reference | ## Bit 10 - GENSNKEN1 Generated Sink Enable for Output #1 bit | Value | Description | |-------|--------------------------------------------------------------| | 1 | Source generates the current source mirror reference | | 0 | Source does not generate the current source mirror reference | ### Bit 9 - SRCEN1 Source Enable for Output #1 bit | Value Description | | | | | |-------------------|----------------------------|--|--|--| | 1 | Current source is enabled | | | | | 0 | Current source is disabled | | | | #### Bit 8 - SNKEN1 Sink Enable for Output #1 bit | Value | Description | |-------|--------------------------| | 1 | Current sink is enabled | | 0 | Current sink is disabled | ### Bit 5 - SHRSRCEN0 Share Source Enable for Output #0 bit | Value | Description | |-------|------------------------------------------------------------------------------| | 1 | Sourcing Current Mirror mode is enabled (uses reference from another source) | | 0 | Sourcing Current Mirror mode is disabled | ### Bit 4 - SHRSNKEN0 Share Sink Enable for Output #0 bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Sinking Current Mirror mode is enabled (uses reference from another source) | | 0 | Sinking Current Mirror mode is disabled | **Current Bias Generator (CBG)** ## Bit 3 - GENSRCEN0 Generated Source Enable for Output #0 bit | Value | Description | |-------|--------------------------------------------------------------| | 1 | Source generates the current source mirror reference | | 0 | Source does not generate the current source mirror reference | ## Bit 2 - GENSNKEN0 Generated Sink Enable for Output #0 bit | Value | Description | | | | |-------|--------------------------------------------------------------|--|--|--| | 1 | Source generates the current source mirror reference | | | | | 0 | Source does not generate the current source mirror reference | | | | ### Bit 1 - SRCEN0 Source Enable for Output #0 bit | Value | Description | |-------|----------------------------| | 1 | Current source is enabled | | 0 | Current source is disabled | ### Bit 0 - SNKEN0 Sink Enable for Output #0 bit | Value | Description | |-------|--------------------------| | 1 | Current sink is enabled | | 0 | Current sink is disabled | **Current Bias Generator (CBG)** ## 26.1.3 Current Bias Generator 50 μA Current Source Control High Register Name: IBIASCON0H Offset: 0x8F6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|-----------|-----------|-----------|-----------|--------|--------| | | | | SHRSRCEN3 | SHRSNKEN3 | GENSRCEN3 | GENSNKEN3 | SRCEN3 | SNKEN3 | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SHRSRCEN2 | SHRSNKEN2 | GENSRCEN2 | GENSNKEN2 | SRCEN2 | SNKEN2 | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 13 - SHRSRCEN3 Share Source Enable for Output #3 bit | Value | Description | |-------|------------------------------------------------------------------------------| | 1 | Sourcing Current Mirror mode is enabled (uses reference from another source) | | 0 | Sourcing Current Mirror mode is disabled | #### Bit 12 - SHRSNKEN3 Share Sink Enable for Output #3 bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Sinking Current Mirror mode is enabled (uses reference from another source) | | 0 | Sinking Current Mirror mode is disabled | ### Bit 11 - GENSRCEN3 Generated Source Enable for Output #3 bit | Value | Description | |-------|--------------------------------------------------------------| | 1 | Source generates the current source mirror reference | | 0 | Source does not generate the current source mirror reference | ## Bit 10 - GENSNKEN3 Generated Sink Enable for Output #3 bit | Value | Description | |-------|--------------------------------------------------------------| | 1 | Source generates the current source mirror reference | | 0 | Source does not generate the current source mirror reference | #### Bit 9 - SRCEN3 Source Enable for Output #3 bit | Value | Description | |-------|----------------------------| | 1 | Current source is enabled | | 0 | Current source is disabled | #### Bit 8 - SNKEN3 Sink Enable for Output #3 bit | Value | Description | |-------|--------------------------| | 1 | Current sink is enabled | | 0 | Current sink is disabled | ### Bit 5 - SHRSRCEN2 Share Source Enable for Output #2 bit | Value | Description | |-------|------------------------------------------------------------------------------| | 1 | Sourcing Current Mirror mode is enabled (uses reference from another source) | | 0 | Sourcing Current Mirror mode is disabled | ## Bit 4 - SHRSNKEN2 Share Sink Enable for Output #2 bit | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | Sinking Current Mirror mode is enabled (uses reference from another source) | | 0 | Sinking Current Mirror mode is disabled | **Current Bias Generator (CBG)** ## Bit 3 - GENSRCEN2 Generated Source Enable for Output #2 bit | Value | Description | |-------|--------------------------------------------------------------| | 1 | Source generates the current source mirror reference | | 0 | Source does not generate the current source mirror reference | ## Bit 2 - GENSNKEN2 Generated Sink Enable for Output #2 bit | Value | Description | |-------|--------------------------------------------------------------| | 1 | Source generates the current source mirror reference | | 0 | Source does not generate the current source mirror reference | ### Bit 1 - SRCEN2 Source Enable for Output #2 bit | Value | Description | |-------|----------------------------| | 1 | Current source is enabled | | 0 | Current source is disabled | ### Bit 0 - SNKEN2 Sink Enable for Output #2 bit | Value | Description | |-------|--------------------------| | 1 | Current sink is enabled | | 0 | Current sink is disabled | ## 27. Operational Amplifier **Note:** Some device variants support only two op amp instances. Refer to dsPIC33CK512MP608 Product Families for availability. The dsPIC33CK512MP608 family implements three instances of operational amplifiers (op amps). The op amps can be used for a wide variety of purposes, including signal conditioning and filtering. The three op amps are functionally identical. The block diagram for a single amplifier is shown in Figure 27-1. Figure 27-1. Single Operational Amplifier Block Diagram The op amps are controlled by two SFR registers: AMPCON1L and AMPCON1H. They remain in a low-power state until the AMPON bit is set. Each op amp can then be enabled independently by setting the corresponding AMPENx bit (x = 1, 2, 3). The NCHDISx bit provides some flexibility regarding input range versus Integral Nonlinearity (INL). When NCHDISx = 0 (default), the op amps have a wider input voltage range (see 33.2 AC Characteristics and Timing Parameters in 33. Electrical Characteristics). When NCHDISx = 1, the wider input range is traded for improved INL performance (lower INL). **Operational Amplifier** ## 27.1 Operational Amplifier Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|-------|---|---|---|---|---------|---------|---------| | 0x08DC | AMPCON1L | 15:8 | AMPON | | | | | | | | | UXUODC | | 7:0 | | | | | | AMPEN3 | AMPEN2 | AMPEN1 | | 0x08DE | AMPCON1H | 15:8 | | | | | | | | | | UXUODE | | 7:0 | | | | | | NCHDIS3 | NCHDIS2 | NCHDIS1 | ## **Operational Amplifier** ## 27.1.1 Op Amp Control Register Low Name: AMPCON1L Offset: 0x8DC ## Bit 15 - AMPON Op Amp Enable/On bit | Value | Description | |-------|--------------------------------------------------------------------------| | 1 | Enables op amp modules if their respective AMPENx bits are also asserted | | 0 | Disables all op amp modules | ### Bit 2 - AMPEN3 Op Amp #3 Enable bit | Value | Description | |-------|-----------------------------------------------------| | 1 | Enables Op Amp #3 if the AMPON bit is also asserted | | 0 | Disables Op Amp #3 | ### Bit 1 - AMPEN2 Op Amp #2 Enable bit | Value | Description | |-------|-----------------------------------------------------| | 1 | Enables Op Amp #2 if the AMPON bit is also asserted | | 0 | Disables Op Amp #2 | ## Bit 0 - AMPEN1 Op Amp #1 Enable bit | Value | Description | |-------|-----------------------------------------------------| | 1 | Enables Op Amp #1 if the AMPON bit is also asserted | | 0 | Disables Op Amp #1 | ## **Operational Amplifier** ## 27.1.2 Op Amp Control Register High Name: AMPCON1H Offset: 0x8DE ## Bit 2 - NCHDIS3 Op Amp #3 N Channel Disable bit | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1 | Disables Op Amp #3 N channels input stage; reduced INL, but lowered input voltage range | | 0 | Wide input range for Op Amp #3 | ## Bit 1 - NCHDIS2 Op Amp #2 N Channel Disable bit | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1 | Disables Op Amp #2 N channels input stage; reduced INL, but lowered input voltage range | | 0 | Wide input range for Op Amp #2 | ## Bit 0 - NCHDIS1 Op Amp #1 N Channel Disable bit | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1 | Disables Op Amp #1 N channels input stage; reduced INL, but lowered input voltage range | | 0 | Wide input range for Op Amp #1 | ## 28. Deadman Timer (DMT) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**Deadman Timer (DMT)**" (www.microchip.com/DS70005155) in the "dsPIC33/PIC24 Family Reference Manual". The primary function of the Deadman Timer (DMT) is to interrupt the processor in the event of a software malfunction. The DMT, which works on the system clock, 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 DMT can be enabled in the Configuration fuse or by software in the DMTCON register by setting the ON bit. The DMT consists of a 32-bit counter with a time-out count match value, as specified by the two 16-bit Configuration Fuse registers: FDMTCNTL and FDMTCNTH. A DMT is typically used in mission-critical and safety-critical applications, where any single failure of the software functionality and sequencing must be detected. Figure 28-1 shows a block diagram of the Deadman Timer module. Figure 28-1. Deadman Timer Block Diagram #### Notes: - 1. DMT Max Count is controlled by the initial value of the FDMTCNTL and FDMTCNTH Configuration registers. - 2. DMT window interval is controlled by the value of the FDMTIVTL and FDMTIVTH Configuration registers. ## 28.1 Deadman Timer Control/Status Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------|--------------|----------|------|----------------|----------|-------|-----------|---|---|--------| | 0x5C | DMTCON | 15:8 | ON | | | | | | ĺ | | | UXSC | DIVITCON | 7:0 | | | | | | | | | | 0x5E | | | | | | | | | | | | *** | Reserved | | | | | | | | | | | 0x5F | | | | | | | | | | | | 0x60 | DMTPRECLR | 15:8 | | | | STE | P1[7:0] | | | | | 10011110-0211-5811 | DIMITITEOLIT | 7:0 | | | | | | | | | | 0x62 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x63 | | | | | | | | | | | | 0x64 | DMTCLR | 15:8 | | | | | | | | | | UNUT | DIVITOLIX | 7:0 | | | | STE | P2[7:0] | | | | | 0x66 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x67 | | | | | | | | | | | | 0x68 | DMTSTAT | 15:8 | | | | | | | | | | 101-107-103-1020 | Dim 10 1/ 11 | 7:0 | BAD1 | BAD2 | DMTEVENT | | | | | WINOPN | | 0x6A | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x6B | | | | | | | | | | | | 0x6C | DMTCNTL | 15:8 | | | | | TER[15:8] | | | | | | Jan 1 Gitte | 7:0 | | COUNTER[7:0] | | | | | | | | 0x6E | DMTCNTH | 15:8 | | COUNTER[31:24] | | | | | | | | OXOL | Billiolitiii | 7:0 | | COUNTER[23:16] | | | | | | | | 0x70 | HOLDREG(1) | 15:8 | | | | | NT[15:8] | | | | | 933435 10 | TIOLDINEO(1) | 7:0 | | | | UPRO | NT[7:0] | | | | | 0x72 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x73 | | | | | | | | | | | | 0x74 | PSCNTL | 15:8 | | | | | IT[15:8] | | | | | OXIT | TOOMIE | 7:0 | | | | | NT[7:0] | | | | | 0x76 | PSCNTH | 15:8 | | | | | T[31:24] | | | | | 0,10 | 1001111 | 7:0 | | | | | T[23:16] | | | | | 0x78 | PSINTVL | 15:8 | | | | | ΓV[15:8] | | | | | UXTO | FOINTVL | 7:0 | | | | | TV[7:0] | | | | | 0x7A | PSINTVH | 15:8 | | | | PSINT | V[31:24] | | | | | UXIA | POINTVH | 7:0 | | | | PSINT | V[23:16] | | | | **Deadman Timer (DMT)** ## 28.1.1 Deadman Timer Control Register Name: DMTCON Offset: 0x05C Legend: SO = Settable Only bit Note: 1. This bit has control only when DMTDIS = 0 in the FDMT register. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|------|----|----|----|----|----|---|---| | | ON | | | | | | | | | Access | R/SO | | | | | | | | | Access<br>Reset | 0 | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset ### Bit 15 - ON DMT Enable bit(1) | Value | Description | |-------|-------------------------------------| | 1 | Deadman Timer module is enabled | | 0 | Deadman Timer module is not enabled | **Deadman Timer (DMT)** ## 28.1.2 Deadman Timer Preclear Register Name: DMTPRECLR Offset: 0x060 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|-----|-----|-----|-----|-----|-----|-----| | | STEP1[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | Access Reset Bits 15:8 - STEP1[7:0] DMT Preclear Enable bits | Value | Description | |-----------------|-----------------------------------------------------------------------------------------------| | 01000000 | Enables the Deadman Timer preclear (Step 1) | | All Other Write | Sets the BAD1 flag; these bits are cleared when a DMT Reset event occurs. STEP1[7:0] | | Patterns | bits are also cleared if the STEP2[7:0] bits are loaded with the correct value in the correct | | | sequence. | **Deadman Timer (DMT)** ## 28.1.3 Deadman Timer Clear Register Name: DMTCLR Offset: 0x064 Bits 7:0 - STEP2[7:0] DMT Clear Timer bits | Value | Description | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00001000 | Clears STEP1[7:0], STEP2[7:0] and the Deadman Timer if preceded by the correct loading of the STEP1[7:0] bits in the correct sequence. The write to these bits may be verified by reading the DMTCNTL/H registers and observing the counter being reset. | | All Other | Sets the BAD2 bit; the value of STEP1[7:0] will remain unchanged and the new value being | | Write | written to STEP2[7:0] will be captured. These bits are cleared when a DMT Reset event occurs. | | Patterns | | **Deadman Timer (DMT)** ## 28.1.4 Deadman Timer Status Register Name: DMTSTAT Offset: 0x068 ### Bit 7 - BAD1 Deadman Timer Bad STEP1[7:0] Value Detect bit | Value | Description | |-------|---------------------------------------------| | 1 | Incorrect STEP1[7:0] value was detected | | 0 | Incorrect STEP1[7:0] value was not detected | ### Bit 6 - BAD2 Deadman Timer Bad STEP2[7:0] Value Detect bit | Value | Description | |-------|---------------------------------------------| | 1 | Incorrect STEP2[7:0] value was detected | | 0 | Incorrect STEP2[7:0] value was not detected | ### Bit 5 - DMTEVENT Deadman Timer Event bit | Value | Description | |-------|----------------------------------------------------------------------------------------------| | 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 event was not detected | ## Bit 0 - WINOPN Deadman Timer Clear Window bit | Value | Description | |-------|----------------------------------------| | 1 | Deadman Timer clear window is open | | 0 | Deadman Timer clear window is not open | **Deadman Timer (DMT)** ## 28.1.5 Deadman Timer Count Register Low Name: DMTCNTL Offset: 0x06C | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|---------------|-----|-----|-------|---------|-----|-----|-----|--|--|--|--| | | COUNTER[15:8] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | COUNT | ER[7:0] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - COUNTER[15:0] Read Current Contents of Lower DMT Counter bits **Deadman Timer (DMT)** ## 28.1.6 Deadman Timer Count Register High Name: DMTCNTH Offset: 0x06E | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|----------------|-----|-----|--------|-----------|-----|-----|-----|--|--|--|--| | | COUNTER[31:24] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | COUNTE | ER[23:16] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - COUNTER[31:16] Read Current Contents of Higher DMT Counter bits **Deadman Timer (DMT)** ## 28.1.7 DMT Hold Register Name: HOLDREG<sup>(1)</sup> Offset: 0x070 #### Note: 1. The DMTHOLDREG register is initialized to '0' on Reset, and is only loaded when the DMTCNTL and DMTCNTH registers are read. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|--------------|-----|-----|-------|---------|-----|-----|-----|--|--|--|--| | | UPRCNT[15:8] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | UPRCI | NT[7:0] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - UPRCNT[15:0] DMTCNTH Register Value when DMTCNTL and DMTCNTH were Last Read bits **Deadman Timer (DMT)** ## 28.1.8 DMT Post-Configure Count Status Register Low Name: PSCNTL Offset: 0x074 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-------------|-----|-----|------|---------|-----|-----|-----|--|--|--|--| | | PSCNT[15:8] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | PSCN | IT[7:0] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | **Bits 15:0 – PSCNT[15:0]** Lower DMT Instruction Count Value Configuration Status bits This is always the value of the FDMTCNTL Configuration register. **Deadman Timer (DMT)** ## 28.1.9 DMT Post-Configure Count Status Register High Name: PSCNTH Offset: 0x076 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|--------------|-----|-----|-------|---------|-----|-----|-----|--|--|--|--| | | PSCNT[31:24] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | PSCNT | [23:16] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | **Bits 15:0 – PSCNT[31:16]** Higher DMT Instruction Count Value Configuration Status bits This is always the value of the FDMTCNTH Configuration register. Deadman Timer (DMT) ## 28.1.10 DMT Post-Configure Interval Status Register Low Name: PSINTVL Offset: 0x078 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|--------------|-----|-----|-------|--------|-----|-----|-----|--|--|--|--| | | PSINTV[15:8] | | | | | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | PSINT | V[7:0] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | **Bits 15:0 – PSINTV[15:0]** Lower DMT Window Interval Configuration Status bits This is always the value of the FDMTIVTL Configuration register. **Deadman Timer (DMT)** ## 28.1.11 DMT Post-Configure Interval Status Register High Name: PSINTVH Offset: 0x07A | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|---------------|-----|-----|--------|----------|-----|-----|-----|--|--|--| | | PSINTV[31:24] | | | | | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | PSINT\ | /[23:16] | | | | | | | | Access | R/W | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | **Bits 15:0 – PSINTV[31:16]** Higher DMT Window Interval Configuration Status bits This is always the value of the FDMTIVTH Configuration register. ## 29. Power-Saving Features **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**Watchdog Timer and Power-Saving Modes**" (www.microchip.com/DS70615) in the "dsPIC33/PIC24 Family Reference Manual". The dsPIC33CK512MP608 family devices provide the ability to manage power consumption by selectively managing clocking to the CPU and the peripherals. In general, a lower clock frequency and a reduction in the number of peripherals being clocked constitutes lower consumed power. dsPIC33CK512MP608 family devices can manage power consumption in four ways: - Clock Frequency - · Instruction-Based Sleep and Idle modes - Software-Controlled Doze mode - · Selective Peripheral Control in Software Combinations of these methods can be used to selectively tailor an application's power consumption while still maintaining critical application features, such as timing-sensitive communications. ## 29.1 Clock Frequency and Clock Switching The dsPIC33CK512MP608 family devices allow a wide range of clock frequencies to be selected under application control. If the system clock configuration is not locked, users can choose low-power or high-precision oscillators by simply changing the NOSCx bits (OSCCON[10:8]). The process of changing a system clock during operation, as well as limitations to the process, are discussed in more detail in 9. Oscillator with High-Frequency PLL. ## 29.2 Instruction-Based Power-Saving Modes The dsPIC33CK512MP608 family devices have two special power-saving modes that are entered through the execution of a special PWRSAV instruction. Sleep mode stops clock operation and halts all code execution. Idle mode halts the CPU and code execution, but allows peripheral modules to continue operation. The assembler syntax of the PWRSAV instruction is shown in Example 29-1 and Example 29-2. $\textbf{Note:} \ \ \texttt{SLEEP\_MODE} \ \ \textbf{and} \ \ \texttt{IDLE\_MODE} \ \ \textbf{are constants defined in the assembler include file for the selected device}.$ Sleep and Idle modes can be exited as a result of an enabled interrupt, WDT time-out or a device Reset. When the device exits these modes, it is said to "wake-up". ``` Example 29-1. PWRSAV Instruction Syntax in Assembly PWRSAV #SLEEP_MODE ; Put the device into Sleep mode PWRSAV #IDLE_MODE ; Put the device into Idle mode ``` ``` Example 29-2. PWRSAV Instruction Syntax in C Language Sleep() // Put the device into Sleep mode Idle () // Put the device into Idle mode ``` #### 29.2.1 Sleep Mode The following occurs in Sleep mode: - The system clock source is shut down. If an on-chip oscillator is used, it is turned off. - The device current consumption is reduced to a minimum, provided that no I/O pin is sourcing current. - · The Fail-Safe Clock Monitor does not operate, since the system clock source is disabled. - The WDT, if enabled, is automatically cleared prior to entering Sleep or Idle mode. - Some device features or peripherals can continue to operate. This includes items such as the Input Change Notification on the I/O ports or peripherals that use an External Clock input. - Any peripheral that requires the system clock source for its operation is disabled. The device wakes up from Sleep mode on any of these events: - · Any interrupt source that is individually enabled - · Any form of device Reset - A WDT time-out On wake-up from Sleep mode, the processor restarts with the same clock source that was active when Sleep mode was entered. For optimal power savings, the internal regulator and the Flash regulator can be configured to go into standby when Sleep mode is entered by clearing the VREGS (RCON[8]) bit (default configuration). If the application requires a faster wake-up time and can accept higher current requirements, the VREGS (RCON[8]) bit can be set to keep the internal regulator and the Flash regulator active during Sleep mode. The available Low-Power Sleep modes are shown in Table 29-1. Additional regulator information is available in 30.5 On-Chip Voltage Regulators. Table 29-1. Low-Power Sleep Modes | Relative Power | LPWREN | VREGS | Mode | | |----------------|-------------|-------|---------------------|--| | Highest | 0 | 1 | Full power, active | | | _ | 0 | 0 | Full power, standby | | | _ | <b>1(1)</b> | 1 | Low power, active | | | Lowest | 1(1) | 0 | Low power, standby | | #### Note: 1. Low-Power modes, when LPWREN = 1, can only be used in the industrial temperature range. #### 29.2.2 Idle Mode The following occurs in Idle mode: - The CPU stops executing instructions. - The WDT is automatically cleared. - The system clock source remains active. By default, all peripheral modules continue to operate normally from the system clock source, but can also be selectively disabled (see 29.4 Peripheral Module Disable). The device wakes up from Idle mode on any of these events: - · Any interrupt that is individually enabled - Any device Reset - A WDT time-out On wake-up from Idle mode, the clock is reapplied to the CPU and instruction execution will begin (two to four clock cycles later), starting with the instruction following the PWRSAV instruction or the first instruction in the ISR. All peripherals also have the option to discontinue operation when Idle mode is entered to allow for increased power savings. This option is selectable in the control register of each peripheral; for example, the SIDL bit in the Timer1 Control register (T1CON[13]). **Power-Saving Features** #### 29.2.3 Interrupts Coincident with Power Save Instructions Any interrupt that coincides with the execution of a PWRSAV instruction is held off until entry into Sleep or Idle mode has completed. The device then wakes up from Sleep or Idle mode. #### 29.3 Doze Mode The preferred strategies for reducing power consumption are changing clock speed and invoking one of the power-saving modes. In some circumstances, this cannot be practical. For example, it may be necessary for an application to maintain uninterrupted synchronous communication, even while it is doing nothing else. Reducing system clock speed can introduce communication errors, while using a power-saving mode can stop communications completely. Doze mode is a simple and effective alternative method to reduce power consumption while the device is still executing code. In this mode, the system clock continues to operate from the same source and at the same speed. Peripheral modules continue to be clocked at the same speed, while the CPU clock speed is reduced. Synchronization between the two clock domains is maintained, allowing the peripherals to access the SFRs while the CPU executes code at a slower rate. Doze mode is enabled by setting the DOZEN bit (CLKDIV[11]). The ratio between peripheral and core clock speed is determined by the DOZE[2:0] bits (CLKDIV[14:12]). There are eight possible configurations, from 1:1 to 1:128, with 1:1 being the default setting. Programs can use Doze mode to selectively reduce power consumption in event-driven applications. This allows clock-sensitive functions, such as synchronous communications, to continue without interruption while the CPU is not in Idle, waiting for something to invoke an interrupt routine. An automatic return to full-speed CPU operation on interrupts can be enabled by setting the ROI bit (CLKDIV[15]). By default, interrupt events have no effect on Doze mode operation. ## 29.4 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 any effect and read values are invalid. A peripheral module is enabled only if both the associated bit in the PMD register is cleared and the peripheral is supported by the specific dsPIC® DSC variant. If the peripheral is present in the device, it is enabled in the PMD register by default. **Note:** If a PMD bit is set, the corresponding module is disabled after a delay of one instruction cycle. Similarly, if a PMD bit is cleared, the corresponding module is enabled after a delay of one instruction cycle (assuming the module control registers are already configured to enable module operation). ## 29.5 Power-Saving Resources Many useful resources are provided on the main product page of the Microchip website for the devices listed in this data sheet. This product page contains the latest updates and additional information. **Power-Saving Features** ## 29.5.1 Key Resources - "Watchdog Timer and Power-Saving Modes" (www.microchip.com/DS70615) in the "dsPIC33/PIC24 Family Reference Manual." - Code Samples - Application Notes - Software Libraries - Webinars - All related "dsPIC33/PIC24 Family Reference Manual" Sections - Development Tools ## 29.6 Power-Saving Control Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------|----------|----------|--------|--------|---------|---------|---------|--------|--------|--------| | 00540 | PMPCON | 15:8 | | | | | PMDLOCK | | | | | 0x0FA0 | PMDCON | 7:0 | | | | | | | | | | 0x0FA2 | | | | | | | | | | | | 0x0FA3 | Reserved | | | | | | | | | | | 0x0FA4 | PMD1 | 15:8 | | | | | TAMD | QEIMD | PWMMD | | | UXUFA4 | PIVIDT | 7:0 | I2C1MD | U2MD | U1MD | SPI2MD | SPI1MD | C2MD | C1MD | ADC1MD | | 0x0FA6 | PMD2 | 15:8 | | | | | | | | CCP9MD | | UXUFAO | PIVIDZ | 7:0 | CCP8MD | CCP7MD | CCP6MD | CCP5MD | CCP4MD | CCP3MD | CCP2MD | CCP1MD | | 0x0FA8 | PMD3 | 15:8 | | | | | | | | PMPMD | | UXUFAO | PIVIDS | 7:0 | CRCMD | | QEI2MD | | U3MD | I2C3MD | I2C2MD | | | 0x0FAA | PMD4 | 15:8 | | | | | | | | | | UXUI AA | FWD4 | 7:0 | | | | | REFOMD | | | | | 0x0FAC<br><br>0x0FAD | Reserved | | | | | | | | | | | 0x0FAE | PMD6 | 15:8 | DMA7MD | DMA6MD | DMA5MD | DMA4MD | DMA3MD | DMA2MD | DMA1MD | DMA0MD | | OXOTAL | 1 W.D.O | 7:0 | QEI3MD | | | | | | | SPI3MD | | 0x0FB0 | PMD7 | 15:8 | | | PDC6MD | PDC5MD | PDC4MD | PDC3MD | PDC2MD | PDC1MD | | OVOL DO | T WID? | 7:0 | | | | | PTGMD | | | | | 0x0FB2 | PMD8 | 15:8 | | | OPAMPMD | SENT2MD | SENT1MD | | | DMTMD | | OXOI DZ | 1 WIDO | 7:0 | | | CLC4MD | CLC3MD | CLC2MD | CLC1MD | BIASMD | | **Power-Saving Features** ## 29.6.1 Peripheral Module Disable Control Register Low Name: PMDCON Offset: 0xFA0 Access Reset ### Bit 11 - PMDLOCK PMD Lock bit | Value | Description | |-------|-------------| | 1 | | | 0 | | ## 29.6.2 Peripheral Module Disable 1 Register Name: PMD1 Offset: 0xFA4 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|------|------|--------|--------|-------|-------|--------------| | | | | | | TAMD | QEIMD | PWMMD | | | Access | | , | | | R/W | R/W | R/W | <del>3</del> | | Reset | | | | | 0 | 0 | 0 | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | I2C1MD | U2MD | U1MD | SPI2MD | SPI1MD | C2MD | C1MD | ADC1MD | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 11 - TAMD Timer A Module Disable bit | Value | Description | |-------|----------------------------| | 1 | Timer A module is disabled | | 0 | Timer A module is enabled | ### Bit 10 - QEIMD QEI Module Disable bit | Value | Description | |-------|------------------------| | 1 | QEI module is disabled | | 0 | QEI module is enabled | ### Bit 9 - PWMMD PWM Module Disable bit | Value | Description | |-------|------------------------| | 1 | PWM module is disabled | | 0 | PWM module is enabled | #### Bit 7 - I2C1MD I2C1 Module Disable bit | V | alue | Description | |---|------|-------------------------| | 1 | | I2C1 module is disabled | | 0 | | I2C1 module is enabled | ## Bit 6 - U2MD UART2 Module Disable bit | DIL 0 - 02 | BIT 6 - 02MID OART 2 MIOUULE DISABLE BIT | | | |------------|------------------------------------------|--|--| | Value | Description | | | | 1 | UART2 module is disabled | | | | 0 | UART2 module is enabled | | | #### Bit 5 - U1MD UART1 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | UART1 module is disabled | | 0 | UART1 module is enabled | ### Bit 4 - SPI2MD SPI2 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | SPI2 module is disabled | | 0 | SPI2 module is enabled | ### Bit 3 - SPI1MD SPI1 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | SPI1 module is disabled | | 0 | SPI1 module is enabled | ## **Power-Saving Features** ## Bit 2 - C2MD CAN2 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | CAN2 module is disabled | | 0 | CAN2 module is enabled | #### Bit 1 - C1MD CAN1 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | CAN1 module is disabled | | 0 | CAN1 module is enabled | ### Bit 0 - ADC1MD ADC Module Disable bit | Value | Description | |-------|------------------------| | 1 | ADC module is disabled | | 0 | ADC module is enabled | ## 29.6.3 Peripheral Module Disable 2 Register Name: PMD2 Offset: 0xFA6 #### Note: 1. Availability is dependent on the supported peripherals, refer to Table 1. ### Bit 8 - CCP9MD SCCP9 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP9 module is disabled | | 0 | SCCP9 module is enabled | #### Bit 7 - CCP8MD SCCP8 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP8 module is disabled | | 0 | SCCP8 module is enabled | ### Bit 6 - CCP7MD SCCP7 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP7 module is disabled | | 0 | SCCP7 module is enabled | ### Bit 5 - CCP6MD SCCP6 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP6 module is disabled | | 0 | SCCP6 module is enabled | #### Bit 4 - CCP5MD SCCP5 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP5 module is disabled | | 0 | SCCP5 module is enabled | #### Bit 3 - CCP4MD SCCP4 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP4 module is disabled | | 0 | SCCP4 module is enabled | #### Bit 2 - CCP3MD SCCP3 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP3 module is disabled | | 0 | SCCP3 module is enabled | #### Bit 1 - CCP2MD SCCP2 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP2 module is disabled | ## **Power-Saving Features** | Value | Description | |-------|-------------------------| | 0 | SCCP2 module is enabled | ## Bit 0 - CCP1MD SCCP1 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SCCP1 module is disabled | | 0 | SCCP1 module is enabled | ## **Power-Saving Features** ## 29.6.4 Peripheral Module Disable 3 Register Name: PMD3 Offset: 0xFA8 ### Bit 8 - PMPMD Peripheral Port Module Disable bit | Value | Description | |-------|------------------------------------| | 1 | Peripheral port module is disabled | | 0 | Peripheral port module is enabled | ### Bit 7 - CRCMD CRC Module Disable bit | Value | Description | |-------|------------------------| | 1 | CRC module is disabled | | 0 | CRC module is enabled | ### Bit 5 - QEI2MD QEI Module 2 Disable bit | Value | Description | |-------|-------------------------| | 1 | QEI2 module is disabled | | 0 | QEI2 module is enabled | #### Bit 3 - U3MD UART3 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | UART3 module is disabled | | 0 | UART3 module is enabled | #### Bit 2 - I2C3MD I2C3 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | I2C3 module is disabled | | 0 | I2C3 module is enabled | #### Bit 1 - I2C2MD I2C2 Module Disable bit | V | /alue | Description | |---|-------|-------------------------| | 1 | | I2C2 module is disabled | | C | V | I2C2 module is enabled | **Power-Saving Features** # 29.6.5 Peripheral Module Disable 4 Register Name: PMD4 Offset: 0xFAA Bit 3 - REFOMD Reference Clock Module Disable bit | Value | Description | |-------|------------------------------------| | 1 | Reference clock module is disabled | | 0 | Reference clock module is enabled | ## 29.6.6 Peripheral Module Disable 6 Register Name: PMD6 Offset: 0xFAE | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|--------|--------|--------|--------|--------|--------|--------|--------|---| | | DMA7MD | DMA6MD | DMA5MD | DMA4MD | DMA3MD | DMA2MD | DMA1MD | DMA0MD | l | | Access | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | QEI3MD | | | | | | | SPI3MD | | | Access | R/W | | | | | | | R/W | • | | Reset | 0 | | | | | | | 0 | | #### Bit 15 - DMA7MD DMA7 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | DMA7 module is disabled | | 0 | DMA7 module is enabled | #### Bit 14 - DMA6MD DMA6 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | DMA6 module is disabled | | 0 | DMA6 module is enabled | #### Bit 13 - DMA5MD DMA5 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | DMA5 module is disabled | | 0 | DMA5 module is enabled | #### Bit 12 - DMA4MD DMA4 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | DMA4 module is disabled | | 0 | DMA4 module is enabled | #### Bit 11 - DMA3MD DMA3 Module Disable bit | DICTI - L | MIASING BINAS Module Disable bit | |-----------|----------------------------------| | Value | Description | | 1 | DMA3 module is disabled | | 0 | DMA3 module is enabled | #### Bit 10 - DMA2MD DMA2 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | DMA2 module is disabled | | 0 | DMA2 module is enabled | ### Bit 9 - DMA1MD DMA1 Module Disable bit | טונט – טו | MATING DIVAT Module Disable bit | |-----------|---------------------------------| | Value | Description | | 1 | DMA1 module is disabled | | 0 | DMA1 module is enabled | ## Bit 8 - DMA0MD DMA0 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | DMA0 module is disabled | | 0 | DMA0 module is enabled | # **Power-Saving Features** ### Bit 7 - QEI3MD QEI3 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | QEI3 module is disabled | | 0 | QEI3 module is enabled | #### Bit 0 - SPI3MD SPI3 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | SPI3 module is disabled | | 0 | SPI3 module is enabled | ## 29.6.7 Peripheral Module Disable 7 Register Name: PMD7 Offset: 0xFB0 Reset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|--------|--------|--------|--------|--------|--------| | | | | PDC6MD | PDC5MD | PDC4MD | PDC3MD | PDC2MD | PDC1MD | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | PTGMD | | | | | Access | | | | | R/W | | | | Bit 13 - PDC6MD Peripheral DMA Controller 6 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | PDC6 module is disabled | | 0 | PDC6 module is enabled | #### Bit 12 - PDC5MD Peripheral DMA Controller 5 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | PDC5 module is disabled | | 0 | PDC5 module is enabled | #### Bit 11 - PDC4MD Peripheral DMA Controller 4 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | PDC4 module is disabled | | 0 | PDC4 module is enabled | ## Bit 10 - PDC3MD Peripheral DMA Controller 3 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | PDC3 module is disabled | | 0 | PDC3 module is enabled | #### Bit 9 - PDC2MD Peripheral DMA Controller 2 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | PDC2 module is disabled | | 0 | PDC2 module is enabled | #### Bit 8 - PDC1MD Peripheral DMA Controller 1 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | PDC1 module is disabled | | 0 | PDC1 module is enabled | #### Bit 3 - PTGMD PTG Module Disable bit | Value | Description | |-------|------------------------| | 1 | PTG module is disabled | | 0 | PTG module is enabled | ## 29.6.8 Peripheral Module Disable 8 Register Name: PMD8 Offset: 0xFB2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|---------|---------|---------|--------|--------|-------| | | | | OPAMPMD | SENT2MD | SENT1MD | | | DMTMD | | Access | | , | R/W | R/W | R/W | | | R/W | | Reset | | | 0 | 0 | 0 | | | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CLC4MD | CLC3MD | CLC2MD | CLC1MD | BIASMD | | | Access | | | R/W | R/W | R/W | R/W | R/W | | | Reset | | | 0 | 0 | 0 | 0 | 0 | | #### Bit 13 - OPAMPMD Op Amp Module Disable bit | Value | Description | |-------|---------------------------| | 1 | Op amp module is disabled | | 0 | Op amp module is enabled | #### Bit 12 - SENT2MD SENT2 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SENT2 module is disabled | | 0 | SENT2 module is enabled | #### Bit 11 - SENT1MD SENT1 Module Disable bit | Value | Description | |-------|--------------------------| | 1 | SENT1 module is disabled | | 0 | SENT1 module is enabled | #### Bit 8 - DMTMD Deadman Timer Module Disable bit | Value | Description | |-------|----------------------------------| | 1 | Deadman Timer module is disabled | | 0 | Deadman Timer module is enabled | #### Bit 5 - CLC4MD CLC4 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | CLC4 module is disabled | | 0 | CLC4 module is enabled | #### Bit 4 - CLC3MD CLC3 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | CLC3 module is disabled | | 0 | CLC3 module is enabled | ### Bit 3 - CLC2MD CLC2 Module Disable bit | Dit 0 - Ci | COZIND CLOZ MOGGIC DISABIC BIL | |------------|--------------------------------| | Value | Description | | 1 | CLC2 module is disabled | | 0 | CLC2 module is enabled | #### Bit 2 - CLC1MD CLC1 Module Disable bit | Value | Description | |-------|-------------------------| | 1 | CLC1 module is disabled | | 0 | CLC1 module is enabled | **Power-Saving Features** | Bit 1 - BI | Bit 1 – BIASMD Constant-Current Source Module Disable bit | | | | | | | | |------------|-----------------------------------------------------------|--|--|--|--|--|--|--| | Value | Description | | | | | | | | | 1 | Constant-current source module is disabled | | | | | | | | | 0 | Constant-current source module is enabled | | | | | | | | # 30. Special Features **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the related section of the "dsPIC33/PIC24 Family Reference Manual", which is available from the Microchip website (www.microchip.com). The dsPIC33CK512MP608 family devices include several features intended to maximize application flexibility and reliability, and minimize cost through elimination of external components. These are: - · Flexible Configuration - · Watchdog Timer (WDT) - Code Protection and CodeGuard<sup>™</sup> Security - · JTAG Boundary Scan Interface - In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) - · In-Circuit Emulation - · Brown-out Reset (BOR) ## 30.1 Configuration Bits In dsPIC33CK512MP608 family devices, the Configuration Words are implemented as volatile memory. This means that configuration data will get loaded to volatile memory (from the Flash Configuration Words) each time the device is powered up. Configuration data are stored at the end of the on-chip program memory space, known as the Flash Configuration Words. Their specific locations are shown in Table 30-1. The configuration data are automatically loaded from the Flash Configuration Words to the proper Configuration Shadow registers during device Resets. When creating applications for these devices, users should always specifically allocate the location of the Flash Configuration Words for configuration data in their code for the compiler. This is to make certain that program code is not stored in this address when the code is compiled. Program code executing out of configuration space will cause a device Reset. **Note:** Performing a page erase operation on the last page of program memory clears the Flash Configuration Words. Table 30-1. dsPIC33CKXXXMPX0X Configuration Addresses | Register Name | Single F | Partition | Dual Partit | ion, Active | Dual Partition, Inactive | | | |-----------------------|------------------|--------------|--------------|--------------|--------------------------|--------------|--| | Register Name | 256k Address | 512k Address | 256k Address | 512k Address | 256k Address | 512k Address | | | FSEC <sup>(1)</sup> | 0x02BF00 | 0x057F00 | 0x015F00 | 0x02BF00 | 0x4 <mark>15F00</mark> | 0x42BF00 | | | FBSLIM <sup>(1)</sup> | 0x02BF10 0x057F1 | | 0x015F10 | 0x02BF10 | 0x415F10 | 0x42BF10 | | | FSIGN <sup>(1)</sup> | 0x02BF14 | 0x057F14 | 0x015F14 | 0x02BF14 | 0x415F14 | 0x42BF14 | | | FOSCSEL | 0x02BF18 | 0x057F18 | 0x015F18 | 0x02BF18 | 0x415F18 | 0x42BF18 | | | FOSC | 0x02BF1C | 0x057F1C | 0x015F1C | 0x02BF1C | 0x415F1C | 0x42BF1C | | | FWDT | 0x02BF20 | 0x057F20 | 0x015F20 | 0x02BF20 | 0x415F20 | 0x42BF20 | | | FPOR | 0x02BF24 | 0x057F24 | 0x015F24 | 0x02BF24 | 0x415F24 | 0x42BF24 | | | FICD | 0x02BF28 | 0x057F28 | 0x015F28 | 0x02BF28 | 0x415F28 | 0x42BF28 | | | FDMTIVTL | 0x02BF2C | 0x057F2C | 0x015F2C | 0x02BF2C | 0x415F2C | 0x42BF2C | | #### Notes: - Changes to the Inactive Partition Configuration Words affect how the Active Partition accesses the Inactive Partition. - 2. FBOOT resides in calibration memory space. | continued | continued | | | | | | | | | | | |----------------------|--------------|--------------|--------------|--------------|--------------------------|--------------|--|--|--|--|--| | Degister Name | Single F | Partition | Dual Partit | ion, Active | Dual Partition, Inactive | | | | | | | | Register Name | 256k Address | 512k Address | 256k Address | 512k Address | 256k Address | 512k Address | | | | | | | FDMTIVTH | 0x02BF30 | 0x057F30 | 0x015F30 | 0x02BF30 | 0x415F30 | 0x42BF30 | | | | | | | FDMTCNTL | 0x02BF34 | 0x057F34 | 0x015F34 | 0x02BF34 | 0x415F34 | 0x42BF34 | | | | | | | FDMTCNTH | 0x02BF38 | 0x057F38 | 0x015F38 | 0x02BF38 | 0x415F38 | 0x42BF38 | | | | | | | FDMT | 0x02BF3C | 0x057F3C | 0x015F3C | 0x02BF3C | 0x415F3C | 0x42BF3C | | | | | | | FDEVOPT | 0x02BF40 | 0x057F40 | 0x015F40 | 0x02BF40 | 0x415F40 | 0x42BF40 | | | | | | | FALTREG | 0x02BF44 | 0x057F44 | 0x015F44 | 0x02BF44 | 0x415F44 | 0x42BF44 | | | | | | | FALTSEQ | 0x02BFFC | 0x057FFC | 0x015FFC | 0x02BFFC | 0x415FFC | 0x42BFFC | | | | | | | FBOOT <sup>(2)</sup> | | | 0x80 | 1800 | | | | | | | | #### Notes: - Changes to the Inactive Partition Configuration Words affect how the Active Partition accesses the Inactive Partition. - 2. FBOOT resides in calibration memory space. Table 30-2. dsPIC33CKXXXMPX0X Configuration Addresses | Register Name | Single F | artition | Dual Partit | ion, Active | Dual Partition, Inactive | | | |-----------------------|-------------|-------------|-------------|-------------|--------------------------|-------------|--| | Register Name | 64k Address | 32k Address | 64k Address | 32k Address | 64k Address | 32k Address | | | FSEC <sup>(1)</sup> | 0x00AF00 | 0x005F00 | 0x005700 | 0x002F00 | 0x405700 | 0x402F00 | | | FBSLIM <sup>(1)</sup> | 0x00AF10 | 0x005F10 | 0x005710 | 0x002F10 | 0x405710 | 0x402F10 | | | FSIGN <sup>(1)</sup> | 0x00AF14 | 0x005F14 | 0x005714 | 0x002F14 | 0x405714 | 0x402F14 | | | FOSCSEL | 0x00AF18 | 0x005F18 | 0x005718 | 0x002F18 | 0x405718 | 0x402F18 | | | FOSC | 0x00AF1C | 0x005F1C | 0x00571C | 0x002F1C | 0x40571C | 0x402F1C | | | FWDT | 0x00AF20 | 0x005F20 | 0x005720 | 0x002F20 | 0x405720 | 0x402F20 | | | FPOR | 0x00AF24 | 0x005F24 | 0x005724 | 0x002F24 | 0x405724 | 0x402F24 | | | FICD | 0x00AF28 | 0x005F28 | 0x005728 | 0x002F28 | 0x405728 | 0x402F28 | | | FDMTIVTL | 0x00AF2C | 0x005F2C | 0x00572C | 0x002F2C | 0x40572C | 0x402F2C | | | FDMTIVTH | 0x00AF30 | 0x005F30 | 0x005730 | 0x002F30 | 0x405730 | 0x402F30 | | | FDMTCNTL | 0x00AF34 | 0x005F34 | 0x005734 | 0x002F34 | 0x405734 | 0x402F34 | | | FDMTCNTH | 0x00AF38 | 0x005F38 | 0x005738 | 0x002F38 | 0x405738 | 0x402F38 | | | FDMT | 0x00AF3C | 0x005F3C | 0x00573C | 0x002F3C | 0x40573C | 0x402F3C | | | FDEVOPT | 0x00AF40 | 0x005F40 | 0x005740 | 0x002F40 | 0x405740 | 0x402F40 | | | FALTREG | 0x00AF44 | 0x005F44 | 0x005744 | 0x002F44 | 0x405744 | 0x402F44 | | | FALTSEQ | 0x00AFFC | 0x005FFC | 0x0057FC | 0x002FFC | 0x4057FC | 0x402FFC | | #### Notes: - 1. Changes to the Inactive Partition Configuration Words affect how the Active Partition accesses the Inactive Partition. - 2. FBOOT resides in calibration memory space. # **Special Features** | continued | | | | | | | | | | | |----------------------|----------|-------------|-------------|-------------|--------------------------|-------------|--|--|--|--| | Register Name | Single F | artition | Dual Partit | ion, Active | Dual Partition, Inactive | | | | | | | Register Name | | 32k Address | 64k Address | 32k Address | 64k Address | 32k Address | | | | | | FBOOT <sup>(2)</sup> | 0x801800 | | | | | | | | | | #### Notes: - Changes to the Inactive Partition Configuration Words affect how the Active Partition accesses the Inactive Partition - 2. FBOOT resides in calibration memory space. # 30.2 Configuration Registers | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|----------|----------|---------|----------|-------------|---------------|-------------|------------|----------| | | | 23:16 | | | | | | | | | | 0x00 | FSEC | 15:8 | AIVTDIS | | | | | CSS[2:0] | | CWRP | | | | 7:0 | GSS | [1:0] | GWRP | | BSEN | BSS | [1:0] | BWRP | | 0x03 | | | | | | | | | | | | *** | Reserved | | | | | | | | | | | 0x0CFB | | | | | | | | | | | | 0x0CFC | VREGCON | 15:8 | LPWREN | | | | | | | | | | TILLOGOIT | 7:0 | | | Resen | ved[1:0] | Reserv | /ed[1:0] | Reserv | ed[1:0] | | 0x0CFE | | | | | | | | | | | | *** | Reserved | | | | | | | | | | | 0x0F0F | | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F10 | FBSLIM | 15:8 | | | | | | BSLIM[12:8] | | | | | | 7:0 | | | | BSLI | M[7:0] | | | | | 0x0F13 | Reserved | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F14 | FSIGN | 15:8 | Reserved | | | | | | | | | | | 7:0 | | | | | | | | | | 0x0F17 | Reserved | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F18 | FOSCSEL | 15:8 | | | | | | | | | | | | 7:0 | IESO | | | | | | FNOSC[2:0] | | | 0x0F1B | Reserved | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F1C | FOSC | 15:8 | | | | XTBST | XTCF | G[1:0] | | PLLKEN | | | | 7:0 | FCKS | M[1:0] | | | | OSCIOFNC | POSC | MD[1:0] | | 0x0F1F | Reserved | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F20 | FWDT | 15:8 | FWDTEN | | 3. | SWDTPS[4:0] | 1 | | WDTW | /IN[1:0] | | | | 7:0 | WINDIS | RCLKS | SEL[1:0] | | RWDTPS[4:0] | | | | | 0x0F23 | Reserved | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F24 | FPOR | 15:8 | | | | | | | | | | | | 7:0 | | BISTDIS | Resen | ved[1:0] | | | | | | 0x0F27 | Reserved | | | 11.00 | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F28 | FICD | 15:8 | NOBTSWP | | ş: | | Reserved[6:0] | t | 10 | | | | | 7:0 | | | JTAGEN | | | | ICS | [1:0] | | 0x0F2B | Reserved | | | | | | Ì | | | | | | | 23:16 | | | | | | | | | | 0x0F2C | FDMTIVTL | 15:8 | | | | DMTIV | /T[15:8] | | | | | | | 7:0 | | | | | VT[7:0] | | | | | 0x0F2F | Reserved | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F30 | FDMTIVTH | 15:8 | | | | DMTIV | T[31:24] | | | | | | | 7:0 | | | | | T[23:16] | | | | | 0x0F33 | Reserved | | | | | | | | | | | | | 23:16 | | | | | | | | | | 0x0F34 | FDMTCNTL | 15:8 | | | | DMTC | NT[15:8] | | | | | | | 7:0 | | | | | NT[7:0] | | | | | 0x0F37 | Reserved | 100000 | | | | 20,000,000 | | | | | | | | 23:16 | | | | | | | | | | 0x0F38 | FDMTCNTH | 15:8 | | | | DMTCN | IT[31:24] | | | | | | | 7:0 | | | | | T[23:16] | | | | | 0x0F3B | Reserved | | | | | 2 | [] | | | | | | | | | | | | | | | | # **Special Features** | conti | continued | | | | | | | | | | | |--------|----------------|----------|------------------------|------------|---------|-----------|-------------|-------------|-------|----------|--| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 23:16 | | | | | | | | | | | 0x0F3C | FDMT | 15:8 | | | | | | | | | | | | | 7:0 | | | | | | | | DMTDIS | | | 0x0F3F | Reserved | | | | | | | | | | | | | | 23:16 | | | | | | | | | | | 0x0F40 | <b>FDEVOPT</b> | 15:8 | | ALTTMS | SPI2PIN | DUPPWM | | SMBEN | Reser | ved[1:0] | | | | | 7:0 | Reserved | | ALTI2C3 | ALTI2C2 | ALTI2C1 | Reserved | | | | | 0x0F43 | Reserved | | | | | | | | | | | | | | 23:16 | | | | | | | | | | | 0x0F44 | <b>FALTREG</b> | 15:8 | | CTXT4[2:0] | | | CTXT3[2:0] | | | | | | | | 7:0 | CTXT2[2:0] CTXT | | | | | CTXT1[2:0] | | | | | | | 23:16 | IBSEQ[11:0] | | | | | | | | | | 0x0F44 | FBTSEQ | 15:8 | IBSEQ[11:0] BSEQ[11:8] | | | | | Q[11:8] | | | | | | | 7:0 | | | | BSEQ[7:0] | | | | | | | 0x0F47 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x0FB3 | | | | | | | | | | | | | 0x0FB4 | WDTCONL | 15:8 | ON | | | | | RUNDIV[4:0] | | | | | UXUFB4 | WDTCONE | 7:0 | CLKSI | EL[1:0] | | | SLPDIV[4:0] | | | WDTWINEN | | | 0x0FB6 | WDTCONH | 15:8 | | | | WDTCLR | KEY[15:8] | | | | | | UXUFBO | WDICONH | 7:0 | | | | WDTCLR | KEY[7:0] | | | | | ## 30.2.1 FSEC Configuration Register Name: FSEC Offset: 0x00 Legend: PO = Program Once bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |-----------------|---------|-------|------|----|------|----------|-------|------| | Access<br>Reset | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | AIVTDIS | | | | | CSS[2:0] | | CWRP | | Access | R/PO | | | | R/PO | R/PO | R/PO | R/PO | | Reset | 1 | | | | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | GSS | [1:0] | GWRP | | BSEN | BSS | [1:0] | BWRP | | Access | R/PO | R/PO | R/PO | | R/PO | R/PO | R/PO | R/PO | | Reset | 1 | 1 | 1 | | 1 | 1 | 1 | 1 | #### Bit 15 - AIVTDIS Alternate Interrupt Vector Table Disable bit | Value | Description | |-------|---------------| | 1 | Disables AIVT | | 0 | Enables AIVT | #### Bits 11:9 - CSS[2:0] Configuration Segment Code Flash Protection Level bits | Value | Description | |-------|--------------------------------------------------| | 111 | No protection (other than CWRP write protection) | | 110 | Standard security | | 10x | Enhanced security | | 0xx | High security | #### Bit 8 - CWRP Configuration Segment Write-Protect bit | Value | Description | |-------|----------------------------------------------| | 1 | Configuration Segment is not write-protected | | 0 | Configuration Segment is write-protected | #### Bits 7:6 - GSS[1:0] General Segment Code Flash Protection Level bits | Dito 1.0 | CCC[1:0] Contral Cognitive Code Flacil Frotocion Edver bite | |----------|-------------------------------------------------------------| | Value | Description | | 11 | No protection (other than GWRP write protection) | | 10 | Standard security | | 0x | High security | ## Bit 5 - GWRP General Segment Write-Protect bit | Value | Description | |-------|--------------------------------------------| | 1 | User program memory is not write-protected | | 0 | User program memory is write-protected | #### Bit 3 - BSEN Boot Segment Control bit | Value | Description | |-------|------------------------------------------------| | 1 | No Boot Segment | | 0 | Boot Segment size is determined by BSLIM[12:0] | #### Bits 2:1 - BSS[1:0] Boot Segment Code Flash Protection Level bits # **Special Features** | Value | Description | |-------|--------------------------------------------------| | 11 | No protection (other than BWRP write protection) | | 10 | Standard security | | 0 x | High security | ### Bit 0 - BWRP Boot Segment Write-Protect bit | Value | Description | |-------|--------------------------------------------| | 1 | User program memory is not write-protected | | 0 | User program memory is write-protected | ## 30.2.2 FBSLIM Configuration Register Name: FBSLIM Offset: 0xF10 Legend: PO = Program Once bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|------|------|------|-------|--------|-------------|------|------| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | BSLIM[12:8] | | | | Access | | | | R/PO | R/PO | R/PO | R/PO | R/PO | | Reset | | | | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | BSLII | M[7:0] | | | | | Access | R/PO | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Bits 12:0 - BSLIM[12:0] Boot Segment Code Flash Page Address Limit bits Contains the page address of the first active General Segment page. The value to be programmed is the inverted page address, such that programming additional '0's can only increase the Boot Segment size. **Special Features** # 30.2.3 FSIGN Configuration Register Name: FSIGN Offset: 0xF14 **Legend:** PO = Program Once bit, r = Reserved bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |-----------------|---------------|----|----|----|----|----|----|----| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | | | Reserved | | | | | | | | | Access | Reserved<br>r | | | | | | | | | Access<br>Reset | r | | | | | | | | | | r | | | | | | | | | | r<br>0 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reset | r<br>0 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Access Reset Bit 15 - Reserved Maintain as '0' # **Special Features** # 30.2.4 FOSCSEL Configuration Register Name: FOSCSEL Offset: 0xF18 Legend: PO = Program Once bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----------------|-----------------------------------------------|----|------|----|------|------------|------| | | | | | | | | | | | Access | | | | | | | | • | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | IESO | , <u>, , , , , , , , , , , , , , , , , , </u> | | 71.5 | | | ENOCCIO:01 | | | | BOY COURTED IN | | | | | | FNOSC[2:0] | | | Access | R/PO | | | | | R/PO | R/PO | R/PO | | Reset | 1 | | | | | 1 | 1 | 1 | ### Bit 7 - IESO Internal External Switchover bit | 1 | Value | Description | |---|-------|--------------------------------------------------------------------------------| | ſ | 1 | Internal External Switchover mode is enabled (Two-Speed Start-up is enabled) | | | 0 | Internal External Switchover mode is disabled (Two-Speed Start-up is disabled) | ## Bits 2:0 - FNOSC[2:0] Initial Oscillator Source Selection bits | Value | Description | |-------|---------------------------------------------------| | 111 | Internal Fast RC (FRC) Oscillator with Postscaler | | 110 | Backup Fast RC (BFRC) | | 101 | LPRC Oscillator | | 100 | Reserved | | 011 | Primary Oscillator with PLL (XTPLL, HSPLL, ECPLL) | | 010 | Primary (XT, HS, EC) Oscillator | | 001 | Internal Fast RC Oscillator with PLL (FRCPLL) | | 000 | Fast RC (FRC) Oscillator | ### 30.2.5 FOSC Configuration Register Name: FOSC Offset: 0xF1C #### Note: A time-out period will occur when the system clock switching logic requests the PLL clock source and the PLL is not already enabled. Legend: PO = Program Once bit, #### Bit 12 - XTBST Oscillator Kick-Start Programmability bit | Value | Description | |-------|-----------------------| | 1 | Boosts the kick-start | | 0 | Default kick-start | ### Bits 11:10 - XTCFG[1:0] Crystal Oscillator Drive Select bits Current gain programmability for oscillator (output drive). | Value | Description | |-------|------------------------------------| | 11 | Gain3 (use for 24-32 MHz crystals) | | 10 | Gain2 (use for 16-24 MHz crystals) | | 01 | Gain1 (use for 8-16 MHz crystals) | | 00 | Gain0 (use for 4-8 MHz crystals) | ## Bit 8 - PLLKEN PLL Lock Status Control bit(1) | Value | Description | |-------|----------------------------------------------------------------------------------------| | 1 | PLL lock signal will be used to disable PLL clock output if lock is lost | | 0 | PLL lock signal is not used; the PLL clock output will not be disabled if lock is lost | #### Bits 7:6 - FCKSM[1:0] Clock Switching Mode bits | Value | Description | |-------|------------------------------------------------------------------| | 1x | Clock switching is disabled, Fail-Safe Clock Monitor is disabled | | 01 | Clock switching is enabled, Fail-Safe Clock Monitor is disabled | | 00 | Clock switching is enabled, Fail-Safe Clock Monitor is enabled | #### Bit 2 - OSCIOFNC OSCO Pin Function bit (except in XT and HS modes)(1) | Dit 2 | bolot the coco t in t another bit (except in X1 and 110 medee) | |-------|----------------------------------------------------------------| | Value | Description | | 1 | OSCO is the clock output | | 0 | OSCO is the general purpose digital I/O pin | ### Bits 1:0 - POSCMD[1:0] Primary Oscillator Mode Select bits # **Special Features** | Value | Description | |-------|---------------------------------------------| | 11 | Primary Oscillator is disabled | | 10 | HS Crystal Oscillator mode (10 MHz-32 MHz) | | 01 | XT Crystal Oscillator mode (3.5 MHz-10 MHz) | | 00 | EC (External Clock) mode | 1 ## 30.2.6 FWDT Configuration Register Name: FWDT Offset: 0xF20 Reset Legend: PO = Program Once bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|--------|-------|---------|-------------|------|-------------|------|----------| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | FWDTEN | | | SWDTPS[4:0] | | | WDTW | /IN[1:0] | | Access | R/PO | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | WINDIS | RCLKS | EL[1:0] | | | RWDTPS[4:0] | | | | Access | R/PO ### Bit 15 - FWDTEN Watchdog Timer Enable bit | Value | Description | |-------|---------------------------------------------| | 1 | WDT is enabled in hardware | | 0 | WDT controller via the ON bit (WDTCONL[15]) | 1 #### Bits 14:10 - SWDTPS[4:0] Sleep Mode Watchdog Timer Period Select bits | | and the first and the same | | | | | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 11111 | Divide by 2 ^ 31 = 2,147,483,648 | | | | | | 11110 | Divide by 2 ^ 30 = 1,073,741,824 | | | | | | | | | | | | | 00001 | Divide by 2 ^ 1, 2 | | | | | | 00000 | Divide by 2 ^ 0, 1 | | | | | #### Bits 9:8 - WDTWIN[1:0] Watchdog Timer Window Select bits | Value | Description | |-------|---------------------------------------| | 11 | WDT window is 25% of the WDT period | | 10 | WDT window is 37.5% of the WDT period | | 01 | WDT window is 50% of the WDT period | | 00 | WDT Window is 75% of the WDT period | #### Bit 7 - WINDIS Watchdog Timer Window Enable bit | Value | Description | |-------|--------------------------------------| | 1 | Watchdog Timer is in Non-Window mode | | 0 | Watchdog Timer is in Window mode | ### Bits 6:5 - RCLKSEL[1:0] Watchdog Timer Clock Select bits | Value | Description | |-------|--------------------------------------------------------------------------------------------------------------------| | 11 | LPRC clock | | 10 | Uses FRC when WINDIS = 0, system clock is not INTOSC/LPRC and device is not in Sleep; otherwise, uses INTOSC/LPRC | | 01 | Uses peripheral clock when system clock is not INTOSC/LPRC and device is not in Sleep; otherwise, uses INTOSC/LPRC | | 0.0 | Reserved | # **Special Features** | Bits 4:0 - RWDTPS[4:0] Run Mode Watchdog Timer Period Select bits | | | | | | |-------------------------------------------------------------------|----------------------------------|--|--|--|--| | Value | Description | | | | | | 11111 | Divide by 2 ^ 31 = 2,147,483,648 | | | | | | 11110 | Divide by 2 ^ 30 = 1,073,741,824 | | | | | | | | | | | | | 00001 | Divide by 2 ^ 1, 2 | | | | | | 00000 | Divide by 2 ^ 0, 1 | | | | | # **Special Features** # 30.2.7 FPOR Configuration Register Name: FPOR Offset: 0xF24 **Legend:** PO = Program Once bit, r = Reserved bit Note: 1. Applies to a Power-on Reset (POR) only. | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----|---------|--------|---------|----|----|----|----| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | BISTDIS | Reserv | ed[1:0] | | | | | | Access | | R/PO | r | r | | | | | | Reset | | 1 | 1 | 1 | | | | | Bit 6 - BISTDIS Memory BIST Feature Disable bit(1) | Value | Description | |-------|--------------------------------------------------------------------------------------| | 1 | Normal start-up operation after Reset; executes instruction at 0x000000 | | 0 | Optional start-up operation after Reset; executes instruction at start of boot space | Bits 5:4 - Reserved[1:0] Maintain as '1' ## 30.2.8 FICD Configuration Register Name: FICD Offset: 0xF28 **Legend:** PO = Program Once bit, r = Reserved bit Bit 15 - NOBTSWP BOOTSWP Instruction Disable bit | Value | Description | |-------|---------------------------------| | 1 | BOOTSWP instruction is disabled | | 0 | BOOTSWP instruction is enabled | ### Bits 14:8 - Reserved[6:0] Maintain as '1' #### Bit 5 - JTAGEN JTAG Enable bit | Value | Description | |-------|-----------------------| | 1 | JTAG port is enabled | | 0 | JTAG port is disabled | #### Bits 1:0 - ICS[1:0] ICD Communication Channel Select bits | Value | Description | |-------|-------------------------------| | 11 | Communicates on PGC1 and PGD1 | | 10 | Communicates on PGC2 and PGD2 | | 01 | Communicates on PGC3 and PGD3 | | 00 | Reserved, do not use | **Special Features** # 30.2.9 FDMTIVTL Configuration Register Name: FDMTIVTL Offset: 0xF2C | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | |--------|-------------|------|------|-------|---------|------|------|------|--| | | | | | | | | | | | | Access | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | DMTIV | T[15:8] | | | | | | Access | R/PO | | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DMTIVT[7:0] | | | | | | | | | | Access | R/PO | | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Bits 15:0 - DMTIVT[15:0] DMT Window Interval Lower 16 bits **Special Features** # 30.2.10 FDMTIVTH Configuration Register Name: FDMTIVTH Offset: 0xF30 | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | |--------|---------------|------|------|-------|----------|------|------|------|--| | | | | | | | | | | | | Access | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | DMTIV | T[31:24] | | | | | | Access | R/PO | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DMTIVT[23:16] | | | | | | | | | | Access | R/PO | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bits 15:0 - DMTIVT[31:16] DMT Window Interval Higher 16 bits **Special Features** # 30.2.11 FDMTCNTL Configuration Register Name: FDMTCNTL Offset: 0xF34 | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | |--------|------|-------------|------|-------|----------|------|------|------|--|--| | | | | | | | | | | | | | Access | | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | DMTCN | IT[15:8] | | | | | | | Access | R/PO | | | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DMTCNT[7:0] | | | | | | | | | | Access | R/PO | | | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | Bits 15:0 - DMTCNT[15:0] DMT Instruction Count Time-out Value Lower 16 bits **Special Features** # 30.2.12 FDMTCNTH Configuration Register Name: FDMTCNTH Offset: 0xF38 | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | |--------|---------------|------|------|-------|----------|------|------|------|--| | | | | | | | | | | | | Access | | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | DMTCN | T[31:24] | | | | | | Access | R/PO | | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DMTCNT[23:16] | | | | | | | | | | Access | R/PO | | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Bits 15:0 - DMTCNT[31:16] DMT Instruction Count Time-out Value Upper 16 bits **Special Features** # 30.2.13 FDMT Configuration Register Name: FDMT Offset: 0xF3C Legend: PO = Program Once bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----|----|---------------------------------------|----|----|----|----|--------| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | | Access | | | , , , , , , , , , , , , , , , , , , , | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Dit | , | | | | | | , | | | | | | | | | | | DMTDIS | | Access | | | | | | | | R/PO | | Reset | | | | | | | | 1 | ### Bit 0 - DMTDIS DMT Disable bit | Value | Description | |-------|-----------------| | 1 | DMT is disabled | | 0 | DMT is enabled | ### 30.2.14 FDEVOPT Configuration Register Name: FDEVOPT Offset: 0xF40 Note: Reset 1. Fixed pin option is only available for higher pin packages (48-pin, 64-pin and 80-pin). Legend: PO = Program Once bit, r = Reserved bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----------|--------|---------|---------|---------|----------|--------|----------| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | ALTTMS | SPI2PIN | DUPPWM | | SMBEN | Reserv | red[1:0] | | Access | | R/PO | R/PO | R/PO | | R/PO | r | r | | Reset | | 1 | 1 | 1 | | 1 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | ALTI2C3 | ALTI2C2 | ALTI2C1 | Reserved | | | | Access | r | | R/PO | R/PO | R/PO | r | | | Bit 14 - ALTTMS Alternate TMS Pin Mapping bit | Value | Description | |-------|----------------------------------------------------------| | 1 | Default location for TMS pin (shared with PWM pin: RB10) | | 0 | Alternate location for TMS pin (without PWM pin: RB2) | #### Bit 13 - SPI2PIN Main SPI #2 Fast I/O Pad Disable bit(1) | Value | Description | |-------|---------------------------------------------------------------------| | 1 | Host SPI2 uses PPS (I/O remap) to make connections with device pins | | 0 | Host SPI2 uses direct connections with specified device pins | ## Bit 12 - DUPPWM Duplicate PWM Pin Mapping bit | Value | Description | |-------|----------------------------------------------| | 1 | Default PWM4 functions on PPS and fixed pins | | 0 | PWM4 functions only on fixed pins | #### Bit 10 - SMBEN Select Input Voltage Threshold for I<sup>2</sup>C Pads to be SMBus 3.0 Compliant bit | Value | Description | |-------|---------------------------------------------| | 1 | Enables SMBus 3.0 input threshold voltage | | 0 | I <sup>2</sup> C pad input buffer operation | ## Bits 9:8 - Reserved[1:0] Maintain as '0' #### Bit 7 - Reserved Maintain as '1' #### Bit 5 - ALTI2C3 Alternate I2C3 Pin Mapping bit | Value | Description | |-------|-----------------------------------------------------| | 1 | Default location for SCL3/SDA3 pins | | 0 | Alternate location for SCL3/SDA3 pins (ASCL3/ASDA3) | #### Bit 4 - ALTI2C2 Alternate I2C2 Pin Mapping bit | Value | Description | |-------|-------------------------------------| | 1 | Default location for SCL2/SDA2 pins | # **Special Features** | Value | Description | |-------|-----------------------------------------------------| | 0 | Alternate location for SCL2/SDA2 pins (ASCL2/ASDA2) | ## Bit 3 - ALTI2C1 Alternate I2C1 Pin Mapping bit | Value | Description | |-------|-----------------------------------------------------| | 1 | Default location for SCL1/SDA1 pins | | 0 | Alternate location for SCL1/SDA1 pins (ASCL1/ASDA1) | Bit 2 - Reserved Maintain as '1' ## 30.2.15 FALTREG Configuration Register Name: FALTREG Offset: 0xF44 | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----|------|------------|------|----|------|------------|------| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | CTXT4[2:0] | | | | CTXT3[2:0] | | | Access | | R/PO | R/PO | R/PO | | R/PO | R/PO | R/PO | | Reset | | 1 | 1 | 1 | | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CTXT2[2:0] | | | | CTXT1[2:0] | | | Access | | R/PO | R/PO | R/PO | | R/PO | R/PO | R/PO | | Reset | | 1 | 1 | 1 | | 1 | 1 | 1 | Bits 14:12 - CTXT4[2:0] Specifies Alternate Working Register Set #4 with IPLs bits | Value | Description | |-------|------------------------------------------------------| | 111 | Not assigned | | 110 | Alternate Register Set #4 is assigned to IPL Level 7 | | 101 | Alternate Register Set #4 is assigned to IPL Level 6 | | 100 | Alternate Register Set #4 is assigned to IPL Level 5 | | 011 | Alternate Register Set #4 is assigned to IPL Level 4 | | 010 | Alternate Register Set #4 is assigned to IPL Level 3 | | 001 | Alternate Register Set #4 is assigned to IPL Level 2 | | 000 | Alternate Register Set #4 is assigned to IPL Level 1 | Bits 10:8 - CTXT3[2:0] Specifies Alternate Working Register Set #3 with IPLs bits | Value | Description | |-------|------------------------------------------------------| | 111 | Not assigned | | 110 | Alternate Register Set #3 is assigned to IPL Level 7 | | 101 | Alternate Register Set #3 is assigned to IPL Level 6 | | 100 | Alternate Register Set #3 is assigned to IPL Level 5 | | 011 | Alternate Register Set #3 is assigned to IPL Level 4 | | 010 | Alternate Register Set #3 is assigned to IPL Level 3 | | 001 | Alternate Register Set #3 is assigned to IPL Level 2 | | 000 | Alternate Register Set #3 is assigned to IPL Level 1 | Bits 6:4 - CTXT2[2:0] Specifies Alternate Working Register Set #2 with IPLs bits | Value | Description | |-------|------------------------------------------------------| | 111 | Not assigned | | 110 | Alternate Register Set #2 is assigned to IPL Level 7 | | 101 | Alternate Register Set #2 is assigned to IPL Level 6 | | 100 | Alternate Register Set #2 is assigned to IPL Level 5 | | 011 | Alternate Register Set #2 is assigned to IPL Level 4 | | 010 | Alternate Register Set #2 is assigned to IPL Level 3 | | 001 | Alternate Register Set #2 is assigned to IPL Level 2 | | 000 | Alternate Register Set #2 is assigned to IPL Level 1 | Bits 2:0 - CTXT1[2:0] Specifies Alternate Working Register Set #1 with IPLs bits # **Special Features** | Value | Description | |-------|------------------------------------------------------| | 111 | Not assigned | | 110 | Alternate Register Set #1 is assigned to IPL Level 7 | | 101 | Alternate Register Set #1 is assigned to IPL Level 6 | | 100 | Alternate Register Set #1 is assigned to IPL Level 5 | | 011 | Alternate Register Set #1 is assigned to IPL Level 4 | | 010 | Alternate Register Set #1 is assigned to IPL Level 3 | | 001 | Alternate Register Set #1 is assigned to IPL Level 2 | | 000 | Alternate Register Set #1 is assigned to IPL Level 1 | ### 30.2.16 FBTSEQ Configuration Register Name: FBTSEQ Offset: 0xF44 Legend: PO = Program Once bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|-------------|------|------|------------|------|------|------|------| | | IBSEQ[11:0] | | | | | | | | | Access | R/PO | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | IBSEQ[11:0] | | | BSEQ[11:8] | | | | | | Access | R/PO | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BSEQ[7:0] | | | | | | | | | Access | R/PO | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | **Bits 23:12 – IBSEQ[11:0]** Inverse Boot Sequence Number bits (Dual Partition modes only) The one's complement of BSEQ[11:0]; must be calculated by the user and written into device programming. Bits 11:0 - BSEQ[11:0] Boot Sequence Number bits (Dual Partition modes only) Relative value defining which partition will be active after a device Reset; the partition containing a lower boot number will be active. ### 30.2.17 FBOOT Configuration Register Name: FBOOT Legend: PO = Program Once bit Bits 1:0 - BTMODE[1:0] Device Partition Mode Configuration Status bits | Value | Description | |-------|------------------------------------------------------------------------------| | 11 | Single Partition mode | | 10 | Dual Partition mode | | 01 | Protected Dual Partition mode (Partition 1 is write-protected when inactive) | | 00 | Reserved, do not use | ## 30.3 Device Calibration and Identification The dsPIC33CK512MP608 devices have two Identification registers, near the end of configuration memory space, that store the Device ID (DEVID) and Device Revision (DEVREV). These registers are used to determine the mask, variant and manufacturing information about the device. These registers are read-only and are shown in 30.3.2 DEVID and 30.3.1 DEVREV. **Special Features** # 30.3.1 Device Revision Register Name: DEVREV Legend: R = Read-only bit, r = Reserved bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----------|----|----|----|----|------|---------|----| | | | | | | | | | | | Access | | | | | | , | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | Reserved | | | | | | | | | Access | r | | | | | | | | | Reset | 0 | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | DEVR | EV[3:0] | | | Access | | | | | R | R | R | R | | Reset | | | | | | | | | Bit 15 - Reserved Maintain as '0' Bits 3:0 - DEVREV[3:0] Device Revision bits ## 30.3.2 Device ID Register Name: DEVID Note: 1. See 30.3.3 Device IDs for the list of Device Identifier bits. Legend: R = Read-only bit | Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----------|----|----|-------|--------|----|----|----| | | | | | | | | | | | Access | | | | | | | | | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | FAMII | D[7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DEV[7:0] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | | | | | | | | | Bits 15:8 - FAMID[7:0] Device Family Identifier bits | Value | Description | |-----------|--------------------------| | 1000 0111 | dsPIC33CK512MP608 family | Bits 7:0 - DEV[7:0] Individual Device Identifier bits(1) ## 30.3.3 Device IDs Table 30-3. Device IDs for the dsPIC33CK512MP608 Family | Device | DEVID | | | | | | | |--------------------------------------------------------|---------|--|--|--|--|--|--| | Device IDs for dsPIC33CK512MP608 Family with CAN FD | | | | | | | | | dsPIC33CK512MP608 | 0x9F54 | | | | | | | | dsPIC33CK512MP606 | 0x9F53 | | | | | | | | dsPIC33CK512MP605 | 0x9F52 | | | | | | | | dsPIC33CK256MP608 | 0x9F44 | | | | | | | | dsPIC33CK256MP606 | 0x9F43 | | | | | | | | dsPIC33CK256MP605 | 0x9F42 | | | | | | | | Device IDs for dsPIC33CK512MP308 Family without CAN FD | | | | | | | | | dsPIC33CK512MP308 | 0x9F14 | | | | | | | | dsPIC33CK512MP306 | 00x9F13 | | | | | | | | dsPIC33CK512MP305 | 0x9F12 | | | | | | | | dsPIC33CK256MP308 | 0x9F04 | | | | | | | | dsPIC33CK256MP306 | 0x9F03 | | | | | | | | dsPIC33CK256MP305 | 0x9F02 | | | | | | | ### 30.4 User OTP Memory The dsPIC33CK512MP608 family devices contain 64 One-Time-Programmable (OTP) double words, located at addresses, 801700h through 8017FEh. Each 48-bit OTP double word can only be written one time. The OTP Words can be used for storing checksums, code revisions, manufacturing dates, manufacturing lot numbers or any other application-specific information. The OTP area is not cleared by any erase command. This memory can be written only once. #### 30.5 On-Chip Voltage Regulators dsPIC33CK512MP608 family devices have a capacitorless internal voltage regulator to supply power to the core at 1.2V (typical). A pair of voltage regulators, VREG1 and VREG2 together, provide power for the core. The PLL is powered using a separate regulator, VREGPLL, as shown in Figure 30-1. The regulators have Low-Power and Standby modes for use in Sleep modes. For additional information about Sleep, see 29.2.1 Sleep Mode. When the regulators are in Low-Power mode (LPWREN = 1), the power available to the core is limited. Before the LPWREN bit is set, the device should be placed into a lower power state by disabling peripherals and lowering CPU frequency (e.g., 8 MHz FRC without PLL). The output voltages of the three regulators can be controlled independently by the user, which gives the capability to save additional power during Sleep mode. Figure 30-1. Internal Regulator ### 30.5.1 Voltage Regulator Control Register Name: VREGCON Offset: 0xCFC Legend: r = Reserved bit Bit 15 - LPWREN Low-Power Mode Enable bit | Value | Description | |-------|-------------------------------------------| | 1 | Voltage regulators are in Low-Power mode | | 0 | Voltage regulators are in Full-Power mode | Bits 5:4 - Reserved[1:0] Read as '0' Bits 3:2 - Reserved[1:0] Read as '0' Bits 1:0 - Reserved[1:0] Read as '0' ### 30.6 Brown-out Reset (BOR) The Brown-out Reset (BOR) module is based on an internal voltage reference circuit that monitors the regulated supply voltage. The main purpose of the BOR module is to generate a device Reset when a brown-out condition occurs. Brown-out conditions are generally caused by glitches on the AC mains (for example, missing portions of the AC cycle waveform due to bad power transmission lines or voltage sags due to excessive current draw when a large inductive load is turned on). A BOR generates a Reset pulse which resets the device. The BOR selects the clock source based on the device Configuration bit selections. If an Oscillator mode is selected, the BOR activates the Oscillator Start-up Timer (OST). The system clock is held until OST expires. If the PLL is used, the clock is held until the LOCK bit (OSCCON[5]) is '1'. The BOR status bit (RCON[1]) is set to indicate that a BOR has occurred. The BOR circuit continues to operate while in Sleep or Idle mode and resets the device should V<sub>DD</sub> fall below the BOR threshold voltage. ### 30.7 Dual Watchdog Timer (WDT) **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "**Dual Watchdog Timer**" (www.microchip.com/DS70005250) in the "dsPIC33/PIC24 Family Reference Manual". The dsPIC33 dual Watchdog Timer (WDT) is described in this section. Refer to Figure 30-2 for a block diagram of the WDT. The WDT, when enabled, operates from the internal Low-Power RC Oscillator clock source or a selectable clock source in Run mode. The WDT can be used to detect system software malfunctions by resetting the device if the WDT is not cleared periodically in software. The WDT can be configured in Windowed mode or Non-Windowed mode. Various WDT time-out periods can be selected using the WDT postscaler. The WDT can also be used to wake **Special Features** the device from Sleep or Idle mode (Power Save mode). If the WDT expires and issues a device Reset, the WTDO bit in the RCON register will be set. The following are some of the key features of the WDT modules: - · Configuration or Software Controlled - Separate User-Configurable Time-out Periods for Run and Sleep/Idle - · Can Wake the Device from Sleep or Idle - · User-Selectable Clock Source in Run mode - · Operates from LPRC in Sleep/Idle mode Figure 30-2. Watchdog Timer Block Diagram ### 30.7.1 Watchdog Timer Control Register Low Name: WDTCONL Offset: 0xFB4 #### Notes: - 1. A read of this bit will result in a '1' if the WDT is enabled by the device configuration or by software. The user's software should not read or write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit. - 2. The user's software should not read or write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit. - 3. These bits reflect the value of the Configuration bits. - 4. The WDTWINEN bit reflects the status of the Configuration bit if the bit is set. If the bit is cleared, the value is controlled by software. - 5. The available clock sources are device-dependent. Legend: y = Value from Configuration bit on POR, HS = Hardware Settable bit | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|---------|----|----|-------------|-------------|---|----------| | | ON | | | | | RUNDIV[4:0] | | | | Access | R/W | | | R | R | R | R | R | | Reset | 0 | | | 0 | 0 | 0 | 0 | У | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CLKS | EL[1:0] | | | SLPDIV[4:0] | | | WDTWINEN | | Access | R | R | R | R | R | R | R | HS/R/W | | Reset | | | 0 | 0 | 0 | 0 | y | 0 | ## Bit 15 - ON Watchdog Timer Enable bit(1,2) | Value | e Description | |-------|-----------------------------------------------------------------------------| | 1 | Enables the Watchdog Timer if it is not enabled by the device configuration | | 0 | Disables the Watchdog Timer if it was enabled in software | ## Bits 12:8 - RUNDIV[4:0] WDT Run Mode Postscaler Status bits<sup>(3)</sup> | Value | Description | |-------|----------------------------------| | 11111 | Divide by 2 ^ 31 = 2,147,483,648 | | 11110 | Divide by 2 ^ 30 = 1,073,741,824 | | | | | 00001 | Divide by 2 ^ 1, 2 | | 00000 | Divide by 2 ^ 0, 1 | ### Bits 7:6 - CLKSEL[1:0] WDT Run Mode Clock Select Status bits (3,5) | Value | Description | |-------|-----------------| | 11 | LPRC Oscillator | | 10 | FRC Oscillator | | 01 | Reserved | | 00 | SYSCLK | #### Bits 5:1 - SLPDIV[4:0] Sleep and Idle Mode WDT Postscaler Status bits(3) | Value | Description | |---------|----------------------------------| | 11111 | Divide by 2 ^ 31 = 2,147,483,648 | | 11110 | Divide by 2 ^ 30 = 1,073,741,824 | | 2• • 3• | | | 00001 | Divide by 2 ^ 1, 2 | | 00000 | Divide by 2 ^ 0, 1 | Special Features | Rit 0 - | WINEN | Watchdog 7 | Timer Window Enable bit(4) | |---------|------------------|------------|------------------------------| | DIL U - | · VV DI VVIIVLIV | vvalciluou | IIII O WIII WOW LIIADIE DIL' | | Value | Description | |-------|----------------------| | 1 | Enables Window mode | | 0 | Disables Window mode | #### 30.7.2 Watchdog Timer Control Register High Name: WDTCONH Offset: 0xFB6 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|--------|-----------|----|---|---| | | | | | WDTCLR | KEY[15:8] | | | | | Access | W | W | W | W | W | W | W | W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | WDTCLF | RKEY[7:0] | | | | | Access | W | W | W | W | W | W | W | W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - 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 this location using a single 16-bit write. #### 30.8 JTAG Interface The dsPIC33CK512MP608 family devices implement a JTAG interface, which supports boundary scan device testing. Programming is not supported through the JTAG interface; only boundary scan is supported. **Note:** Refer to "**Programming and Diagnostics**" (www.microchip.com/DS70608) in the "dsPIC33/PIC24 Family Reference Manual" for further information on usage, configuration and operation of the JTAG interface. ### 30.9 In-Circuit Debugger When MPLAB<sup>®</sup> ICD 3 or the REAL ICE<sup>™</sup> emulator is selected as a debugger, the in-circuit debugging functionality is enabled. This function allows simple debugging functions when used with MPLAB IDE. Debugging functionality is controlled through the PGCx (Emulation/Debug Clock) and PGDx (Emulation/Debug Data) pin functions. Any of the three pairs of debugging clock/data pins can be used: - PGC1 and PGD1 Host Debug or Client Debug. - · PGC2 and PGD2 Host Debug or Client Debug. - PGC3 and PGD3 Host Debug or Client Debug for debugging Host and Client simultaneously; two ICD or the REAL ICE<sup>™</sup> emulator are required. This mode of debugging, where the Host and Client are simultaneously debugged, is called the Dual Debug mode. To use the in-circuit debugger function of the device, the design must implement ICSP connections to $\overline{\text{MCLR}}$ , $V_{DD}$ , $V_{SS}$ and the PGCx/PGDx pin pair. In addition, when the feature is enabled, some of the resources are not available for general use. These resources include the first 80 bytes of data RAM and two or five (in Dual Debug mode) I/O pins (PGCx and PGDx). ## 30.10 Code Protection and CodeGuard™ Security dsPIC33CK512MP608 family devices offer multiple levels of security for protecting individual intellectual property. The program Flash protection can be broken up into three segments: Boot Segment (BS), General Segment (GS) and Configuration Segment (CS). Boot Segment has the highest security privilege and can be thought to have limited restrictions when accessing other segments. General Segment has the least security and is intended for the end user system code. Configuration Segment contains only the device user configuration data, which are located at the end of the program memory space. The code protection features are controlled by the Configuration registers, FSEC and FBSLIM. The FSEC register controls the code-protect level for each segment and if that segment is write-protected. The size of BS and GS will ## **Special Features** depend on the BSLIM[12:0] bits setting and if the Alternate Interrupt Vector Table (AIVT) is enabled. The BSLIM[12:0] bits define the number of pages for BS, with each page containing 1024 IW. The smallest BS size is one page, which will consist of the Interrupt Vector Table (IVT) and 512 IW of code protection. If the AIVT is enabled, the last page of BS will contain the AIVT and will not contain any BS code. With AIVT enabled, the smallest BS size is now two pages (2048 IW), with one page for the IVT and BS code, and the other page for the AIVT. Write protection of the BS does not cover the AIVT. The last page of BS can always be programmed or erased by BS code. The General Segment will start at the next page and will consume the rest of program Flash, except for the Flash Configuration Words. The IVT will assume GS security only if BS is not enabled. The IVT is protected from being programmed or page erased when either security segment has enabled write protection. The different device security segments are shown in Figure 30-3. Here, all three segments are shown, but are not required. If only basic code protection is required, then GS can be enabled independently or combined with CS, if desired. Figure 30-3. Security Segments Example - Note 1: If CS is write-protected, the last page (GS + CS) of program memory will be protected from an erase condition. - **2:** The last half (256 IW) of the last page of BS is unusable program memory. # 31. Instruction Set Summary **Note:** This data sheet summarizes the features of the dsPIC33CK512MP608 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the related section in the "dsPIC33/PIC24 Family Reference Manual", which is available from the Microchip website (www.microchip.com). The dsPIC33CK instruction set is almost identical to that of the dsPIC30F and dsPIC33F. Most instructions are a single program memory word (24 bits). Only three instructions require two program memory locations. Each single-word instruction is a 24-bit word, divided into an 8-bit opcode, which specifies the instruction type and one or more operands, which further specify the operation of the instruction. The instruction set is highly orthogonal and is grouped into five basic categories: - · Word or byte-oriented operations - Bit-oriented operations - Literal operations - DSP operations - · Control operations Table 31-1 lists the general symbols used in describing the instructions. The dsPIC33 instruction set summary in Table 31-2 lists all the instructions, along with the status flags affected by each instruction. Most word or byte-oriented W register instructions (including barrel shift instructions) have three operands: - The first source operand, which is typically a register 'Wb' without any address modifier - The second source operand, which is typically a register 'Ws' with or without an address modifier - · The destination of the result, which is typically a register 'Wd' with or without an address modifier However, word or byte-oriented file register instructions have two operands: - · The file register specified by the value 'f' - · The destination, which could be either the file register 'f' or the W0 register, which is denoted as 'WREG' Most bit-oriented instructions (including simple rotate/shift instructions) have two operands: - The W register (with or without an address modifier) or file register (specified by the value of 'Ws' or 'f') - The bit in the W register or file register (specified by a literal value or indirectly by the contents of register 'Wb') The literal instructions that involve data movement can use some of the following operands: - · A literal value to be loaded into a W register or file register (specified by 'k') - The W register or file register where the literal value is to be loaded (specified by 'Wb' or 'f') However, literal instructions that involve arithmetic or logical operations use some of the following operands: - · The first source operand, which is a register 'Wb' without any address modifier - · The second source operand, which is a literal value - The destination of the result (only if not the same as the first source operand), which is typically a register 'Wd' with or without an address modifier The MAC class of DSP instructions can use some of the following operands: - The accumulator (A or B) to be used (required operand) - The W registers to be used as the two operands - The X and Y address space prefetch operations - · The X and Y address space prefetch destinations - The accumulator write-back destination **Instruction Set Summary** The other DSP instructions do not involve any multiplication and can include: - · The accumulator to be used (required) - The source or destination operand (designated as Wso or Wdo, respectively) with or without an address modifier - · The amount of shift specified by a W register 'Wn' or a literal value The control instructions can use some of the following operands: - · A program memory address - The mode of the Table Read and Table Write instructions Most instructions are a single word. Certain double-word instructions are designed to provide all the required information in these 48 bits. In the second word, the eight MSbs are '0's. If this second word is executed as an instruction (by itself), it executes as a NOP. The double-word instructions execute in two instruction cycles. Most single-word instructions are executed in a single instruction cycle, unless a conditional test is true or the Program Counter is changed as a result of the instruction, or a PSV or Table Read is performed. In these cases, the execution takes multiple instruction cycles, with the additional instruction cycle(s) executed as a NOP. Certain instructions that involve skipping over the subsequent instruction require either two or three cycles if the skip is performed, depending on whether the instruction being skipped is a single-word or two-word instruction. Moreover, double-word moves require two cycles. **Note:** For more details on the instruction set, refer to the "16-Bit MCU and DSC Programmer's Reference Manual" (www.microchip.com/DS70000157). Table 31-1. Symbols Used in Opcode Descriptions | Field | Description | | | | | |-----------------|-------------------------------------------------------------------------|--|--|--|--| | #text | Means literal defined by "text" | | | | | | (text) | Means "content of text" | | | | | | [text] | Means "the location addressed by text" | | | | | | {} | Optional field or operation | | | | | | a ⊂ {b, c, d} | a is selected from the set of values b, c, d | | | | | | [n:m] | Register bit field | | | | | | .b | Byte mode selection | | | | | | .d | Double-Word mode selection | | | | | | .S | Shadow register select | | | | | | .w | Word mode selection (default) | | | | | | Acc | One of two accumulators {A, B} | | | | | | AWB | Accumulator Write-Back Destination Address register ∈ {W13, [W13]+ = 2} | | | | | | bit4 | 4-bit bit selection field (used in word-addressed instructions) ∈ {015} | | | | | | C, DC, N, OV, Z | MCU Status bits: Carry, Digit Carry, Negative, Overflow, Sticky Zero | | | | | | Expr | Absolute address, label or expression (resolved by the linker) | | | | | | f | File register address ∈ {0x00000x1FFF} | | | | | | lit1 | 1-bit unsigned literal ∈ {0,1} | | | | | **Note:** In dsPIC33CK512MP608 devices, read and Read-Modify-Write (RMW) operations on non-CPU Special Function Registers require an additional cycle when compared to dsPIC30F, dsPIC33F, PIC24F and PIC24H devices. ## **Instruction Set Summary** | continued | | | | | | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Field | Description | | | | | | lit4 | 4-bit unsigned literal ∈ {015} | | | | | | lit5 | 5-bit unsigned literal ∈ {031} | | | | | | lit8 | 8-bit unsigned literal ∈ {0255} | | | | | | lit10 | 10-bit unsigned literal ∈ {0255} for Byte mode, {0:1023} for Word mode | | | | | | lit14 | 14-bit unsigned literal ∈ {016384} | | | | | | lit16 | 16-bit unsigned literal ∈ {065535} | | | | | | lit23 | 23-bit unsigned literal ∈ {08388608}; LSb must be '0' | | | | | | None | Field does not require an entry, can be blank | | | | | | OA, OB, SA, SB | DSP Status bits: ACCA Overflow, ACCB Overflow, ACCA Saturate, ACCB Saturate | | | | | | PC | Program Counter | | | | | | Slit10 | 10-bit signed literal ∈ {-512511} | | | | | | Slit16 | 16-bit signed literal ∈ {-3276832767} | | | | | | Slit6 | 6-bit signed literal ∈ {-1616} | | | | | | Wb | Base W register ∈ {W0W15} | | | | | | Wd | Destination W register ⊂ { Wd, [Wd], [Wd++], [Wd], [++Wd], [Wd] } | | | | | | Wdo | Destination W register ∈ { Wnd, [Wnd], [Wnd++], [Wnd], [++Wnd], [Wnd], [Wnd+Wb] } | | | | | | Wm,Wn | Dividend, Divisor Working register pair (direct addressing) | | | | | | Wm*Wm | Multiplicand and Multiplier Working register pair for Square instructions ∈ {W4 * W4,W5 * W5,W6 * W6,W7 * W7} | | | | | | Wm*Wn | Multiplicand and Multiplier Working register pair for DSP instructions ∈ {W4 * W5,W4 * W6,W4 * W7,W5 * W6,W5 * W7,W6 * W7} | | | | | | Wn | One of 16 Working registers ∈ {W0W15} | | | | | | Wnd | One of 16 Destination Working registers ∈ {W0W15} | | | | | | Wns | One of 16 Source Working registers ∈ {W0W15} | | | | | | WREG | W0 (Working register used in file register instructions) | | | | | | Ws | Source W register ∈ { Ws, [Ws], [Ws++], [Ws], [++Ws], [Ws] } | | | | | | Wso | Source W register ∈ { Wns, [Wns], [Wns++], [Wns], [++Wns], [Wns], [Wns+Wb] } | | | | | | Wx | X Data Space Prefetch Address register for DSP instructions<br>∈ {[W8] + = 6, [W8] + = 4, [W8] + = 2, [W8], [W8] - = 6, [W8] - = 4, [W8] - = 2,<br>[W9] + = 6, [W9] + = 4, [W9] + = 2, [W9], [W9] - = 6, [W9] - = 4, [W9] - = 2,<br>[W9 + W12], none} | | | | | | Wxd | X Data Space Prefetch Destination register for DSP instructions ∈ {W4W7} | | | | | | Note: In dsPIC33Ck | (512MP608 devices, read and Read-Modify-Write (RMW) operations on non-CPU Special | | | | | **Note:** In dsPIC33CK512MP608 devices, read and Read-Modify-Write (RMW) operations on non-CPU Special Function Registers require an additional cycle when compared to dsPIC30F, dsPIC33F, PIC24F and PIC24H devices. **Instruction Set Summary** | continued | | | | | | | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Field | Description | | | | | | | Wy | Y Data Space Prefetch Address register for DSP instructions $\in \{[W10] + = 6, [W10] + = 4, [W10] + = 2, [W10], [W10] - = 6, [W10] - = 4, [W10] - = 2, [W11] + = 6, [W11] + = 4, [W11] + = 2, [W11], [W11] - = 6, [W11] - = 4, [W11] - = 2, [W11 + W12], none}$ | | | | | | | Wyd | Y Data Space Prefetch Destination register for DSP instructions ∈ {W4W7} | | | | | | **Note:** In dsPIC33CK512MP608 devices, read and Read-Modify-Write (RMW) operations on non-CPU Special Function Registers require an additional cycle when compared to dsPIC30F, dsPIC33F, PIC24F and PIC24H devices. Table 31-2. Instruction Set Overview | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | |----------------|----------------------|------|-----------------|--------------------------------------------|---------------|----------------------------|--------------------------| | 1 | ADD | ADD | Acc | Add Accumulators | 1 | 1 | OA,OB,SA,SB | | | | ADD | f | f = f + WREG | 1 | 1 | C,DC,N,OV,Z | | | | ADD | f,WREG | WREG = f + WREG | 1 | 1 | C,DC,N,OV,Z | | | | ADD | #lit10,Wn | Wd = lit10 + Wd | 1 | 1 | C,DC,N,OV,Z | | | | ADD | Wb, Ws, Wd | Wd = Wb + Ws | 1 | 1 | C,DC,N,OV,Z | | | | ADD | Wb,#lit5,Wd | Wd = Wb + lit5 | 1 | 1 | C,DC,N,OV,Z | | | | ADD | Wso,#Slit4,Acc | 16-bit Signed Add to<br>Accumulator | 1 | 1 | OA,OB,SA,SB | | 2 | ADDC | ADDC | f | f = f + WREG + (C) | 1 | 1 | C,DC,N,OV,Z | | | | ADDC | f,WREG | WREG = f + WREG + (C) | 1 | 1 | C,DC,N,OV,Z | | | | ADDC | #1il10,Wm | Wd = lit10 + Wd + (C) | 1 | 1 | C,DC,N,OV,Z | | | | ADDC | Wb, Ws, Wd | Wd = Wb + Ws + (C) | 1 | 1 | C,DC,N,OV,Z | | | | ADDC | Wb,#lit5,Wd | Wd = Wb + Iit5 + (C) | 1 | 1 | C,DC,N,OV,Z | | 3 | AND | AND | f | f = f .AND. WREG | 1 | 1 | N,Z | | | | AND | f,WREG | WREG = f .AND. WREG | 1 | 1 | N,Z | | | | AND | #lit10,Wn | Wd = lit10 .AND. Wd | 1 | 1 | N,Z | | | | AND | Wb, Ws, Wd | Wd = Wb .AND. Ws | 1 | 1 | N,Z | | | | AND | Wb,#lit5,Wd | Wd = Wb .AND. lit5 | 1 | 1 | N,Z | | 4 | ASR | ASR | f | f = Arithmetic Right Shift f | 1 | 1 | C,N,OV,Z | | | | ASR | f,WREG | WREG = Arithmetic Right Shift f | 1 | 1 | C,N,OV,Z | | | | ASR | Ws,Wd | Wd = Arithmetic Right Shift<br>Ws | 1 | 1 | C,N,OV,Z | | | | ASR | Wb, Wns, Wnd | Wnd = Arithmetic Right Shift Wb by Wns | 1 | 1 | N,Z | | | | ASK | Wb,#lit5,Wnd | Wnd = Arithmetic Right Shift<br>Wb by lit5 | 1 | 1 | N,Z | | 5 | BCLR | BCLR | f,#bit4 | Bit Clear f | 1 | 1 | None | | | | BCLR | Ws,#bit4 | Bit Clear Ws | 1 | 1 | None | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles(1) | Status Flags<br>Affected | |----------------|----------------------|---------|-------------------|-----------------------------------------------------|---------------|----------------|--------------------------| | 6 | BFEXT | BFEXT | bit4,wid5,Ws,Wb | Bit Field Extract from Ws to Wb | 2 | 2 | None | | | | BFEXT | bit4,wid5,f,Wb | Bit Field Extract from f to Wb | 2 | 2 | None | | 7 | BFINS | BFINS | bit4,wid5,Wb,Ws | Bit Field Insert from Wb into Ws | 2 | 2 | None | | | | BFINS | bit4,wid5,Wb,f | Bit Field Insert from Wb into f | 2 | 2 | None | | | | BFINS | bit4,wid5,lit8,Ws | Bit Field Insert from #lit8 to<br>Ws | 2 | 2 | None | | 3 | BOOTSWP | BOOTSWP | | Swap the Active and Inactive<br>Program Flash Space | 1 | 2 | None | | 9 | BRA | BRA | C, Expr | Branch if Carry | 1 | 1 (4)/1 | None | | | | BRA | GE, Expr | Branch if Greater Than or<br>Equal | 1 | 1 (4)/1 | None | | | | BRA | GEU, Expr | Branch if unsigned Greater<br>Than or Equal | 1 | 1 (4)/1 | None | | | | BRA | GT, Expr | Branch if Greater Than | 1 | 1 (4)/1 | None | | | | BRA | GTU, Expr | Branch if Unsigned Greater<br>Than | 1 | 1 (4)/1 | None | | | | BRA | LE, Expr | Branch if Less Than or Equal | 1 | 1 (4)/1 | None | | | | BRA | LEU, Expr | Branch if Unsigned Less<br>Than or Equal | 1 | 1 (4)/1 | None | | | | BRA | LT, Expr | Branch if Less Than | 1 | 1 (4)/1 | None | | | | BRA | LTU, Expr | Branch if Unsigned Less<br>Than | 1 | 1 (4)/1 | None | | | | BRA | N, Expr | Branch if Negative | 1 | 1 (4)/1 | None | | | | BRA | NC, Expr | Branch if Not Carry | 1 | 1 (4)/1 | None | | | | BRA | NN, Expr | Branch if Not Negative | 1 | 1 (4)/1 | None | | | | BRA | NOV, Expr | Branch if Not Overflow | 1 | 1 (4)/1 | None | | | | BRA | NZ, Expr | Branch if Not Zero | 1 | 1 (4)/1 | None | | | | BRA | OA, Expr | Branch if Accumulator A<br>Overflow | 1 | 1 (4)/1 | None | | | | BRA | OB, Expr | Branch if Accumulator B<br>Overflow | 1 | 1 (4)/1 | None | | | | BRA | OV, Expr | Branch if Overflow | 1 | 1 (4)/1 | None | | | | BRA | SA, Expr | Branch if Accumulator A<br>Saturated | 1 | 1 (4)/1 | None | | | | BRA | SB, Expr | Branch if Accumulator B<br>Saturated | 1 | 1 (4)/1 | None | | | | BRA | Expr | Branch Unconditionally | 1 | 4/2 | None | | | | BRA | Z,Expr | Branch if Zero | 1 | 1 (4)/1 | None | | | | BRA | Wn | Computed Branch | 1 | 4 | None | | 10 | BREAK | BREAK | | Stop User Code Execution | 1 | 1 | None | | 11 | BSET | BSET | f,#bit4 | Bit Set f | 1 | 1 | None | | | | | Ws,#bit4 | Bit Set Ws | 1 | 1 | None | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | со | ntinued | | | | | | | |----------------|----------------------|---------|----------------------------|-----------------------------------------|---------------|----------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | 12 | BSW | BSW.C | Ws,Wb | Write C Bit to Ws[Wb] | 1 | 1 | None | | | | BSW.Z | Ws,Wb | Write Z Bit to Ws[Wb] | 1 | 1 | None | | 13 | BTG | BTG | f,#bit4 | Bit Toggle f | 1 | 1 | None | | | | BTG | Ws,#bit4 | Bit Toggle Ws | 1 | 1 | None | | 14 | BTSC | BTSC | f,#bit4 | Bit Test f, Skip if Clear | 1 | 1<br>(2 or 3) | None | | | | BTSC | Ws,#bit4 | Bit Test Ws, Skip if Clear | 1 | 1<br>(2 or 3) | None | | 15 | BTSS | BTSS | f,#bit4 | Bit Test f, Skip if Set | 1 | 1<br>(2 or 3) | None | | | | BTSS | Ws,#bit4 | Bit Test Ws, Skip if Set | 1 | 1<br>(2 or 3) | None | | 16 | BTST | BTST | f,#bit4 | Bit Test f | 1 | 1 | Z | | | | BTST.C | Ws,#bit4 | Bit Test Ws to C | 1 | 1 | С | | | | BTST.Z | Ws,#bit4 | Bit Test Ws to Z | 1 | 1 | Z | | | | BTST.C | Ws,Wb | Bit Test Ws[Wb] to C | 1 | 1 | С | | | | BTST.Z | Ws,Wb | Bit Test Ws[Wb] to Z | 1 | 1 | Z | | 17 | BTSTS | BTSTS | f,#bit4 | Bit Test then Set f | 1 | 1 | Z | | | | BTSTS.C | Ws,#bit4 | Bit Test Ws to C, then Set | 1 | 1 | С | | | | BTSTS.Z | Ws,#bit4 | Bit Test Ws to Z, then Set | 1 | 1 | Z | | 18 | CALL | CALL | lit23 | Call Subroutine | 2 | 4/(2) | SFA | | | | CALL | Wn | Call Indirect Subroutine | 1 | 4(2) | SFA | | | | CALL.L | Wn | Call Indirect Subroutine (long address) | 1 | 4(2) | SFA | | 19 | CLR | CLR | f | f = 0x0000 | 1 | 1 | None | | | | CLR | WREG | WREG = 0x0000 | 1 | 1 | None | | | | CLR | Ws | Ws = 0x0000 | 1 | 1 | None | | | | CLR | Acc, Wx, Wxd, Wy, Wyd, AWB | Clear Accumulator | 1 | 1 | OA,OB,SA,SB | | 20 | CLRWDT | CLRWDT | | Clear Watchdog Timer | 1 | 1 | WDTO,Sleep | | 21 | COM | COM | f | f = Ī | 1 | 1 | N,Z | | | | COM | f,WREG | WREG = f | 1 | 1 | N,Z | | | | COM | Ws, Wd | Wd = Ws | 1 | 1 | N,Z | | 22 | CP | CP | f | Compare f with WREG | 1 | 1 | C,DC,N,OV,Z | | | | CP | Wb,#lit8 | Compare Wb with lit8 | 1 | 1 | C,DC,N,OV,Z | | | | CP | Wb,Ws | Compare Wb with Ws (Wb – Ws) | 1 | 1 | C,DC,N,OV,Z | | 23 | CP0 | CP0 | f | Compare f with 0x0000 | 1 | 1 | C,DC,N,OV,Z | | | | CP0 | Ws | Compare Ws with 0x0000 | 1 | 1 | C,DC,N,OV,Z | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | co | ntinued | | | | | | | |----------------|----------------------|---------|-------------------------------------------------------------|--------------------------------------------------------------|---------------|----------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | 24 | СРВ | СРВ | f | Compare f with WREG, with Borrow | 1 | 1 | C,DC,N,OV,Z | | | | СРВ | Wb,#lit8 | Compare Wb with lit8, with Borrow | 1 | 1 | C,DC,N,OV,Z | | | CPB | Wb,Ws | Compare Wb with Ws, with Borrow (Wb – Ws – $\overline{C}$ ) | 1 | 1 | C,DC,N,OV,Z | | | 25 | 25 CPSEQ | CPSEQ | Wb,Wn | Compare Wb with Wn,<br>Skip if = | 1 | 1<br>(2 or 3) | None | | | CPBEQ | CPBEQ | Wb, Wn, Expr | Compare Wb with Wn,<br>Branch if = | 1 | 1 (5) | None | | 26 | CPSGT | CPSGT | Wb,Wn | Compare Wb with Wn,<br>Skip if > | 1 | 1<br>(2 or 3) | None | | | CPBGT | CPBGT | Wb, Wn, Expr | Compare Wb with Wn,<br>Branch if > | 1 | 1 (5) | None | | 27 | CPSLT | CPSLT | Wb,Wn | Compare Wb with Wn,<br>Skip if < | 1 | 1<br>(2 or 3) | None | | | | CPBLT | Wb,Wn,Expr | Compare Wb with Wn,<br>Branch if < | 1 | 1 (5) | None | | 28 | CPSNE | CPSNE | Wb,Wn | Compare Wb with Wn,<br>Skip if ≠ | 1 | 1<br>(2 or 3) | None | | | | CPBNE | Wb,Wn,Expr | Compare Wb with Wn,<br>Branch if ≠ | 1 | 1 (5) | None | | 29 | CTXTSWP | CTXTSWP | #1it3 | Switch CPU Register<br>Context to Context Defined<br>by lit3 | 1 | 2 | None | | 30 | CTXTSWP | CTXTSWP | Wn | Switch CPU Register<br>Context to Context Defined<br>by Wn | 1 | 2 | None | | 31 | DAW.B | DAW.B | Wn | Wn = Decimal Adjust Wn | 1 | 1 | С | | 32 | DEC | DEC | f | f = f - 1 | 1 | 1 | C,DC,N,OV,Z | | | | DEC | f,WREG | WREG = f – 1 | 1 | 1 | C,DC,N,OV,Z | | | | DEC | Ws,Wd | Wd = Ws - 1 | 1 | 1 | C,DC,N,OV,Z | | 33 | DEC2 | DEC2 | f | f = f - 2 | 1 | 1 | C,DC,N,OV,Z | | | | DEC2 | f,WREG | WREG = f – 2 | 1 | 1 | C,DC,N,OV,Z | | | | DEC2 | Ws, Wd | Wd = Ws - 2 | 1 | 1 | C,DC,N,OV,Z | | 34 | DISI | DISI | #lit14 | Disable Interrupts for k Instruction Cycles | 1 | 1 | None | | 35 | DIVF(2) | DIVF | Wm, Wn | Signed 16/16-Bit Fractional<br>Divide | 1 | 18/6 | N,Z,C,OV | | 36 | DIV.S(2) | DIV.S | Wm, Wn | Signed 16/16-Bit Integer<br>Divide | 1 | 18/6 | N,Z,C,OV | | | | DIV.SD | Wm, Wn | Signed 32/16-Bit Integer<br>Divide | 1 | 18/6 | N,Z,C,OV | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | co | ntinued | | | | | | | |----------------|----------------------|---------|-------------------------|----------------------------------------------------------------------------|---------------|----------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | 37 | DIV.U(2) | DIV.U | Wm, Wn | Unsigned 16/16-Bit Integer<br>Divide | 1 | 18/6 | N,Z,C,OV | | | | DIV.UD | Wm,Wn | Unsigned 32/16-Bit Integer<br>Divide | 1 | 18/6 | N,Z,C,OV | | 38 | DIVF2(2) | DIVF2 | Wm, Wn | Signed 16/16-Bit Fractional Divide (W1:W0 preserved) | 1 | 6 | N,Z,C,OV | | 39 | DIV2.S(2) | DIV2.S | Wm, Wn | Signed 16/16-Bit Integer<br>Divide (W1:W0 preserved) | 1 | 6 | N,Z,C,OV | | | | DIV2.SD | Wm, Wn | Signed 32/16-Bit Integer<br>Divide<br>(W1:W0 preserved) | 1 | 6 | N,Z,C,OV | | 40 | DIV2.U <b>(2)</b> | DIV2.U | Wm, Wn | Unsigned 16/16-Bit Integer<br>Divide<br>(W1:W0 preserved) | 1 | 6 | N,Z,C,OV | | | | DIV2.UD | Wm, Wn | Unsigned 32/16-Bit Integer<br>Divide<br>(W1:W0 preserved) | 1 | 6 | N,Z,C,OV | | 41 | DO | DO | #lit15,Expr | Do Code to PC + Expr,<br>lit15 + 1 Times | 2 | 2 | None | | | | DO | Wn, Expr | Do code to PC + Expr,<br>(Wn) + 1 Times | 2 | 2 | None | | 42 | ED | ED | Wm*Wm, Acc, Wx, Wy, Wxd | Euclidean Distance (no accumulate) | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | 43 | EDAC | EDAC | Wm*Wm, Acc, Wx, Wy, Wxd | Euclidean Distance | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | 44 | EXCH | EXCH | Wns, Wnd | Swap Wns with Wnd | 1 | 1 | None | | 46 | FBCL | FBCL | Ws, Wnd | Find Bit Change from Left (MSb) Side | 1 | 1 | С | | 47 | FF1L | FF1L | Ws, Wnd | Find First One from Left (MSb) Side | 1 | 1 | С | | 48 | FF1R | FF1R | Ws, Wnd | Find First One from Right (LSb) Side | 1 | 1 | С | | 49 | FLIM | FLIM | Wb, Ws | Force Data (Upper and<br>Lower) Range Limit without<br>Limit Excess Result | 1 | 1 | N,Z,OV | | | | FLIM.V | Wb, Ws, Wd | Force Data (Upper and Lower) Range Limit with Limit Excess Result | 1 | 1 | N,Z,OV | | 50 | GOTO | GOTO | Expr | Go to Address | 2 | 4/2 | None | | | | GOTO | Wn | Go to Indirect | 1 | 4/2 | None | | | | GOTO.L | Wn | Go to Indirect (long address) | 1 | 4/2 | None | | 51 | INC | INC | f | f = f + 1 | 1 | 1 | C,DC,N,OV,Z | | | | INC | f,WREG | WREG = f + 1 | 1 | 1 | C,DC,N,OV,Z | | | | INC | Ws,Wd | Wd = Ws + 1 | 1 | 1 | C,DC,N,OV,Z | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | co | ntinued | | | | | | | |----------------|----------------------|------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------|---------------|----------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | 52 | INC2 | INC2 | f | f = f + 2 | 1 | 1 | C,DC,N,OV,Z | | | | INC2 | f,WREG | WREG = f + 2 | 1 | 1 | C,DC,N,OV,Z | | | | INC2 | Ws, Wd | Wd = Ws + 2 | 1 | 1 | C,DC,N,OV,Z | | 53 | IOR | IOR | f | f = f .IOR. WREG | 1 | 1 | N,Z | | | | IOR | f,WREG | WREG = f .IOR. WREG | 1 | 1 | N.Z | | | | IOR | #lit10,Wn | Wd = lit10 .IOR. Wd | 1 | 1 | N,Z | | | | IOR | Wb, Ws, Wd | Wd = Wb .IOR. Ws | 1 | 1 | N,Z | | | | IOR | Wb,#lit5,Wd | Wd = Wb .IOR. lit5 | 1 | 1 | N,Z | | 54 | 4 LAC | LAC | Wso,#Slit4,Acc | Load Accumulator | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | | LAC.D | Wso, #Slit4, Acc | Load Accumulator Double | 1 | 2 | OA,SA,OB,SB | | | 56 | LNK | LNK | #lit14 | Link Frame Pointer | 1 | 1 | SFA | | 57 | LSR | LSR | f | f = Logical Right Shift f | 1 | 1 | C,N,OV,Z | | | | LSR | f,WREG | WREG = Logical Right Shift f | 1 | 1 | C,N,OV,Z | | | | LSR | Ws,Wd | Wd = Logical Right Shift Ws | 1 | 1 | C,N,OV,Z | | | | LSR | Wb, Wns, Wnd | Wnd = Logical Right Shift<br>Wb by Wns | 1 | 1 | N,Z | | | | LSR | Wb,#lit5,Wnd | Wnd = Logical Right Shift<br>Wb by lit5 | 1 | 1 | N,Z | | 58 | MAC | MAC | Wm*Wn, Acc, Wx, Wxd, Wy, W<br>yd, AWB | Multiply and Accumulate | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | | | MAC | Wm*Wm, Acc, Wx, Wxd, Wy, Wyd | Square and Accumulate | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | 59 | MAX | MAX | Acc | Force Data Maximum Range<br>Limit | 1 | 1 | N,OV,Z | | | | MAX.V | Acc, Wnd | Force Data Maximum Range<br>Limit with Result | 1 | 1 | N,OV,Z | | 60 | MIN | MIN | Acc | If Accumulator A Less than B Load Accumulator with B or vice versa | 1 | 1 | N,OV,Z | | | | MIN.V | Acc, Wd | If Accumulator A Less than B<br>Accumulator Force Minimum<br>Data Range Limit with Limit<br>Excess Result | 1 | 1 | N,OV,Z | | | | MINZ | Acc | Accumulator Force Minimum Data Range Limit | 1 | 1 | N,OV,Z | | | | MINZ.V | Acc, Wd | Accumulator Force Minimum<br>Data Range Limit with Limit<br>Excess Result | 1 | 1 | N,OV,Z | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | co | ntinued | | | | | | | |----------------|----------------------|----------------------------------|-----------------------------------|-------------------------------------------|---------------|----------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | 61 | MOV | MOV | f,Wn | Move f to Wn | 1 | 1 | None | | | | VOM | f | Move f to f | 1 | 1 | None | | | | MOV | f,WREG | Move f to WREG | 1 | 1 | None | | | | MOV | #lit16,Wn | Move 16-Bit Literal to Wn | 1 | 1 | None | | | | MOV.b | #lit8,Wn | Move 8-Bit Literal to Wn | 1 | 1 | None | | | | MOV | Wn,f | Move Wn to f | 1 | 1 | None | | | | MOV | Wso, Wdo | Move Ws to Wd | 1 | 1 | None | | | | MOV | WREG, f | Move WREG to f | 1 | 1 | None | | | | MOV.D Wn | s,Wd | Move Double from W(ns):W(ns + 1) to Wd | 1 | 2 | None | | | | | | Move Double from Ws to W(nd + 1):W(nd) | 1 | 2 | None | | 62 | MOVPAG | MOVPAG | #lit10,DSRPAG | Move 10-Bit Literal to DSRPAG | 1 | 1 | None | | | | MOVPAG | #lit8,TBLPAG | Move 8-Bit Literal to TBLPAG | 1 | 1 | None | | | | MOVPAG | Ws, DSRPAG | Move Ws[9:0] to DSRPAG | 1 | 1 | None | | | | MOVPAG | Ws, TBLPAG | Move Ws[7:0] to TBLPAG | 1 | 1 | None | | 64 | MOVSAC | MOVSAC | Acc, Wx, Wxd, Wy, Wyd, AWB | Prefetch and Store<br>Accumulator | 1 | 1 | None | | 65 | MPY | | | Multiply Wm by Wn to<br>Accumulator | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | | | MPY Wm*Wm, Acc, Wx, Wxd, Wy, Wyd | | Square Wm to Accumulator | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | 66 | MPY.N | MPY.N Wm | *Wn, Acc, Wx, Wxd, Wy, Wyd | -(Multiply Wm by Wn) to<br>Accumulator | 1 | 1 | None | | 67 | MSC | MSC | Wm*Wm, Acc, Wx, Wxd, Wy, Wyd, AWB | Multiply and Subtract from<br>Accumulator | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | cor | ntinued | | | | | | | |----------------|----------------------|---------|-----------------|------------------------------------------------------|---------------|----------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | 68 | MUL | MUL.SS | Wb, Ws, Wnd | {Wnd + 1, Wnd} =<br>Signed(Wb) * Signed(Ws) | 1 | 1 | None | | | | MUL.SS | Wb, Ws, Acc | Accumulator = Signed(Wb) * Signed(Ws) | 1 | 1 | None | | | | MUL.SU | Wb, Ws, Wnd | {Wnd + 1, Wnd} =<br>Signed(Wb) * Unsigned(Ws) | 1 | 1 | None | | | | MUL.SU | Wb, Ws, Acc | Accumulator = Signed(Wb) * Unsigned(Ws) | 1 | 1 | None | | | | MUL.SU | Wb,#lit5,Acc | Accumulator = Signed(Wb) * Unsigned(lit5) | 1 | 1 | None | | | | MUL.US | Wb, Ws, Wnd | {Wnd + 1, Wnd} =<br>Unsigned(Wb) * Signed(Ws) | 1 | 1 | None | | | | MUL.US | Wb, Ws, Acc | Accumulator = Unsigned(Wb) * Signed(Ws) | 1 | 1 | None | | | | MUL.UU | Wb, Ws, Wnd | {Wnd + 1, Wnd}<br>= Unsigned(Wb) *<br>Unsigned(Ws) | 1 | 1 | None | | | | MUL.UU | Wb,#lit5,Acc | Accumulator = Unsigned(Wb) * Unsigned(lit5) | 1 | 1 | None | | | | MUL.UU | Wb, Ws, Acc | Accumulator = Unsigned(Wb) * Unsigned(Ws) | 1 | 1 | None | | | | MULW.SS | Wb, Ws, Wnd | Wnd = Signed(Wb) * Signed(Ws) | 1 | 1 | None | | | | MULW.SU | Wb, Ws, Wnd | Wnd = Signed(Wb) * Unsigned(Ws) | 1 | 1 | None | | | | MULW.US | Wb, Ws, Wnd | Wnd = Unsigned(Wb) * Signed(Ws) | 1 | 1 | None | | | | MULW.UU | Wb, Ws, Wnd | Wnd = Unsigned(Wb) * Unsigned(Ws) | 1 | 1 | None | | | | MUL.SU | Wb,#lit5,Wnd | {Wnd + 1, Wnd} =<br>Signed(Wb) * Unsigned(lit5) | 1 | 1 | None | | | | MUL.SU | Wb,#lit5,Wnd | Wnd = Signed(Wb) * Unsigned(lit5) | 1 | 1 | None | | | | MUL.UU | Wb,#lit5,Wnd | {Wnd + 1, Wnd}<br>= Unsigned(Wb) *<br>Unsigned(lit5) | 1 | 1 | None | | | | MUL.UU | Wb,#lit5,Wnd | Wnd = Unsigned(Wb) * Unsigned(lit5) | 1 | 1 | None | | | | MUL | f | W3:W2 = f * WREG | 1 | 1 | None | | 69 | NEG | NEG | Acc | Negate Accumulator | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | | | NEG | f | $f = \bar{f} + 1$ | 1 | 1 | C,DC,N,OV,Z | | | | NEG | f,WREG | WREG = Ī + 1 | 1 | 1 | C,DC,N,OV,Z | | | | NEG | Ws, Wd | $Wd = \overline{Ws} + 1$ | 1 | 1 | C,DC,N,OV,Z | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | coı | ntinued | | | | | | | |----------------|----------------------|----------|-----------------|------------------------------------------------------|---------------|------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles(1) | Status Flags<br>Affected | | 70 | NOP | NOP | | No Operation | 1 | 1 | None | | | | NOPR | | No Operation | 1 | 1 | None | | 71 | NORM | NORM | Acc, Wd | Normalize Accumulator | 1 | 1 | N,OV,Z | | 72 | POP | POP | f | Pop f from Top-of-Stack (TOS) | 1 | 1 | None | | | | POP | Wdo | Pop from Top-of-Stack (TOS) to Wdo | 1 | 1 | None | | | | POP.D | Wnd | Pop from Top-of-Stack<br>(TOS) to<br>W(nd):W(nd + 1) | 1 | 2 | None | | | | POP.S | | Pop Shadow Registers | 1 | 1 | All | | 73 | PUSH | PUSH | f | Push f to Top-of-Stack (TOS) | 1 | 1 | None | | | | PUSH | Wso | Push Wso to Top-of-Stack (TOS) | 1 | 1 | None | | | | PUSH.D | Wns | Push W(ns):W(ns + 1) to<br>Top-of-Stack (TOS) | 1 | 2 | None | | | | PUSH.S | 1 | Push Shadow Registers | 1 | 1 | None | | 74 | PWRSAV | PWRSAV # | lit1 | Go into Sleep or Idle mode | 1 | 1 | WDTO,Sleep | | 75 | RCALL | RCALL | Expr | Relative Call | 1 | 4/2(2) | SFA | | | | RCALL | Wn | Computed Call | 1 | 4/2(2) | SFA | | 76 | REPEAT | REPEAT | #lit15 | Repeat Next Instruction<br>lit15 + 1 Times | 1 | 1 | None | | | | REPEAT | Wn | Repeat Next Instruction<br>(Wn) + 1 Times | 1 | 1 | None | | 77 | RESET | RESET | | Software Device Reset | 1 | 1 | None | | 78 | RETFIE | RETFIE | | Return from Interrupt | 1 | 6 (5)/3 <sup>(2)</sup> | SFA | | 79 | RETLW | RETLW | #lit10,Wn | Return with Literal in Wn | 1 | 6 (5)/3 <sup>(2)</sup> | SFA | | 80 | RETURN | RETURN | | Return from Subroutine | 1 | 6 (5)/3 <sup>(2)</sup> | SFA | | 81 | RLC | RLC | f | f = Rotate Left through<br>Carry f | 1 | 1 | C,N,Z | | | | RLC | f,WREG | WREG = Rotate Left through<br>Carry f | 1 | 1 | C,N,Z | | | | RLC | Ws, Wd | Wd = Rotate Left through<br>Carry Ws | 1 | 1 | C,N,Z | | 82 | RLNC | RLNC | f | f = Rotate Left (No Carry) f | 1 | 1 | N,Z | | | | RLNC | f,WREG | WREG = Rotate Left (No<br>Carry) f | 1 | 1 | N,Z | | | | RLNC | Ws,Wd | Wd = Rotate Left (No Carry)<br>Ws | 1 | 1 | N,Z | | 83 | RRC | RRC | f | f = Rotate Right through<br>Carry f | 1 | 1 | C,N,Z | | | | RRC | f,WREG | WREG = Rotate Right through Carry f | 1 | 1 | C,N,Z | | | | RRC | Ws,Wd | Wd = Rotate Right through<br>Carry Ws | 1 | 1 | C,N,Z | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | co | | | | | | | | |----------------|----------------------|--------|------------------|---------------------------------------|---------------|----------------------------|--------------------------| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | 84 | RRNC | RRNC | f | f = Rotate Right (No Carry) f | 1 | 1 | N,Z | | | | RRNC | f,WREG | WREG = Rotate Right (No<br>Carry) f | 1 | 1 | N,Z | | | | RRNC | Ws, Wd | Wd = Rotate Right (No<br>Carry) Ws | 1 | 1 | N,Z | | 85 | SAC | SAC | Acc, #Slit4, Wdo | Store Accumulator | 1 | 1 | None | | | | SAC.R | Acc, #Slit4, Wdo | Store Rounded Accumulator | 1 | 1 | None | | | | SAC.D | #Slit4, Wdo | Store Accumulator Double | 1 | 1 | None | | 86 | SE | SE | Ws, Wnd | Wnd = Sign-Extended Ws | 1 | 1 | C,N,Z | | 87 | SETM | SETM | f | f = 0xFFFF | 1 | 1 | None | | | | SETM | WREG | WREG = 0xFFFF | 1 | 1 | None | | | | SETM | Ws | Ws = 0xFFFF | 1 | 1 | None | | 88 | SFTAC | SFTAC | Acc, Wn | Arithmetic Shift Accumulator by (Wn) | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | | | SFTAC | Acc,#Slit6 | Arithmetic Shift Accumulator by Slit6 | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | 89 | SL | SL | f | f = Left Shift f | 1 | 1 | C,N,OV,Z | | | | SL | f,WREG | WREG = Left Shift f | 1 | 1 | C,N,OV,Z | | | | SL | Ws, Wd | Wd = Left Shift Ws | 1 | 1 | C,N,OV,Z | | | | SL | Wb, Wns, Wnd | Wnd = Left Shift Wb by Wns | 1 | 1 | N,Z | | | | SL | Wb, #lit5, Wnd | Wnd = Left Shift Wb by lit5 | 1 | 1 | N,Z | | 91 | SUB | SUB | Acc | Subtract Accumulators | 1 | 1 | OA,OB,OAB,<br>SA,SB,SAB | | | | SUB | Í | t = t – WREG | 1 | 1 | C,DC,N,OV,Z | | | | SUB | f,WREG | WREG = f – WREG | 1 | 1 | C,DC,N,OV,Z | | | | SUB | #lit10,Wn | Wn = Wn – lit10 | 1 | 1 | C,DC,N,OV,Z | | | | SUB | Wb, Ws, Wd | Wd = Wb – Ws | 1 | 1 | C,DC,N,OV,Z | | | | SUB | Wb, #lit5, Wd | Wd = Wb – lit5 | 1 | 1 | C,DC,N,OV,Z | | 92 | SUBB | SUBB | f | $f = f - WREG - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | | | SUBB | f,WREG | WREG = $f - WREG - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | | | SUBB | #lit10,Wn | $Wn = Wn - lit10 - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | | | SUBB | Wb, Ws, Wd | $Wd = Wb - Ws - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | | | SUBB | Wb,#lit5,Wd | $Wd = Wb - lit5 - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | 93 | SUBR | SUBR | f | f = WREG – f | 1 | 1 | C,DC,N,OV,Z | | | | SUBR | f,WREG | WREG = WREG – f | 1 | 1 | C,DC,N,OV,Z | | | | SUBR | Wb, Ws, Wd | Wd = Ws – Wb | 1 | 1 | C,DC,N,OV,Z | | | | SUBR | Wb,#lit5,Wd | Wd = lit5 – Wb | 1 | 1 | C,DC,N,OV,Z | | 94 | SUBBR | SUBBR | f | $f = WREG - f - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | | | SUBBR | f,WREG | WREG = WREG $-f - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | | | SUBBR | Wb, Ws, Wd | $Wd = Ws - Wb - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | | | SUBBR | Wb,#lit5,Wd | $Wd = lit5 - Wb - (\overline{C})$ | 1 | 1 | C,DC,N,OV,Z | | 95 | SWAP | SWAP.b | Wn | Wn = Nibble Swap Wn | 1 | 1 | None | | | | SWAP | Wn | Wn = Byte Swap Wn | 1 | 1 | None | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. ## **Instruction Set Summary** | co | continued | | | | | | | | | |----------------|----------------------|--------|-----------------|------------------------------|---------------|----------------------------|--------------------------|--|--| | Base<br>Instr# | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of Cycles <sup>(1)</sup> | Status Flags<br>Affected | | | | 96 | TBLRDH | TBLRDH | Ws,Wd | Read Prog[23:16] to Wd[7:0] | 1 | 5/3 | None | | | | 97 | TBLRDL | TBLRDL | Ws,Wd | Read Prog[15:0] to Wd | 1 | 5/3 | None | | | | 98 | TBLWTH | TBLWTH | Ws,Wd | Write Ws[7:0] to Prog[23:16] | 1 | 2 | None | | | | 99 | TBLWTL | TBLWTL | Ws,Wd | Write Ws to Prog[15:0] | 1 | 2 | None | | | | 101 | ULNK | ULNK | | Unlink Frame Pointer | 1 | 1 | SFA | | | | 104 | XOR | XOR | f | f = f .XOR. WREG | 1 | 1 | N,Z | | | | | | XOR | f,WREG | WREG = f .XOR. WREG | 1 | 1 | N,Z | | | | | | XOR | #lit10,Wn | Wd = lit10 .XOR. Wd | 1 | 1 | N,Z | | | | | | XOR | Wb, Ws, Wd | Wd = Wb .XOR. Ws | 1 | 1 | N,Z | | | | | | XOR | Wb,#lit5,Wd | Wd = Wb .XOR. lit5 | 1 | 1 | N,Z | | | | 105 | ZE | ZE | Ws, Wnd | Wnd = Zero-Extend Ws | 1 | 1 | C,Z,N | | | - 1. Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle. - 2. For dsPIC33CK512MP608 devices, the divide instructions must be preceded with a "REPEAT #5" instruction, such that they are executed six consecutive times. **Development Support** # 32. Development Support Move a design from concept to production in record time with Microchip's award-winning development tools. Microchip tools work together to provide state of the art debugging for any project with easy-to-use Graphical User Interfaces (GUIs) in our free MPLAB® X and Atmel Studio Integrated Development Environments (IDEs), and our code generation tools. Providing the ultimate ease-of-use experience, Microchip's line of programmers, debuggers and emulators work seamlessly with our software tools. Microchip development boards help evaluate the best silicon device for an application, while our line of third party tools round out our comprehensive development tool solutions. Microchip's MPLAB X and Atmel Studio ecosystems provide a variety of embedded design tools to consider, which support multiple devices, such as PIC MCUs, AVR MCUs, SAM MCUs and dsPIC DSCs. MPLAB X tools are compatible with Windows, Linux and Mac operating systems while Atmel Studio tools are compatible with Windows. Go to the following website for more information and details: www.microchip.com/development-tools/ ## 33. Electrical Characteristics This section provides an overview of the dsPIC33CK512MP608 family electrical characteristics. Additional information will be provided in future revisions of this document as it becomes available. Absolute maximum ratings for the dsPIC33CK512MP608 family 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. Table 33-1. Absolute Maximum Ratings(1) | Ambient temperature under bias | -40°C to +125°C | |---------------------------------------------------------------------------------------|-----------------------------------| | Storage temperature | -65°C to +150°C | | Voltage on V <sub>DD</sub> with respect to V <sub>SS</sub> | -0.3V to +4.0V | | Voltage on any pin that is not 5V tolerant with respect to $V_{\rm SS}^{(3)}$ | -0.3V to (V <sub>DD</sub> + 0.3V) | | Voltage on any 5V tolerant pin with respect to $V_{SS}$ when $V_{DD} \ge 3.0 V^{(3)}$ | -0.3V to +5.5V | | Voltage on any 5V tolerant pin with respect to $V_{SS}$ when $V_{DD} < 3.0 V^{(3)}$ | -0.3V to +3.6V | | Maximum current out of V <sub>SS</sub> pin | 300 mA | | Maximum current into V <sub>DD</sub> pin <sup>(2)</sup> | 300 mA | | Maximum current sunk/sourced by any 4x I/O pin | 15 mA | | Maximum current sunk/sourced by any 8x I/O pin | 25 mA | | Maximum current sunk by a group of I/Os between two $V_{SS}$ pins <sup>(4)</sup> | 75 mA | | Maximum current sourced by a group of I/Os between two $V_{DD} \mathrm{pins}^{(4)}$ | 75 mA | | Maximum current sunk by all ports <sup>(2)</sup> | 200 mA | - 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. - Maximum allowable current is a function of device maximum power dissipation (see 33.1 DC Characteristics. - 3. See the "Pin Diagrams" section for the 5V tolerant pins. - 4. Not applicable to $AV_{DD}$ and $AV_{SS}$ pins. ## 33.1 DC Characteristics Table 33-2. Operating MIPs vs. Voltage | Characteristic | V <sub>DD</sub> Range<br>(in Volts) | Temperature Range<br>(in °C) | Maximum MIPS<br>dsPIC33CK512MP608<br>Family | |----------------|-------------------------------------|------------------------------|---------------------------------------------| | _ | 3.0V to 3.6V | -40°C to +85°C | 100 | | | 3.0V to 3.6V | -40°C to +125°C | 100 | | | 3.0V to 3.6V | -40°C to +150°C | 70 | **Table 33-3. Thermal Operating Conditions** | Rating | Symbol | Min. | Тур. | Max. | Unit | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------------------|------|--------------|------|--| | Industrial Temperature Devices Operating Junction Temperature Range Operating Ambient Temperature Range | T <sub>J</sub><br>T <sub>A</sub> | -40<br>-40 | _ | +125<br>+85 | °C | | | Extended Temperature Devices Operating Junction Temperature Range Operating Ambient Temperature Range | T <sub>J</sub><br>T <sub>A</sub> | -40<br>-40 | | +140<br>+125 | °C | | | Power Dissipation: Internal Chip Power Dissipation: $P_{INT} = V_{DD} \times (I_{DD} - \Sigma I_{OH})$ I/O Pin Power Dissipation: | P <sub>D</sub> | P <sub>INT</sub> + P <sub>I/O</sub> | | | w | | | I/O = $\Sigma$ ({V <sub>DD</sub> - V <sub>OH</sub> } x I <sub>OH</sub> ) + $\Sigma$ (V <sub>OL</sub> x I <sub>OL</sub> )<br>Maximum Allowed Power Dissipation | P <sub>DMAX</sub> | $(T_J - T_A)/\Theta_{JA}$ | | | | | **Table 33-4. Thermal Packaging Characteristics** | Characteristic | Symbol | Тур. | Max. | Unit | Notes | |-------------------------------------------------------|------------------------|-------|------|------|-------| | Package Thermal Resistance, 80-Pin<br>TQFP 12x12x1 mm | $\theta_{ m JA}$ | 50.67 | - | °C/W | 1 | | Package Thermal Resistance, 64-Pin TQFP 10x10x1 mm | $\theta_{JA}$ | 45.7 | _ | °C/W | 1 | | Package Thermal Resistance, 64-Pin<br>QFN 9x9x0.9 mm | $\theta_{ m JA}$ | 18.7 | _ | °C/W | 1 | | Package Thermal Resistance, 48-Pin TQFP 7x7 mm | $\theta_{ m JA}$ | 62.76 | _ | °C/W | 1 | | Package Thermal Resistance, 48-Pin<br>UQFN 6x6 mm | $\theta_{\mathrm{JA}}$ | 27.6 | _ | °C/W | 1 | ### Note: 1. Junction to ambient thermal resistance, Theta- $_{JA}$ ( $\theta_{JA}$ ) numbers are achieved by package simulations. **Electrical Characteristics** ### Table 33-5. Operating Voltage Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated)<sup>(1)</sup> Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T<sub>A</sub> $\leq$ +125°C for Extended | Param No. | Symbol | Characteristic | Min. | Тур. | Max. | Units | Conditions | | | | |-------------------|------------------|------------------------------------------------------------------------------|------------------------------------------------|------|-----------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Operating Voltage | | | | | | | | | | | | DC10 | V <sub>DD</sub> | Supply Voltage | 3.0 | _ | 3.6 | V | | | | | | DC11 | AV <sub>DD</sub> | Supply Voltage | Greater of:<br>V <sub>DD</sub> – 0.3<br>or 3.0 | _ | Lesser of:<br>V <sub>DD</sub> + 0.3<br>or 3.6 | V | The difference between AV <sub>DD</sub> supply and V <sub>DD</sub> supply must not exceed ±300 mV at all times, including during device power-up | | | | | DC16 | V <sub>POR</sub> | V <sub>DD</sub> Start Voltage<br>to Ensure Internal<br>Power-on Reset Signal | _ | _ | V <sub>SS</sub> | V | | | | | | DC17 | SV <sub>DD</sub> | V <sub>DD</sub> Rise Rate<br>to Ensure Internal<br>Power-on Reset Signal | 0.03 | _ | _ | V/ms | 0V-3V in 100 ms | | | | | BO10 | V <sub>BOR</sub> | BOR Event on V <sub>DD</sub><br>Transition High-to-Low <sup>(2)</sup> | 2.68 | 2.84 | 2.99 | V | | | | | - 1. Device is functional at V<sub>BORMIN</sub> < V<sub>DD</sub> < V<sub>DDMIN</sub>. Analog modules (ADC and comparators) may have degraded performance. - 2. Parameters are characterized but not tested. Table 33-6. DC Characteristics: Operating Current (I<sub>DD</sub>) | | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) | | | | | | | |----------------------|-------------------|-------|-----------------------------------------------------------------------|----------------------------------|------|------------------------------|--|--|--| | DC Characteristics | Rı | un | | temperature -₄<br>≤ +125°C for E | | ⊦85°C for Industrial | | | | | Parameter No. | Тур. | Max. | Units | | Con | ditions | | | | | Operating Current (I | סס <sup>(1)</sup> | | | | | | | | | | DC20 | 7.76 | 10.7 | mA | -40°C | 3.3V | 10 MIPS (N = 1, N2 = 5, | | | | | | 7.49 | 10 | mA | +25°C | | N3 = 2, M = 50, | | | | | | 7.82 | 15.5 | mA | +85°C | | F <sub>VCO</sub> = 400 MHz, | | | | | | 10.32 | 23.5 | mA | +125°C | | F <sub>PLLO</sub> = 40 MHz) | | | | | DC21 | 10.36 | 13.1 | mA | -40°C | 3.3V | 20 MIPS (N = 1, N2 = 5, | | | | | | 10.09 | 12.45 | mA | +25°C | | N3 = 1, M = 60, | | | | | | 10.42 | 17.5 | mA | +85°C | | F <sub>VCO</sub> = 480 MHz, | | | | | | 12.89 | 25.5 | mA | +125°C | | F <sub>PLLO</sub> = 280 MHz) | | | | | DC22 | 14.54 | 17.45 | mA | -40°C | 3.3V | 40 MIPS (N = 1, N2 = 3, | | | | | | 14.26 | 16.7 | mA | +25°C | | N3 = 1, M = 60, | | | | | | 14.58 | 22 | mA | +85°C | | F <sub>VCO</sub> = 480 MHz, | | | | | | 17.06 | 30 | mA | +125°C | | F <sub>PLLO</sub> = 160 MHz) | | | | | DC23 | 22.2 | 25.4 | mA | -40°C | 3.3V | 70 MIPS (N = 1, N2 = 2, | | | | | | 21.91 | 24.9 | mA | +25°C | | N3 = 1, M = 70, | | | | | | 22.21 | 30.75 | mA | +85°C | | F <sub>VCO</sub> = 560 MHz, | | | | | | 24.65 | 37.5 | mA | +125°C | | F <sub>PLLO</sub> = 280 MHz) | | | | | DC24 | 27.36 | 30.7 | mA | -40°C | 3.3V | 90 MIPS (N = 1, N2 = 2, | | | | | | 26.96 | 30.5 | mA | +25°C | | N3 = 1, M = 90, | | | | | | 26.68 | 35 | mA | +85°C | | F <sub>VCO</sub> = 720 MHz, | | | | | | 29.01 | 42 | mA | +125°C | | F <sub>PLLO</sub> = 360 MHz) | | | | 1. I<sub>DD</sub> is primarily a function of the operating voltage and frequency. Other factors, such as I/O pin loading and switching rate, oscillator type, internal code execution pattern and temperature, also have an impact on the current consumption. Base Run current ( $I_{DD}$ ) is measured as follows: - · Oscillator is switched to EC+PLL mode in software - OSC1 pin is driven with external 8 MHz square wave with levels from 0.3V to $V_{DD}$ 0.3V - OSC2 is configured as an I/O in the Configuration Words (OSCIOFNC (FOSC[2]) = 0) - FSCM is disabled (FCKSM[1:0] (FOSC[7:6]) = 01) - Watchdog Timer is disabled (FWDT[15] = 0 and WDTCONL[15] = 0) - · All I/O pins (except OSC1) are configured as outputs and driving low - No peripheral modules are operating or being clocked (defined PMDx bits are all '1's) - JTAG is disabled (JTAGEN (FICD[5]) = 0) - NOP instructions are executed in while (1) loop | continued | | | | | | | | | | |--------------------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|------|--------------------------|--|--|--| | DC Characteristics | Rı | ın | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) | | | | | | | | De characteristics | , , | | Operating temperature -40°C $\leq$ T <sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T <sub>A</sub> $\leq$ +125°C for Extended | | | | | | | | Parameter No. | Тур. | Max. | Units | | Con | ditions | | | | | DC25 | 27.14 | 30.9 | mA | -40°C | 3.3V | 100 MIPS (N = 1, N2 = 1, | | | | | | 26.54 | 30.1 | mA | +25°C N3 = 1, M = 50,<br>+85°C F <sub>VCO</sub> = 400 MHz, | | | | | | | | 26.79 | 35 | mA | | | | | | | | | 29.23 | 42.5 | mA +125°C F <sub>PLLO</sub> = 400 MHz) | | | | | | | 1. I<sub>DD</sub> is primarily a function of the operating voltage and frequency. Other factors, such as I/O pin loading and switching rate, oscillator type, internal code execution pattern and temperature, also have an impact on the current consumption. Base Run current (I<sub>DD</sub>) is measured as follows: - · Oscillator is switched to EC+PLL mode in software - OSC1 pin is driven with external 8 MHz square wave with levels from 0.3V to $V_{DD}$ 0.3V - OSC2 is configured as an I/O in the Configuration Words (OSCIOFNC (FOSC[2]) = 0) - FSCM is disabled (FCKSM[1:0] (FOSC[7:6]) = 01) - Watchdog Timer is disabled (FWDT[15] = 0 and WDTCONL[15] = 0) - · All I/O pins (except OSC1) are configured as outputs and driving low - No peripheral modules are operating or being clocked (defined PMDx bits are all '1's) - JTAG is disabled (JTAGEN (FICD[5]) = 0) - NOP instructions are executed in while (1) loop Table 33-7. Idle Current (I<sub>IDLE</sub>)<sup>(2)</sup> | Parameter No. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | | | |---------------|---------------------|-------|-------|------------|------|-------------------------------------------------------|--|--|--| | DC40 | 6.41 | 8.47 | mA | -40°C | 3.3V | 10 MIPS (N = 1, N2 = 5, N3 = 2, | | | | | | 6.15 | 7.57 | mA | +25°C | | $M = 50, F_{VCO} = 400 MHz,$<br>$F_{PLLO} = 40 MHz)$ | | | | | | 6.45 | 13 | mA | +85°C | | | | | | | | 8.95 | 22 | mA | +125°C | | | | | | | DC41 | 7.31 | 10.1 | mA | -40°C | 3.3V | 20 MIPS (N = 1, N2 = 5, N3 = 1, | | | | | | 7.04 | 9.1 | mA | +25°C | | $M = 50, F_{VCO} = 400 MHz,$<br>$F_{PLLO} = 80 MHz)$ | | | | | | 7.36 | 14.75 | mA | +85°C | | | | | | | | 9.83 | 22.75 | mA | +125°C | | | | | | | DC42 | 9.4 | 12.3 | mA | -40°C | 3.3V | 40 MIPS (N = 1, N2 = 3, N3 = 1, | | | | | | 9.13 | 11.2 | mA | +25°C | | $M = 60, F_{VCO} = 480 MHz,$<br>$F_{PLLO} = 160 MHz)$ | | | | | | 9.45 | 16.5 | mA | +85°C | | | | | | | | 11.92 | 25 | mA | +125°C | | | | | | ## **Electrical Characteristics** | continued | | | | | | | | | | | | |---------------|---------------------|-------|-------|------------|------|-----------------------------------------------------------------------|--|--|--|--|--| | Parameter No. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | | | | | | DC43 | 12.39 | 15.3 | mA | -40°C | 3.3V | 70 MIPS (N = 1, N2 = 2, N3 = 1, | | | | | | | | 12.11 | 14.3 | mA | +25°C | | $M = 70, F_{VCO} = 560 \text{ MHz},$<br>$F_{PLLO} = 280 \text{ MHz})$ | | | | | | | | 12.43 | 19.75 | mA | +85°C | | , 223 | | | | | | | | 14.89 | 28.25 | mA | +125°C | | | | | | | | | DC44 | 14.78 | 17.85 | mA | -40°C | 3.3V | 90 MIPS (N = 1, N2 = 2, N3 = 1, | | | | | | | | 14.5 | 16.9 | mA | +25°C | | $M = 90, F_{VCO} = 720 MHz,$<br>$F_{PLLO} = 360 MHz)$ | | | | | | | | 14.81 | 22.5 | mA | +85°C | | | | | | | | | | 17.26 | 29.5 | mA | +125°C | | | | | | | | | DC45 | 14.44 | 17.55 | mA | -40°C | 3.3V | 100 MIPS (N = 1, N2 = 1, | | | | | | | | 14.15 | 16.5 | mA | +25°C | | N3 = 1,<br>M = 50, F <sub>VCO</sub> = 400 MHz, | | | | | | | | 14.46 | 22.25 | mA | +85°C | | F <sub>PLLO</sub> = 400 MHz) | | | | | | | | 17.5 | 30 | mA | +125°C | | | | | | | | - 1. Data in the "Typ." column are for design guidance only and are not tested. - 2. Base Idle current (I<sub>IDLE</sub>) is measured as follows: - Oscillator is switched to EC+PLL mode in software - $-\,$ OSC1 pin is driven with external 8 MHz square wave with levels from 0.3V to $V_{DD}-0.3V$ - OSC2 is configured as an I/O in the Configuration Words (OSCIOFNC (FOSC[2]) = 0) - FSCM is disabled (FCKSM[1:0] (FOSC[7:6]) = 01) - Watchdog Timer is disabled (FWDTEN (FWDT[15]) = 0) - All I/O pins (except OSC1) are configured as outputs and driving low - No peripheral modules are operating or being clocked (defined PMDx bits are all '1's) - JTAG is disabled (JTAGEN (FICD[5]) = 0) - Flash in standby with NVMSIDL (NVMCON[12]) = 1 Table 33-8. DC Characteristics: Power-Down Current (IPD) | | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) | | | | | |------------------------|-------------------------------|------|-----------------------------------------------------------------------|-----------------------|------|--|--| | DC Charateristics | Sle | eep | Operating tempe<br>Industrial<br>-40°C ≤ T <sub>A</sub> ≤ +12! | 35°C for | | | | | Parameter No. | Typ. <sup>(1)</sup> | Max. | Max. Units Conditions | | | | | | Power-Down Current (IP | <sub>D</sub> ) <sup>(2)</sup> | | | | | | | | DC60 | 270 | 650 | μA | -40°C | 3.3V | | | | | 525 | 1000 | μА | +25°C | | | | | | 2150 | 7250 | μА | +85°C | | | | | | 7.03 | 18.5 | mA | +125°C <sup>(3)</sup> | | | | - 1. Data in the "Typ." column are for design guidance only and are not tested. - 2. I<sub>PD</sub> (Sleep) current is measured as follows: - CPU core is off, oscillator is configured in EC mode and External Clock is active; OSCI is driven with external square wave from rail-to-rail (EC clock overshoot/undershoot < 250 mV required)</li> - CLKO is configured as an I/O input pin in the Configuration Word - All I/O pins are configured as output low - MCLR = $V_{DD}$ , WDT and FSCM are disabled - All peripheral modules are disabled (PMDx bits are all set) - The VREGS bit (RCON[8]) = 0 (i.e., core regulator is set to standby while the device is in Sleep mode) - JTAG is disabled - 3. The regulators are in High-Power mode, LPWREN (VREGCON[15]) = 0. Table 33-9. Doze Current (IDOZE) | Parameter No. | Typ. <sup>(1)</sup> | Max | Doze Ratio | Units | | | Conditions | |---------------|---------------------|-------|------------|-------|--------|------|----------------------------------------------------------| | DC70 | 18.19 | 20 | 1:2 | mA | -40°C | 3.3V | 70 MIPS (N = 1, N2 = 2, N3 = 1, M = 70, | | | 12.66 | 15 | 1:128 | mA | | | F <sub>VCO</sub> = 560 MHz, F <sub>PLLO</sub> = 280 MHz) | | | 17.54 | 20.15 | 1:2 | mA | +25°C | | | | | 12.39 | 14.7 | 1:128 | mA | | | | | | 17.85 | 25 | 1:2 | mA | +85°C | | | | | 12.7 | 20 | 1:128 | mA | | | | | | 20.32 | 32.5 | 1:2 | mA | +125°C | | | | | 16.05 | 28.5 | 1:128 | mA | | | | ## **Electrical Characteristics** | continued | | | | | | | | | | |---------------|---------------------|-------|------------|-------|------------|------|----------------------------------------------------------|--|--| | Parameter No. | Typ. <sup>(1)</sup> | Max | Doze Ratio | Units | Conditions | | | | | | DC71 | 22.3 | 25.55 | 1:2 | mA | -40°C | 3.3V | 100 MIPS (N = 1, N2 = 1, N3 = 1, M = 50, | | | | | 14.83 | 17.25 | 1:128 | mA | | | F <sub>VCO</sub> = 400 MHz, F <sub>PLLO</sub> = 400 MHz) | | | | | 21.86 | 25.05 | 1:2 | mA | +25°C | | | | | | | 14.55 | 16.95 | 1:128 | mA | | | | | | | | 22.16 | 30 | 1:2 | mA | +85°C | | | | | | | 14.86 | 22 | 1:128 | mA | | | | | | | | 24.62 | 36.5 | 1:2 | mA | +125°C | | | | | | | 17.45 | 30 | 1:128 | mA | | | | | | #### Note: 1. Data in the "Typ." column are for design guidance only and are not tested. Table 33-10. DC Characteristics: Watchdog Timer Delta Current (ΔI<sub>WDT</sub>)<sup>(1)</sup> | DC Characteristics | Standard Operating Conditions: 3.0V to 3.6V<br>(unless otherwise stated)<br>Operating temperature -40°C ≤ T <sub>A</sub> ≤ +85°C for Industrial<br>-40°C ≤ T <sub>A</sub> ≤ +125°C for Extended | | | | | | | | | | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----|--------|------|--|--|--|--|--| | Parameter No. | Тур. | Typ. Max. Units Conditions | | | | | | | | | | DC61c | 25 | 125 | μΑ | -40°C | 3.3V | | | | | | | DC61b | 110 | 600 | μA | +25°C | | | | | | | | DC61a | 100 600 μA +85°C | | | | | | | | | | | DC61d | 100 | 600 | μA | +125°C | | | | | | | ## Note: The ΔI<sub>WDT</sub> current is the additional current consumed when the module is enabled. This includes the LPRC/ BFRC clock source current. This current should be added to the base I<sub>PD</sub> current. All parameters are characterized but not tested during manufacturing. Table 33-11. DC Characteristics: PWM Delta Current(1) | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) | | | | | | | | |--------------------|-----------------------------------------------------------------------|------|------------------------------|-------------------------------------|-------------------------------------------|--|--|--| | DC Characteristics | | | ıre -40°C ≤ ׄ<br>for Extende | Γ <sub>A</sub> ≤ +85°C for Ir<br>ed | ndustrial | | | | | Parameter No. | Тур. | Max. | Units | | Conditions | | | | | DC100 | 5.96 | 6.6 | mA | -40°C, 3.3V | PWM Output 500 kHz, | | | | | | 5.99 | 6.7 | mA | +25°C, 3.3V | PWM Input (AF <sub>PLLO</sub> = 500 MHz), | | | | | | 5.92 | 6.9 | mA | +85°C, 3.3V | AVCO = 1000 MHz, PLLFBD = 125, | | | | | | 5.47 | 7 | mA | +125°C, 3.3V | APLLDIV = 2 | | | | | DC101 | 4.89 | 5.4 | mA | -40°C, 3.3V | PWM Output 500 kHz, | | | | | | 4.91 | 5.5 | mA | +25°C, 3.3V | PWM Input (AF <sub>PLLO</sub> = 400 MHz), | | | | | | 4.85 | 5.7 | mA | +85°C, 3.3V | AVCO = 400 MHz, PLLFBD = 50, | | | | | | 4.42 | 5.7 | mA | +125°C, 3.3V | APLLDIV = 1 | | | | | DC102 | 2.77 | 3.7 | mA | -40°C, 3.3V | PWM Output 500 kHz, | | | | | | 2.75 | 3.7 | mA | +25°C, 3.3V | PWM Input (AF <sub>PLLO</sub> = 200 MHz), | | | | | | 2.7 | 3.7 | mA | +85°C, 3.3V | AVCO = 400 MHz, PLLFBD = 50, | | | | | | 2.26 | 3.7 | mA | +125°C, 3.3V | APLLDIV = 2 | | | | | DC103 | 1.67 | 2 | mA | -40°C, 3.3V | PWM Output 500 kHz, | | | | | | 1.66 | 2.2 | mA | +25°C, 3.3V | PWM Input (AF <sub>PLLO</sub> = 100 MHz), | | | | | | 1.63 | 2.3 | mA | +85°C, 3.3V | AVCO = 400 MHz, PLLFBD = 50, | | | | | | 1.17 | 2.3 | mA | +125°C, 3.3V | APLLDIV = 4 | | | | Table 33-12. DC Characteristics: APLL Delta Current | DC Characteristics | (unless other | standard Operating Conditions: 3.0V to 3.6V<br>unless otherwise stated)<br>Operating temperature -40°C ≤ T <sub>A</sub> ≤ +85°C for Industrial<br>40°C ≤ T <sub>A</sub> ≤ +125°C for Extended | | | | | | | |--------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------------------------|-------------------------------|--|--|--| | Parameter No. | Тур. | Max. | Units | Conditions <sup>(1)</sup> | | | | | | DC110 | 5.93 | 6.6 | mA | -40°C, 3.3V | AF <sub>PLLO</sub> = 500 MHz, | | | | | | 5.95 | 7 | mA | +25°C, 3.3V | AVCO = 1000 MHz, | | | | | | 6.15 | 7.6 | mA | +85°C, 3.3V PLLFBD = 125, APLLDIV = 2 | | | | | | N 4 | 7.15 | 9 | mA | +125°C, 3.3V | | | | | #### Note: 1. The APLL current will be the same if more than one PWM or DAC is run to the APLL clock. All parameters are characterized but not tested during manufacturing. <sup>1.</sup> APLL current is not included. The APLL current will be the same if more than one PWM is running. Listed delta currents are for only one PWM instance when HREN = 0 (PGxCONL[7]). All parameters are characterized but not tested during manufacturing. | continued | | | | | | | | | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----|--------------|-------------------------------|--|--|--| | DC Characteristics | (unless other | erwise stated) | | | | | | | | | Operating temperature -40°C $\leq$ T <sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T <sub>A</sub> $\leq$ +125°C for Extended | | | | | | | | | Parameter No. | Тур. | Typ. Max. Units Conditions <sup>(1)</sup> | | | | | | | | DC111 | 2.72 | 3.3 | mA | -40°C, 3.3V | AF <sub>PLLO</sub> = 400 MHz, | | | | | | 2.74 | 3.7 | mA | +25°C, 3.3V | AVCO = 400 MHz, | | | | | | 2.92 | 4.3 | mA | +85°C, 3.3V | PLLFBD = 50, APLLDIV = 1 | | | | | | 3.87 | 5.6 | | +125°C, 3.3V | | | | | | DC112 | 1.39 | 2.7 | mA | -40°C, 3.3V | AF <sub>PLLO</sub> = 200 MHz, | | | | | | 1.49 | 2.7 | mA | +25°C, 3.3V | AVCO = 400 MHz, | | | | | | 1.65 | 3 | mA | +85°C, 3.3V | PLLFBD = 50, APLLDIV = 2 | | | | | | 2.6 | 4.4 | mA | +125°C, 3.3V | | | | | | DC113 | 0.79 | 1.1 | mA | -40°C, 3.3V | AF <sub>PLLO</sub> = 100 MHz, | | | | | | 0.84 | 1.4 | mA | +25°C, 3.3V | AVCO = 400 MHz, | | | | | | 0.96 | 2.3 | mA | +85°C, 3.3V | PLLFBD = 50, APLLDIV = 4 | | | | | | 1.93 | 3.6 | mA | +125°C, 3.3V | | | | | | Note: | | | | | | | | | Table 33-13. DC Characteristics: ADC Δ Current | DC Charateristics | (unles | Standard Operating Conditions: 3.0V to 3.6V<br>(unless otherwise stated)<br>Operating temperature -40°C ≤ T <sub>A</sub> ≤ +85°C for Industrial<br>-40°C ≤ T <sub>A</sub> ≤ +125°C for Extended | | | | | | | | | |-------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------|------|------------------------------------------------------|--|--|--|--| | Parameter No. | Тур. | Max. | Units | Conditions | | | | | | | | DC120 | 3.61 | 4 | mA | -40°C | 3.3V | T <sub>AD</sub> = 14.3 ns (3.5 Msps conversion rate) | | | | | | | 3.68 | 4.1 | mA | +25°C | | | | | | | | | 3.69 | 4.2 | mA | +85°C | | | | | | | | | 3.89 | 4.6 | mA | +125°C | | | | | | | <sup>1.</sup> The APLL current will be the same if more than one PWM or DAC is run to the APLL clock. All parameters are characterized but not tested during manufacturing. Table 33-14. DC Characteristics: Comparator + DAC Delta Current | DC Characteristics | (unless other<br>Operating ten | Standard Operating Conditions: 3.0V to 3.6V<br>(unless otherwise stated)<br>Operating temperature -40°C ≤ T <sub>A</sub> ≤ +85°C for Industrial<br>-40°C ≤ T <sub>A</sub> ≤ +125°C for Extended | | | | | | | |--------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------|---------------------------------------------|--|--|--| | Parameter No. | Тур. | Max. | Units | Conditions | | | | | | DC130 | 1.2 | 1.35 | mA | -40°C, 3.3V | AF <sub>PLLO</sub> @ 500 MHz <sup>(1)</sup> | | | | | | 1.23 | 1.65 | mA | +25°C, 3.3V | | | | | | | 1.23 | 1.65 | mA | +85°C, 3.3V | | | | | | | 1.24 | 1.65 | mA | +125°C, 3.3V | | | | | APLL current is not included. Listed delta currents are for only one comparator + DAC instance. All parameters are characterized but not tested during manufacturing. Table 33-15. Op Amp Delta Current<sup>(1)</sup> | Parameter No. | Тур. | Max. | Units | Condit | ions | |---------------|--------|------|-------|--------|------| | DC140 | 0.25 | 1 | mA | -40°C | 3.3V | | | 0.27 | 1.1 | mA | +25°C | - | | | 0.32 | 1.4 | mA | +85°C | | | | 0.4647 | 1.7 | mA | +125°C | | #### Note: Listed delta currents are for only one op amp instance. All parameters are characterized but not tested during manufacturing. Table 33-16. I/O Pin Input Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T<sub>A</sub> $\leq$ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|-----------------|--------------------------|-----------------|---------------------|---------------------|-------|----------------| | | V <sub>IL</sub> | Input Low Voltage | | | | | | | DI10 | | Any I/O Pin and MCLR | V <sub>SS</sub> | _ | 0.2 V <sub>DD</sub> | ٧ | | | DI18 | | I/O Pins with SDAx, SCLx | V <sub>SS</sub> | _ | 0.3 V <sub>DD</sub> | V | SMBus disabled | | DI19 | | I/O Pins with SDAx, SCLx | V <sub>SS</sub> | _ | 0.8 | ٧ | SMBus enabled | - 1. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 2. Negative current is defined as current sourced by the pin. - 3. See the "Pin Diagrams" section for the 5V tolerant I/O pins. - 4. All parameters are characterized but not tested during manufacturing. ## .....continued Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T<sub>A</sub> $\leq$ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|-------------------|---------------------------------------------------------------|---------------------|---------------------|-----------------|-------|----------------------------------------| | | V <sub>IH</sub> | Input High Voltage | | | | | | | DI20 | | I/O Pins Not 5V Tolerant <sup>(3)</sup> | 0.8 V <sub>DD</sub> | _ | $V_{DD}$ | ٧ | | | | | 5V Tolerant I/O Pins and MCLR <sup>(3)</sup> | 0.8 V <sub>DD</sub> | _ | 5.5 | V | | | | | 5V Tolerant I/O Pins with SDAx, SCLx <sup>(3)</sup> | 0.8 V <sub>DD</sub> | _ | 5.5 | V | SMBus disabled | | | | 5V Tolerant I/O Pins with SDAx, SCLx <sup>(3)</sup> | 2.1 | _ | 5.5 | V | SMBus enabled | | | | I/O Pins with SDAx,<br>SCLx Not 5V Tolerant <sup>(3)</sup> | 0.8 V <sub>DD</sub> | _ | V <sub>DD</sub> | V | SMBus disabled | | | | I/O Pins with SDAx,<br>SCLx Not 5V Tolerant <sup>(3)</sup> | 2.1 | _ | $V_{DD}$ | V | SMBus enabled | | DI30 | I <sub>CNPU</sub> | Input Change Notification Pull-up Current <sup>(2,4)</sup> | 175 | 360 | 545 | μΑ | $V_{DD} = 3.6V,$<br>$V_{PIN} = V_{SS}$ | | DI31 | I <sub>CNPD</sub> | Input Change Notification<br>Pull-Down Current <sup>(4)</sup> | 65 | 215 | 360 | μA | $V_{DD} = 3.6V,$<br>$V_{PIN} = V_{DD}$ | #### Notes: - 1. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 2. Negative current is defined as current sourced by the pin. - 3. See the "Pin Diagrams" section for the 5V tolerant I/O pins. - 4. All parameters are characterized but not tested during manufacturing. ### Table 33-17. I/O Pin Input Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T<sub>A</sub> $\leq$ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Max. | Units | Conditions | | | |--------------|-----------------|--------------------------------------------|------|------|-------|--------------------------------|--|--| | DI50 | I <sub>IL</sub> | Input Leakage Current <sup>(1)</sup> | | | | | | | | | | I/O Pins 5V Tolerant <sup>(2)</sup> | -700 | +700 | nA | $V_{PIN} = V_{SS}$ or $V_{DD}$ | | | | | | I/O Pins Not 5V<br>Tolerant <sup>(2)</sup> | -700 | +700 | nA | | | | | | | MCLR | -700 | +700 | nA | | | | | | | OSCI | -700 | +700 | nA | XT and HS modes | | | - 1. Negative current is defined as current sourced by the pin. - 2. See the "Pin Diagrams" section for the 5V tolerant I/O pins. All parameters are characterized but not tested during manufacturing. ### Table 33-18. I/O Pin Input Injection Current Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T<sub>A</sub> $\leq$ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Max. | Units | Conditions | |--------------|-------------------|--------------------------------------------------------------------------------|------|---------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | DI60a | I <sub>ICL</sub> | Input Low Injection<br>Current | 0 | <sub>-5</sub> (1,4) | mA | All pins | | DI60b | I <sub>ICH</sub> | Input High Injection<br>Current | 0 | +5(2,3,4) | mA | All pins, except all 5V tolerant pins | | DI60c | ΣΙ <sub>ΙCΤ</sub> | Total Input Injection Current (sum of all I/O and control pins) <sup>(5)</sup> | -20 | +20 | mA | Absolute instantaneous sum of all ± input injection currents from all I/O pins ( I <sub>ICL</sub> + I <sub>ICH</sub> ) ≤ ΣI <sub>ICT</sub> | #### Notes: - 1. $V_{IL}$ Source < ( $V_{SS}$ 0.3). - 2. $V_{IH}$ Source > $(V_{DD} + 0.3)$ for non-5V tolerant pins only. - 3. 5V tolerant pins do not have an internal high-side diode to V<sub>DD</sub>, and therefore, cannot tolerate any "positive" input injection current. - 4. Injection currents can affect the ADC results. - Any number and/or combination of I/O pins, not excluded under I<sub>ICL</sub> or I<sub>ICH</sub> conditions, are permitted in the sum. ### Table 33-19. I/O Pin Output Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ $T_A \leq$ +85°C for Industrial -40°C $\leq$ $T_A \leq$ +125°C for Extended | Param. | Symbol | Characteristic | Min. | Тур. | Max. | Units | Conditions | |--------|-----------------|-------------------------------------------------------------|------|------|------|-------|----------------------------------------------------| | DO10 | V <sub>OL</sub> | Output Low Voltage<br>4x Sink Driver Pins | _ | _ | 0.42 | V | V <sub>DD</sub> = 3.6V,<br>I <sub>OL</sub> < 9 mA | | | | Output Low Voltage<br>8x Sink Driver Pins <sup>(1)</sup> | _ | _ | 0.4 | V | V <sub>DD</sub> = 3.6V,<br>I <sub>OL</sub> < 11 mA | | DO20 | V <sub>OH</sub> | Output High Voltage<br>4x Source Driver Pins | 2.4 | _ | _ | V | V <sub>DD</sub> = 3.6V,<br>I <sub>OH</sub> > -8 mA | | | | Output High Voltage<br>8x Source Driver Pins <sup>(1)</sup> | 2.4 | _ | _ | V | $V_{DD} = 3.6V,$<br>$I_{OH} > -12 \text{ mA}$ | #### Note: 1. The 8x sink/source pins are RB1, RC8, RC9 and RD8 pins; all other ports are 4x sink drivers. Table 33-20. Electrical Characteristics: BOR | DC Characteristics | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) <sup>(1)</sup> Operating temperature -40°C $\leq$ T <sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T <sub>A</sub> $\leq$ +125°C for Extended | | | | | | |--------------------|-----------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|---|--------------------------|--| | Param<br>No. | Symbol | Characteristic | Min. Typ. Max. Units Conditions | | | | | | | BO10 | $V_{BOR}$ | BOR Event on V <sub>DD</sub><br>Transition<br>High-to-Low | 2.68 | 2.84 | 2.99 | V | V <sub>DD</sub> (Note 2) | | - 1. Device is functional at V<sub>BORMIN</sub> < V<sub>DD</sub> < V<sub>DDMIN</sub>, but will have degraded performance. Device functionality is tested, but not characterized. Analog modules (ADC and comparators) may have degraded performance. - 2. Parameters are for design guidance only and are not tested in manufacturing. ### Table 33-21. Program Memory Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C $\leq$ T<sub>A</sub> $\leq$ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Max. | Units | Conditions | | | | | |--------------|-------------------|-----------------------------------------|--------|--------------|-------|----------------------------------------------------------------|--|--|--|--| | | | Program Flash Memory | | | | | | | | | | D130 | E <sub>P</sub> | Cell Endurance | 10,000 | <del>-</del> | E/W | -40°C to +125°C | | | | | | D131 | V <sub>PR</sub> | V <sub>DD</sub> for Read | 3.0 | 3.6 | V | | | | | | | D132b | V <sub>PEW</sub> | V <sub>DD</sub> for Self-Timed<br>Write | 3.0 | 3.6 | V | | | | | | | D134 | T <sub>RETD</sub> | Characteristic<br>Retention | 20 | _ | Year | Provided no other specifications are violated, -40°C to +125°C | | | | | | D137a | T <sub>PE</sub> | Page Erase Time | 15.3 | 16.82 | ms | T <sub>PE</sub> = 128,454 FRC cycles (Note 1) | | | | | | D138a | T <sub>WW</sub> | Word Write Time | 47.7 | 52.3 | μs | T <sub>WW</sub> = 400 FRC<br>cycles (Note 1) | | | | | | D139a | T <sub>RW</sub> | Row Write Time | 2.0 | 2.2 | ms | T <sub>RW</sub> = 16,782 FRC cycles (Note 1) | | | | | #### Note: Other conditions: FRC = 8 MHz, TUN[5:0] = 011111 (for Minimum), TUN[5:0] = 100000 (for Maximum). This parameter depends on the FRC accuracy (see Table 33-26) and the value of the FRC Oscillator Tuning register (see 9.11.4 OSCTUN). For complete details on calculating the Minimum and Maximum time, see 33.2 AC Characteristics and Timing Parameters. ## 33.2 AC Characteristics and Timing Parameters ## Figure 33-1. Load Conditions for Device Timing Specifications Load Condition 1 - for all pins except OSCO Load Condition 2 - for OSCO $RL = 464\Omega$ CL = 50 pF for all pins except OSCO 15 pF for OSCO output Table 33-22. Capacitive Loading Requirements on Output Pins | Param<br>No. | Symbol | Characteristic | Min. | Тур. | Max. | Units | Conditions | |--------------|-------------------|-----------------------|------|------|------|-------|---------------------------------------------------------------| | DO50 | C <sub>osco</sub> | OSCO Pin | _ | _ | 15 | pF | In XT and HS modes, when External Clock is used to drive OSCI | | DO56 | C <sub>IO</sub> | All I/O Pins and OSCO | _ | _ | 50 | pF | EC mode | | DO58 | C <sub>B</sub> | SCLx, SDAx | _ | _ | 400 | pF | In I <sup>2</sup> C mode | Figure 33-2. External Clock Timing **Electrical Characteristics** ## Table 33-23. External Clock Timing Requirements Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Sym | Characteristic | Min. | Тур.(1) | Max. | Units | Conditions | |--------------|-----------------------------------------|-------------------------------------------------------------------------------------|-------------|---------|-------------------------|-------|------------| | OS10 | FIN | External CLKI DC — 6 Frequency (External Clocks allowed only in EC and ECPLL modes) | | 64 | MHz | EC | | | | | Oscillator Crystal | 3.5 | _ | 10 | MHz | XT | | | | Frequency | 10 | _ | 32 | MHz | нѕ | | OS20 | Tosc | Tosc = 1/Fosc | 15.6 | _ | DC | ns | | | OS25 | TCY | Instruction Cycle Time(2) | 10 | _ | DC | ns | | | OS30 | T <sub>OS</sub> L,<br>T <sub>OS</sub> H | External Clock in<br>(OSCI)<br>High or Low Time | 0.45 x TOSC | _ | 0.55 x T <sub>OSC</sub> | ns | EC | | OS31 | TosR,<br>TosF | External Clock in<br>(OSCI)<br>Rise or Fall Time | _ | _ | 20 | ns | EC | | OS40 | TCKR | CLKO Rise Time(3,4) | _ | 5.4 | _ | ns | | | OS41 | TCKF | CLKO Fall Time(3,4) | | 6.4 | _ | ns | | - 1. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 2. Instruction cycle period (TCY) equals two times the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type, under standard operating conditions, with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "Minimum" values with an External Clock applied to the OSCI pin. When an External Clock input is used, the "Maximum" cycle time limit is "DC" (no clock) for all devices. - 3. Measurements are taken in EC mode. The CLKO signal is measured on the OSCO pin. - 4. This parameter is characterized but not tested in manufacturing. # **Electrical Characteristics** .....continued Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Sym | Characteristic | Min. | Тур. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|-----|-----------------------------------------|------|---------------------|------|-------|-------------------------------| | OS42 | GM | External Oscillator Transconductance(3) | 2.7 | _ | 4 | mA/V | XTCFG[1:0] = 00,<br>XTBST = 0 | | | | | 4 | _ | 7 | mA/V | XTCFG[1:0] = 00,<br>XTBST = 1 | | | | | | 4.5 | _ | 7 | mA/V | | | | | 6 | _ | 11.9 | mA/V | XTCFG[1:0] = 01,<br>XTBST = 1 | | | | | 5.9 | _ | 9.7 | mA/V | XTCFG[1:0] = 10,<br>XTBST = 0 | | | | | 6.9 | _ | 15.9 | mA/V | XTCFG[1:0] = 10,<br>XTBST = 1 | | | | | 6.7 | _ | 12 | mA/V | XTCFG[1:0] = 11,<br>XTBST = 0 | | | | | 7.5 | _ | 19 | mA/V | XTCFG[1:0] = 11,<br>XTBST = 1 | - 1. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 2. Instruction cycle period (TCY) equals two times the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type, under standard operating conditions, with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "Minimum" values with an External Clock applied to the OSCI pin. When an External Clock input is used, the "Maximum" cycle time limit is "DC" (no clock) for all devices. - 3. Measurements are taken in EC mode. The CLKO signal is measured on the OSCO pin. - 4. This parameter is characterized but not tested in manufacturing. ## Table 33-24. PLL Clock Timing Specifications Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq T_A \leq +85$ °C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic | | Typ. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|-------------------|---------------------------------------------------------------|---|---------------------|------|-------|--------------------| | OS50 | F <sub>PLLI</sub> | PLL Voltage Controlled Oscillator (VCO) Input Frequency Range | | _ | 64 | MHz | ECPLL, XTPLL modes | | OS51 | F <sub>VCO</sub> | On-Chip VCO System Frequency | | _ | 1600 | MHz | | | OS52 | T <sub>LOCK</sub> | PLL Start-up Time (Lock Time) | _ | 60 | _ | μs | | #### Notes: - Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - Inclusive of FRC Tolerance Specification, Parameter F20a. ## Table 33-25. Auxiliary PLL Clock Timing Specifications Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic | | Typ. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|-------------------|----------------------------------------------------------------|---|---------------------|------|-------|--------------------| | OS50 | F <sub>PLLI</sub> | APLL Voltage Controlled Oscillator (VCO) Input Frequency Range | | _ | 64 | MHz | ECPLL, XTPLL modes | | OS51 | F <sub>VCO</sub> | On-Chip VCO System Frequency | | _ | 1600 | MHz | | | OS52 | T <sub>LOCK</sub> | APLL Start-up Time (Lock Time) | _ | 125 | _ | μs | | - Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - Inclusive of FRC Tolerance Specification, Parameter F20a. Table 33-26. Internal FRC Accuracy Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param No. | Characteristic | Min. | Max. | Units | Conditions | | | | | | |--------------------------------------------------------------|----------------|-------|------|-------|---------------------------------|--|--|--|--|--| | Internal FRC Accuracy @ FRC Frequency = 8 MHz <sup>(1)</sup> | | | | | | | | | | | | F20a | FRC | -2(2) | +2 | % | -40°C ≤ T <sub>A</sub> ≤ 0°C | | | | | | | | | -1.5 | +1.5 | % | 0°C ≤ T <sub>A</sub> ≤ +85°C | | | | | | | | | -2 | +2 | % | +85°C ≤ T <sub>A</sub> ≤ +125°C | | | | | | | F22 | BFRC/LPRC | -17 | +17 | % | -40°C ≤ T <sub>A</sub> ≤ +125°C | | | | | | #### Notes: - 1. Frequency is calibrated at +25°C and 3.3V. TUNx bits can be used to compensate for temperature drift. - 2. Due to the effect of aging, this value may drift by an additional -0.5% over the lifetime of the device Figure 33-3. I/O Timing Characteristics Table 33-27. I/O Timing Requirements Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|-------------------|--------------------------------------|------|---------------------|------|-----------------|------------| | DO31 | T <sub>IO</sub> R | Port Output Rise Time <sup>(2)</sup> | _ | 6.5 | 9.7 | ns | | | DO32 | T <sub>IO</sub> F | Port Output Fall Time <sup>(2)</sup> | _ | 3.2 | 4.2 | ns | | | DI35 | T <sub>INP</sub> | INTx Pin High or Low Time (input) | 20 | _ | _ | ns | | | DI40 | T <sub>RBP</sub> | CNx High or Low Time (input) | 2 | _ | _ | T <sub>CY</sub> | | - 1. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 2. This parameter is characterized but not tested in manufacturing. Figure 33-4. BOR and Master Clear Reset Timing Characteristics Table 33-28. Reset, Watchdog Timer, Oscillator Start-up Timer, Power-up Timer Timing Requirements Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | |--------------|-----------------------|--------------------------------------------------------------|------|-----------------------|------|-------|--------------------------------| | SY00 | T <sub>PU</sub> | Power-up Period | _ | 200 | _ | μs | | | SY10 | T <sub>OST</sub> | Oscillator Start-up Time | _ | 1024 T <sub>OSC</sub> | _ | _ | T <sub>OSC</sub> = OSCI period | | SY13 | T <sub>IOZ</sub> | I/O High-Impedance from MCLR<br>Low or Watchdog Timer Reset | _ | 1.5 | _ | μs | | | SY20 | T <sub>MCLR</sub> | MCLR Pulse Width (low) | 2 | _ | - | μs | | | SY30 | T <sub>BOR</sub> | BOR Pulse Width (low) | 1 | _ | _ | μs | | | SY35 | T <sub>FSCM</sub> | Fail-Safe Clock Monitor Delay | _ | 500 | 900 | μs | -40°C to +85°C | | SY36 | TV <sub>REG</sub> | Voltage Regulator Standby-to-<br>Active mode Transition Time | _ | _ | 40 | μs | Clock fail to BFRC switch | | SY37 | Toscofrc | FRC Oscillator Start-up Delay | | <del>-</del> | 15 | μs | From POR event | | SY38 | T <sub>OSCDLPRC</sub> | LPRC Oscillator Start-up Delay | _ | _ | 50 | μs | From Reset event | - 1. These parameters are characterized but not tested in manufacturing - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. Figure 33-5. High-Speed PWMx Module Fault Timing Characteristics Figure 33-6. High-Speed PWMx Module Timing Characteristics Table 33-29. High-Speed PWMx Module Timing Requirements Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Тур. | Max. | Units | Conditions | |--------------|-------------------|----------------------------------|------|------|------|-------|--------------------------| | MP00 | F <sub>IN</sub> | PWM Input Frequency | _ | | 500 | MHz | (Note 2) | | MP10 | T <sub>FPWM</sub> | PWMx Output Fall Time | _ | _ | _ | ns | See Parameter DO32 | | MP11 | T <sub>RPWM</sub> | PWMx Output Rise Time | _ | _ | _ | ns | See Parameter DO31 | | MP20 | T <sub>FD</sub> | Fault Input ↓ to PWMx I/O Change | _ | _ | 26 | ns | PCI Inputs 19 through 22 | | MP30 | T <sub>FH</sub> | Fault Input Pulse Width | 8 | _ | _ | ns | | - 1. These parameters are characterized but not tested in manufacturing. - 2. Input frequency of 500 MHz must be used for High-Resolution mode. Table 33-30. SPIx Maximum Data/Clock Rate Summary | SPI Host<br>Transmit Only<br>(Half-Duplex) | SPI Host<br>Transmit/<br>Receive<br>(Full-Duplex) | SPI Client<br>Transmit/<br>Receive<br>(Full-Duplex) | CKE | Maximum<br>Data Rate (MHz) | Condition | |--------------------------------------------|---------------------------------------------------|-----------------------------------------------------|-----|----------------------------|---------------| | Figure 33-7 | _ | _ | 0 | 15 | Using PPS | | Figure 33-8 | | | | 40 | Dedicated Pin | | Figure 33-8 | _ | — | 1 | 15 | Using PPS | | Table 33-31 | | | | 40 | Dedicated Pin | | _ | Figure 33-9 | _ | 0 | 9 | Using PPS | | | Table 33-32 | | | 40 | Dedicated Pin | | _ | Figure 33-10 | _ | 1 | 9 | Using PPS | | | Table 33-33 | | | 40 | Dedicated Pin | | _ | _ | Figure 33-11 | 0 | 15 | Using PPS | | | | Table 33-34 | | 40 | Dedicated Pin | | _ | — Figure 33-12 1 | | 15 | Using PPS | | | | | Table 33-35 | | 40 | Dedicated Pin | Figure 33-7. SPIx Host Mode (Half-Duplex, Transmit Only, CKE = 0) Timing Characteristics Figure 33-8. SPIx Host Mode (Half-Duplex, Transmit Only, CKE = 1) Timing Characteristics Table 33-31. SPIx Host Mode (Half-Duplex, Transmit Only) Timing Requirements Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | |--------------|---------------------------------------------------------------------------|----------------------------------------|----------|---------------------|------|-------|-----------------------------| | SP10 | F <sub>SC</sub> P | Maximum SCKx Frequency | _ | _ | 15 | MHz | Using PPS pins | | | | | _ | _ | 40 | MHz | SPI2 dedicated pins | | SP20 | T <sub>SC</sub> F | SCKx Output Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | SP21 | T <sub>SC</sub> R | SCKx Output Rise Time | _ | _ | _ | ns | See Parameter DO31 (Note 3) | | SP30 | T <sub>DO</sub> F | SDOx Data Output Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | SP31 | T <sub>DO</sub> R | SDOx Data Output Rise Time | <u> </u> | _ | _ | ns | See Parameter DO31 (Note 3) | | SP35 | T <sub>SC</sub> H2 <sub>DO</sub> V,<br>T <sub>SC</sub> L2 <sub>DO</sub> V | SDOx Data Output Valid After SCKx Edge | | 6 | 20 | ns | | | | T <sub>DI</sub> V2 <sub>SC</sub> H, | | 30 | _ | _ | ns | Using PPS pins | | | T <sub>DI</sub> V2 <sub>SC</sub> L | First SCKx Edge | 3 | _ | _ | ns | SPI2 dedicated pins | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. Figure 33-9. SPIx Host Mode (Full-Duplex, CKE = 1, CKP = x, SMP = 1) Timing Characteristics Table 33-32. SPIx Host Mode (Full-Duplex, CKE = 1, CKP = x, SMP = 1) Timing Requirements Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | |--------------|---------------------------------------------------------------------------|-------------------------------------------|------|---------------------|------|-------|-----------------------------| | SP10 | F <sub>SC</sub> P | Maximum SCKx Frequency | _ | _ | 15 | MHz | Using PPS pins | | | | | _, | _ | 40 | MHz | SPI2 dedicated pins | | SP20 | T <sub>SC</sub> F | SCKx Output Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | SP21 | T <sub>SC</sub> R | SCKx Output Rise Time | _ | <u> </u> | _ | ns | See Parameter DO31 (Note 3) | | SP30 | T <sub>DO</sub> F | SDOx Data Output Fall<br>Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | SP31 | T <sub>DO</sub> R | SDOx Data Output Rise<br>Time | _ | ) <del>-</del> | - | ns | See Parameter DO31 (Note 3) | | SP35 | T <sub>SC</sub> H2 <sub>DO</sub> V,<br>T <sub>SC</sub> L2 <sub>DO</sub> V | SDOx Data Output Valid<br>After SCKx Edge | | 6 | 20 | ns | | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. ## .....continued Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | |--------------|-----------------------------------------------------------------------------|-------------------------------|------|---------------------|------|-------|---------------------| | SP36 | DO 307 | SDOx Data Output Setup to | 30 | _ | _ | ns | Using PPS pins | | | T <sub>DO</sub> V2 <sub>SC</sub> L | First SCKx Edge | 3 | _ | _ | ns | SPI2 dedicated pins | | SP40 | T <sub>DI</sub> V2 <sub>SC</sub> H, | Setup Time of SDIx Data | 30 | _ | _ | ns | Using PPS pins | | | T <sub>DI</sub> V2 <sub>SC</sub> L Input to S | Input to SCKx Edge | 20 | _ | _ | ns | SPI2 dedicated pins | | SP41 | P41 T <sub>SC</sub> H2 <sub>DI</sub> L, Hold Time of SDIx Input to SCKx Edg | Hold Time of SDIx Data | 30 | _ | _ | ns | Using PPS pins | | | | Input to SCKx Edge | 15 | _ | _ | ns | SPI2 dedicated pins | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. Figure 33-10. SPIx Host Mode (Full-Duplex, CKE = 0, CKP = $\mathbf{x}$ , SMP = 1) Timing Characteristics **Electrical Characteristics** Table 33-33. SPIx Host Mode (Full-Duplex, CKE = 0, CKP = $\mathbf{x}$ , SMP = 1) Timing Requirements Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Тур. <sup>(2)</sup> | Max. | Units | Conditions | |--------------|---------------------------------------------------------------------------|-------------------------------------------|------|---------------------|------|-------|-----------------------------| | SP10 | F <sub>SC</sub> P | Maximum SCKx Frequency | _ | _ | 15 | MHz | Using PPS pins | | | | | _ | _ | 40 | MHz | SPI2 dedicated pins | | SP20 | T <sub>SC</sub> F | SCKx Output Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | SP21 | T <sub>SC</sub> R | SCKx Output Rise Time | _ | _ | _ | ns | See Parameter DO31 (Note 3) | | SP30 | T <sub>DO</sub> F | SDOx Data Output Fall<br>Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | SP31 | T <sub>DO</sub> R | SDOx Data Output Rise<br>Time | _ | _ | _ | ns | See Parameter DO31 (Note 3) | | SP35 | T <sub>SC</sub> H2 <sub>DO</sub> V,<br>T <sub>SC</sub> L2 <sub>DO</sub> V | SDOx Data Output Valid<br>After SCKx Edge | _ | 6 | 20 | ns | | | SP36 | T <sub>DO</sub> V2 <sub>SC</sub> H, | SDOx Data Output Setup to | 30 | - | _ | ns | Using PPS pins | | | T <sub>DO</sub> V2 <sub>SC</sub> L | First SCKx Edge | 20 | _ | _ | ns | SPI2 dedicated pins | | SP40 | TdiV2 <sub>SC</sub> H, | Setup Time of SDIx Data | 30 | _ | _ | ns | Using PPS pins | | | TdiV2 <sub>SC</sub> L | Input to SCKx Edge | 10 | _ | · | ns | SPI2 dedicated pins | | SP41 | T <sub>SC</sub> H2 <sub>DI</sub> L, | Hold Time of SDIx | 30 | _ | _ | ns | Using PPS pins | | | T <sub>SC</sub> L2 <sub>DI</sub> L | Data Input<br>to SCKx Edge | 15 | _ | _ | ns | SPI2 dedicated pins | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. Figure 33-11. SPIx Client Mode (Full-Duplex, CKE = 0, CKP = x, SMP = 0) Timing Characteristics Table 33-34. SPIx Client Mode (Full-Duplex, CKE = 0, CKP = x, SMP = 0) Timing Requirements Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial # -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Char. <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | | | |--------------|-------------------|----------------------------------|------|---------------------|------|-------|-----------------------------|--|--|--| | SP10 | F <sub>SC</sub> P | Maximum SCKx<br>Input Frequency | _ | _ | 15 | MHz | Using PPS pins | | | | | | | | _ | _ | 40 | MHz | SPI2 dedicated pins | | | | | SP72 | T <sub>SC</sub> F | SCKx Input Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | | | | SP73 | T <sub>SC</sub> R | SCKx Input Rise<br>Time | _ | _ | _ | ns | See Parameter DO31 (Note 3) | | | | | SP30 | T <sub>DO</sub> F | SDOx Data<br>Output Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | | | | SP31 | T <sub>DO</sub> R | SDOx Data<br>Output Rise<br>Time | _ | _ | _ | ns | See Parameter DO31 (Note 3) | | | | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. **Electrical Characteristics** # .....continued Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ $T_A$ ≤ +125°C for Extended | Param<br>No. | Symbol | Char. <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | |--------------|---------------------------------------------------------------------------|--------------------------------------------------|--------------------------|---------------------|------|-------|------------------------| | SP35 | T <sub>SC</sub> H2 <sub>DO</sub> V,<br>T <sub>SC</sub> L2 <sub>DO</sub> V | SDOx Data<br>Output Valid<br>After<br>SCKx Edge | _ | 6 | 20 | ns | | | SP36 | T <sub>DO</sub> V2 <sub>SC</sub> H,<br>T <sub>DO</sub> V2 <sub>SC</sub> L | SDOx Data<br>Output Setup to | 30 | _ | | ns | Using PPS pins | | | | First SCKx<br>Edge | 20 | _ | _ | ns | SPI2<br>dedicated pins | | SP40 | T <sub>DI</sub> V2 <sub>SC</sub> H,<br>T <sub>DI</sub> V2 <sub>SC</sub> L | Setup Time of<br>SDIx Data Input<br>to SCKx Edge | 30 | _ | _ | ns | Using PPS pins | | | | | 10 | _ | _ | ns | SPI2 dedicated pins | | SP41 | T <sub>SC</sub> H2 <sub>DI</sub> L,<br>T <sub>SC</sub> L2 <sub>DI</sub> L | Hold Time of<br>SDIx Data Input | 30 | _ | _ | ns | Using PPS pins | | | | to SCKx Edge | 15 | _ | _ | ns | SPI2<br>dedicated pins | | SP50 | T <sub>SS</sub> L2 <sub>SC</sub> H,<br>T <sub>SS</sub> L2 <sub>SC</sub> L | SSx ↓ to SCKx ↑<br>or SCKx ↓ Input | 120 | _ | _ | ns | | | SP51 | T <sub>SS</sub> H2 <sub>DO</sub> Z | SSx ↑ to SDOx<br>Output<br>High-Impedance | 8 | _ | 50 | ns | (Note 3) | | SP52 | T <sub>SC</sub> H2 <sub>SS</sub> H,<br>T <sub>SC</sub> L2 <sub>SS</sub> H | SSx ↑ After<br>SCKx Edge | 1.5 T <sub>CY</sub> + 40 | _ | _ | ns | (Note 3) | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. Figure 33-12. SPIx Client Mode (Full-Duplex, CKE = 1, CKP = $\mathbf{x}$ , SMP = 0) Timing Characteristics Table 33-35. SPIx Client Mode (Full-Duplex, CKE = 1, CKP = x, SMP = 0) Timing Requirements Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ.(2) | Max. | Units | Conditions | | | | | |--------------|-------------------|-------------------------------|------|---------|------|-------|--------------------------------|--|--|--|--| | SP10 | FSCP | Maximum SCKx | _ | _ | 15 | MHz | Using PPS pins | | | | | | | | Input<br>Frequency | _ | _ | 40 | MHz | SPI2 dedicated pins | | | | | | SP72 | TSCF | SCKx Input Fall<br>Time | _ | _ | _ | ns | See Parameter DO32 (Note 3) | | | | | | SP73 | T <sub>SC</sub> R | SCKx Input Rise<br>Time | _ | _ | _ | ns | See Parameter DO31 (Note 3) | | | | | | SP30 | T <sub>DO</sub> F | SDOx Data Output<br>Fall Time | _ | _ | _ | ns | See Parameter<br>DO32 (Note 3) | | | | | | SP31 | T <sub>DO</sub> R | SDOx Data Output<br>Rise Time | _ | _ | _ | ns | See Parameter<br>DO31 (Note 3) | | | | | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. # **Electrical Characteristics** # .....continued **Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated)** Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ.(2) | Max. | Units | Conditions | |--------------|---------------------------------------------------------------------------|----------------------------------------------|--------------------------|---------|------|-------|---------------------| | SP35 | T <sub>SC</sub> H2 <sub>DO</sub> V,<br>T <sub>SC</sub> L2 <sub>DO</sub> V | SDOx Data Output<br>Valid After<br>SCKx Edge | - | 6 | 20 | ns | | | SP36 | TDOV2scH, | SDOx Data Output | 30 | _ | _ | ns | Using PPS pins | | | T <sub>DO</sub> V2 <sub>SC</sub> L | Setup to<br>First SCKx Edge | 20 | _ | _ | ns | SPI2 dedicated pins | | SP40 | T <sub>DI</sub> V2 <sub>SC</sub> H, | Setup Time of | 30 | _ | _ | ns | Using PPS pins | | | T <sub>DI</sub> V2 <sub>SC</sub> L | SDIx Data Input<br>to SCKx Edge | 10 | _ | _ | ns | SPI2 dedicated pins | | SP41 | , 00, | Hold Time of SDIx | 30 | _ | _ | ns | Using PPS pins | | | T <sub>SC</sub> L2 <sub>DI</sub> L | Data Input<br>to SCKx Edge | 15 | _ | _ | ns | SPI2 dedicated pins | | SP50 | T <sub>SS</sub> L2 <sub>SC</sub> H,<br>T <sub>SS</sub> L2 <sub>SC</sub> L | SSx ↓ to SCKx ↑<br>or SCKx ↓ Input | 120 | _ | _ | ns | | | SP51 | T <sub>SS</sub> H2doZ | SSx ↑ to SDOx<br>Output<br>High-Impedance | 8 | _ | 50 | ns | (Note 3) | | SP52 | T <sub>SC</sub> H2 <sub>SS</sub> H,<br>T <sub>SC</sub> L2 <sub>SS</sub> H | SSx ↑ After SCKx<br>Edge | 1.5 T <sub>CY</sub> + 40 | _ | _ | ns | (Note 3) | | SP60 | T <sub>SS</sub> L2 <sub>DO</sub> V | SDOx Data Output<br>Valid After SSx<br>Edge | _ | _ | 50 | ns | | - 1. These parameters are characterized but not tested in manufacturing. - 2. Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. - 3. Assumes 50 pF load on all SPIx pins. Figure 33-13. I2Cx Bus Start/Stop Bits Timing Characteristics (Host Mode) Figure 33-14. I2Cx Bus Data Timing Characteristics (Host Mode) Table 33-36. I2Cx Bus Data Timing Requirements (Host Mode) Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(4)</sup> | | Min. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|---------|-------------------------------|------------------------------|---------------------------|------|-------|------------| | IM10 | Tlo:scl | Clock Low<br>Time | 100 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | - | μs | | | | | | 400 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | | | | | | 1 MHz<br>mode <sup>(2)</sup> | T <sub>CY</sub> (BRG + 1) | _ | μs | | - 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. Typical value for this parameter is 130 ns. - 4. These parameters are characterized but not tested in manufacturing. **Electrical Characteristics** ## .....continued Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Charact | eristic <sup>(4)</sup> | Min. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|--------------|-------------------------------|------------------------------|----------------------------------|-----------------|-------|----------------------------------| | IM11 | Thi:scl | Clock High<br>Time | 100 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | | | | | | 400 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | | | | | | 1 MHz<br>mode <sup>(2)</sup> | T <sub>CY</sub> (BRG + 1) | _ | μs | | | IM20 | Tf:scl | SDAx and<br>SCLx | 100 kHz<br>mode | _ | 300 | ns | Cb is specified to be from 10 to | | | | Fall Time | 400 kHz<br>mode | 20 x (V <sub>DD</sub> /<br>5.5V) | 300 | ns | 400 pF | | | | | 1 MHz<br>mode <sup>(2)</sup> | _ | 120 | ns | | | IM21 | Tr:scl | SDAx and<br>SCLx<br>Rise Time | 100 kHz<br>mode | _ | 1000 | ns | Cb is specified to be from 10 to | | | | | 400 kHz<br>mode | 20 + 0.1 Cb | 300 | ns | 400 pF | | | | | 1 MHz<br>mode <sup>(2)</sup> | _ | 120 | ns | | | IM25 | Tsu:dat | Data Input<br>Setup Time | 100 kHz<br>mode | 250 | _ | ns | | | | | | 400 kHz<br>mode | 100 | _ | ns | | | | | | 1 MHz<br>mode <sup>(2)</sup> | 50 | s <del></del> - | ns | | | IM26 | IM26 Thd:dat | Hold Time | 100 kHz<br>mode | 0 | _ | μs | | | | | | 400 kHz<br>mode | 0 | 0.9 | μs | | | | | | 1 MHz<br>mode <sup>(2)</sup> | 0 | 0.3 | μs | | - 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. Typical value for this parameter is 130 ns. - 4. These parameters are characterized but not tested in manufacturing. ## .....continued Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Charact | Characteristic <sup>(4)</sup> | | Max. | Units | Conditions | |--------------|--------------|---------------------------------|-------------------------------|---------------------------|------|-------|--------------------------------------| | IM30 | Tsu:sta | Start<br>Condition | 100 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | Only relevant for Repeated | | | | Setup Time | 400 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | Start<br>condition | | | | | 1 MHz<br>mode <sup>(2)</sup> | T <sub>CY</sub> (BRG + 1) | _ | μs | | | IM31 | Thd:sta | Start<br>Condition | 100 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | After this period, the | | | | Hold Time | 400 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | first clock pulse<br>is<br>generated | | | | | 1 MHz<br>mode <sup>(2)</sup> | T <sub>CY</sub> (BRG + 1) | _ | μs | | | IM33 | Tsu:sto | Stop<br>Condition<br>Setup Time | 100 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | | | | | | 400 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | | | | | | 1 MHz<br>mode <sup>(2)</sup> | T <sub>CY</sub> (BRG + 1) | _ | μs | | | IM34 | Thd:sto | Stop<br>Condition | 100 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | | | | | Hold Time | 400 kHz<br>mode | T <sub>CY</sub> (BRG + 1) | _ | μs | | | | | | 1 MHz<br>mode <sup>(2)</sup> | T <sub>CY</sub> (BRG + 1) | _ | μs | | | IM40 | IM40 Taa:scl | Output Valid from Clock | 100 kHz<br>mode | _ | 3450 | ns | | | | | | 400 kHz<br>mode | _ | 900 | ns | | | | | | 1 MHz<br>mode <sup>(2)</sup> | _ | 450 | ns | | - 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. Typical value for this parameter is 130 ns. - 4. These parameters are characterized but not tested in manufacturing. ## .....continued Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic <sup>(4)</sup> | | Min. <sup>(1)</sup> | Max. | Units | Conditions | |--------------|---------|-------------------------------|------------------------------|---------------------|------|-------|-------------------------------------------| | IM45 | Tbf:sda | Bus Free<br>Time | 100 kHz<br>mode | 4.7 | _ | μs | Time the bus must be free | | | | | 400 kHz<br>mode | 1.3 | _ | μs | before a new<br>transmission<br>can start | | | | | 1 MHz<br>mode <sup>(2)</sup> | 0.5 | _ | μs | | | IM50 | Cb | Bus Capacitiv | e Loading | _ | 400 | pF | | | IM51 | Tpgd | Pulse Gobble | r Delay | 65 | 390 | ns | (Note 3) | - 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. Typical value for this parameter is 130 ns. - 4. These parameters are characterized but not tested in manufacturing. Figure 33-15. I2Cx Bus Start/Stop Bits Timing Characteristics (Client Mode) Figure 33-16. I2Cx Bus Data Timing Characteristics (Client Mode) # Table 33-37. I2Cx Bus Data Timing Requirements (Client Mode) Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param No. | Symbol | Charact | Characteristic <sup>(3)</sup> | | Max. | Units | Conditions | | |-----------|-------------|---------------------------------|-------------------------------|----------------------------------|-----------------|-------|------------------------------------------------------|----| | IS10 | Tlo:scl | Clock Low<br>Time | 100 kHz<br>mode | 4.7 | _ | μs | | | | | | | 400 kHz<br>mode | 1.3 | _ | μs | | | | | | | 1 MHz<br>mode <sup>(1)</sup> | 0.5 | _ | μs | | | | IS11 | Thi:scl | Clock High<br>Time | 100 kHz<br>mode | 4.0 | | μs | Device must<br>operate at a<br>minimum of<br>1.5 MHz | | | | | | | | 400 kHz<br>mode | 0.6 | _ | μs | | | | | 1 MHz<br>mode <sup>(1)</sup> | 0.28 | | με | | | | IS20 | Tf:scl | SDAx and<br>SCLx | 100 kHz<br>mode | _ | 300 | ns | Cb is specified to be from | | | | | Fall Time | 400 kHz<br>mode | 20 x (V <sub>DD</sub> /<br>5.5V) | 300 | ns | 10 to 400 pF | | | | | | 1 MHz<br>mode <sup>(1)</sup> | 20 x (V <sub>DD</sub> /<br>5.5V) | 120 | ns | | | | IS21 | Tr:scl | SDAx and SCLx | 100 kHz<br>mode | 20 + 0.1 Cb | 1000 | ns | Cb is specified to be from | | | | | Rise Time | 400 kHz<br>mode | | 300 | ns | 10 to 400 pF | | | | | | 1 MHz<br>mode <sup>(1)</sup> | _ | 120 | ns | | | | IS25 | S25 Tsu:dat | Su:dat Data Input<br>Setup Time | 100 kHz<br>mode | 250 | _ | ns | | | | | | | 400 kHz<br>mode | 100 | _ | ns | | | | | | | 1 MHz<br>mode <sup>(1)</sup> | 50 | _ | ns | | | - 1. Maximum Pin Capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). - 2. Typical value for this parameter is 130 ns. - 3. These parameters are characterized but not tested in manufacturing. **Electrical Characteristics** # .....continued Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param No. | Symbol | Charact | eristic <sup>(3)</sup> | Min. | Max. | Units | Conditions | |-----------|-----------------------------------|--------------------------|------------------------------|------|------|-------|---------------------------------------------------| | IS26 | Thd:dat | Data Input<br>Hold Time | 100 kHz<br>mode | 0 | _ | μs | | | | | | 400 kHz<br>mode | 0 | 0.9 | μs | | | | | | 1 MHz<br>mode <sup>(1)</sup> | 0 | 0.3 | μs | | | IS30 | Tsu:sta | Start<br>Condition | 100 kHz<br>mode | 4.7 | _ | μs | Only relevant for Repeated | | | | Setup Time | 400 kHz<br>mode | 0.6 | _ | μs | Start condition | | | | | 1 MHz<br>mode <sup>(1)</sup> | 0.26 | _ | μs | | | IS31 | Thd:sta Start Condition Hold Time | Condition | 100 kHz<br>mode | 4.0 | _ | μs | After this period,<br>the first clock<br>pulse is | | | | noid fille | 400 kHz<br>mode | 0.6 | _ | μs | generated | | | | | 1 MHz<br>mode <sup>(1)</sup> | 0.26 | _ | μs | | | IS33 | Tsu:sto | Stop<br>Condition | 100 kHz<br>mode | 4 | _ | μs | | | | | Setup Time | 400 kHz<br>mode | 0.6 | _ | μs | | | | | | 1 MHz<br>mode <sup>(1)</sup> | 0.26 | _ | μs | | | IS34 The | Thd:sto | Stop Condition Hold Time | 100 kHz<br>mode | > 0 | _ | μs | | | | | | 400 kHz<br>mode | > 0 | _ | μs | | | | | | 1 MHz<br>mode <sup>(1)</sup> | > 0 | | μs | | - 1. Maximum Pin Capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). - 2. Typical value for this parameter is 130 ns. - 3. These parameters are characterized but not tested in manufacturing. # .....continued Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param No. | Symbol | Charact | eristic <sup>(3)</sup> | Min. | Max. | Units | Conditions | |-----------|------------------|------------------------------|------------------------------|------|-------------|-------|-------------------------------------| | IS40 | Taa:scl | Output Valid from Clock | 100 kHz<br>mode | 0 | 3540 | ns | | | | | | 400 kHz<br>mode | 0 | 900 | ns | | | | | 1 MHz<br>mode <sup>(1)</sup> | | 0 | 400 | ns | | | IS45 | Tbf:sda | Bus Free<br>Time | 100 kHz<br>mode | 4.7 | <del></del> | μs | Time the bus must be free | | | | | 400 kHz<br>mode | 1.3 | _ | μs | before a new transmission can start | | | | | 1 MHz<br>mode <sup>(1)</sup> | 0.5 | _ | μs | | | IS50 | C <sub>B</sub> | Bus Capacitiv | e Loading | _ | 400 | pF | | | IS51 | T <sub>PGD</sub> | Pulse Gobble | r Delay | 65 | 390 | ns | (Note 2) | - 1. Maximum Pin Capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). - 2. Typical value for this parameter is 130 ns. - 3. These parameters are characterized but not tested in manufacturing. Figure 33-17. UARTx Module I/O Timing Characteristics ## Table 33-38. UARTx Module I/O Timing Requirements **Standard Operating Conditions: 3.0V to 3.6V** (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +125°C | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min. | Тур. <sup>(2)</sup> | Max. | Units | Conditions | |--------------|---------------------|---------------------------------------------------|------|---------------------|------|-------|------------| | UA10 | T <sub>UABAUD</sub> | UARTx Baud Time | 40 | _ | _ | ns | | | UA11 | F <sub>BAUD</sub> | UARTx Baud Frequency | _ | _ | 15 | Mbps | | | UA20 | T <sub>CWF</sub> | Start Bit Pulse Width to<br>Trigger UARTx Wake-up | 50 | _ | _ | ns | | #### Notes: - 1. These parameters are characterized but not tested in manufacturing. - Data in "Typ." column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. #### Table 33-39. ADC Module Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated)<sup>(4)</sup> Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ T∧ ≤ +125°C for Extended | -40°C ≤ T <sub>A</sub> ≤ +125°C for Extended | | | | | | | | | | |----------------------------------------------|-------------|------------------------------------------------|------------|-----------|------------------------|-------|--------------------------------------------------------------------------------------|--|--| | Param No. | Symbol | Characteristics | Min. | Typical | Max. | Units | Conditions | | | | | | | Clock R | equiremer | nts | | | | | | AD9 | FSRC | ADC Module Input<br>Frequency | _ | _ | 500 | MHz | Clock frequency selected by the CLKSELx bits | | | | AD10 | FCORESRC | ADC Control Clock<br>Frequency | _ | _ | 250 | MHz | Clock frequency after the first divider controlled by the CLKDIVx bits | | | | AD11 | FADCORE | ADC SAR Core Clock<br>Frequency | _ | _ | 70 | MHz | SAR core frequency after the second divider controlled by the ADCSx or SHRADCSx bits | | | | | | ' | Ana | log Input | | | | | | | AD12 | VINH - VINL | Full-Scale Input Span | AVSS | _ | AVDD | ٧ | | | | | AD14 | VIN | Absolute Input Voltage | AVss - 0.3 | _ | AV <sub>DD</sub> + 0.3 | V | | | | | AD17 | RIN | Recommended Impedance of Analog Voltage Source | _ | 100 | _ | W | For minimum sampling time (Note 1) | | | | AD60 | CHOLD | Capacitance | _ | 5 | _ | pF | Dedicated cores (Note 1) | | | | | | | | | | | A | | | - 1. These parameters are not characterized or tested in manufacturing. - 2. These parameters are characterized but not tested in manufacturing. - 3. Characterized with a 1 kHz sine wave. - The ADC module is functional at VBORMIN < VDD < VDDMIN, but with degraded performance. Unless otherwise stated, module functionality is ensured, but not characterized. - 5. For the dedicated core, the throughput includes 4 TADCORE sampling time and 13 TADCORE conversion time. - 6. For the shared core, the throughput includes 10 TADCORE sampling time and 13 TADCORE conversion time. - 7. Data in the "Typ" column are 3.3V, +25°C. Parameters are for design guidance only and are not tested. # **Electrical Characteristics** | <br>conti | nued | |-----------|------| | | | Operating Conditions: 3.0V to 3.6V (unless otherwise stated)<sup>(4)</sup> Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>Δ</sub> ≤ +125°C for Extended | -40°C ≤ 1 A | -40°C S A S + 125°C 101 Extended | | | | | | | | | | | |-------------|--------------------------------------|----------------------------------------------------------------|------|--------------|------|-------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Param No. | Symbol | Characteristics | Min. | Typical | Max. | Units | Conditions | | | | | | AD61 | CHOLD | Capacitance | _ | 18 | _ | pF | Shared core (Note 1) | | | | | | AD62 | RIC | Input resistance | _ | 500 | 1000 | Ω | Includes RSS (Note 1) | | | | | | AD66 | V <sub>BG</sub> | Internal Voltage Reference<br>Source | 1.14 | 1.2 | 1.26 | V | | | | | | | AD67 | FSRC | Input Frequency | _ | _ | 500 | MHz | Frequency selected by the CLKSEL[1:0] bits | | | | | | | | | _ | _ | 250 | MHz | Frequency selected by the CLKDIV[5:0] bits | | | | | | | | | ADC | Accuracy | | | | | | | | | AD20c | NR | Resolution | | 12 data bits | 3 | bits | | | | | | | AD21a | INL_1D | Dedicated Core Integral<br>Nonlinearity (1 Active<br>Core) | -3.5 | -1.5/+1.5 | +3.5 | LSb | 3.5 Msps <sup>(5)</sup> , T <sub>ADC</sub> = 4 nS (250 MHz),<br>TCORESRC = 8 nS (125 MHz),<br>TADCORE = 16 nS (62.5 MHz), | | | | | | AD22a | DNL_1D | Dedicated Core Differential<br>Nonlinearity (1 Active<br>Core) | -1.0 | -1.0/+1.5 | +3.5 | LSb | Sampling Time = 4 TADCORE,<br>VDD = 3.3V, AVDD = 3.3V | | | | | | AD23a | GERR_1D | Dedicated Core Gain Error (1 Active Core) | _ | +4 | _ | LSb | | | | | | | AD24a | OERR_1D | Dedicated Core Offset<br>Error (1 Active Core) | _ | -4 | _ | LSb | | | | | | | AD21b | INL _1S | Shared Core Integral<br>Nonlinearity (1 Active<br>Core) | -3.5 | -1.5/+1.5 | +3.5 | LSb | 2.7 Msps <sup>(6)</sup> , TADC = 4 nS (250 MHz),<br>TCORESRC = 8 nS (125 MHz),<br>TADCORE = 16 nS (62.5 MHz), | | | | | | AD22b | DNL_1S | Shared Core Differential<br>Nonlinearity (1 Active<br>Core) | -1.0 | -1/+1.5 | +3.5 | LSb | Sampling Time = 10 TADCORE,<br>VDD = 3.3V, AVDD = 3.3V | | | | | | AD23b | GERR_1S | Shared Core Gain Error<br>(1 Active Core) | _ | +4 | _ | LSb | | | | | | | AD24b | OERR_1S | Shared Core Offset Error (1 Active Core) | _ | -4 | _ | LSb | | | | | | - 1. These parameters are not characterized or tested in manufacturing. - 2. These parameters are characterized but not tested in manufacturing. - 3. Characterized with a 1 kHz sine wave. - The ADC module is functional at VBORMIN < VDD < VDDMIN, but with degraded performance. Unless otherwise stated, module functionality is ensured, but not characterized.</li> - $5. \hspace{0.5cm} \text{For the dedicated core, the throughput includes 4 Tadcore sampling time and 13 Tadcore conversion time.} \\$ - 6. For the shared core, the throughput includes 10 TADCORE sampling time and 13 TADCORE conversion time. - 7. Data in the "Typ" column are 3.3V, +25°C. Parameters are for design guidance only and are not tested. # .....continued Operating Conditions: 3.0V to 3.6V (unless otherwise stated)<sup>(4)</sup> Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ $T_A$ ≤ +125°C for Extended | Param No. | Symbol | Characteristics | Min. | Typical | Max. | Units | Conditions | | |-----------|-----------------|-----------------------------------------------------------------|---------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------|--| | AD21c | INL _5D | Dedicated Core Integral<br>Nonlinearity (5 Active<br>Cores) | _ | -8/+8 | _ | LSb | 3.5 Msps <sup>(5)</sup> , T <sub>ADC</sub> = 4 nS (250 MHz),<br>TCORESRC = 8 nS (125 MHz),<br>TADCORE = 16 nS (62.5 MHz), | | | AD22c | DNL_5D | Dedicated Core Differential<br>Nonlinearity (5 Active<br>Cores) | _ | -1.5/+3 | _ | LSb | Sampling Time = 4 TADCORE, VDD = 3.3V, AVDD = 3.3V, all core conversions are started simultaneously | | | AD23c | GERR_5D | Dedicated Core Gain Error (5 Active Cores) | <u> </u> | +9.5 | _ | LSb | | | | AD24c | OERR_5D | Dedicated Core Offset<br>Error (5 Active Cores) | _ | -9.5 | _ | LSb | | | | AD21d | INL _5S | Shared Core Integral<br>Nonlinearity (5 Active<br>Cores) | _ | -8/+8 | _ | LSb | 2.7 Msps <sup>(6)</sup> , T <sub>ADC</sub> = 4 nS (250 MHz),<br>TCORESRC = 8 nS (125 MHz),<br>TADCORE = 16 nS (62.5 MHz), | | | AD22d | DNL_5S | Shared Core Differential<br>Nonlinearity (5 Active<br>Cores) | _ | -1.5/+3 | _ | LSb | Sampling Time = 10 TADCORE, VDD = 3.3V, AVDD = 3.3V, all core conversions are started simultaneously | | | AD23d | GERR_5S | Shared Core Gain Error<br>(5 Active Cores) | <del></del> - | +9.5 | _ | LSb | | | | AD24d | OERR_5S | Shared Core Offset Error<br>(5 Active Cores) | _ | -9.5 | _ | LSb | | | | AD25c | _ | Monotonicity | _ | _ | _ | LSb | Guaranteed | | | | | | Dynamic | Performa | ıce | | | | | AD31b | SINAD | Signal-to-Noise and Distortion | 56 | _ | 70 | dB | (Notes 2, 3) | | | AD34b | ENOB | Effective Number of Bits | 9.8 | 10.2 | 11.4 | bits | (Notes 2, 3) | | | AD50 | T <sub>AD</sub> | ADC Clock Period | 14.3 | _ | _ | ns | | | | AD51 | FTP | Throughput Rate | _ | _ | 3.5 | Msps | Dedicated Cores | | | | | | _ | _ | 2.7 | Msps | Shared core | | - 1. These parameters are not characterized or tested in manufacturing. - 2. These parameters are characterized but not tested in manufacturing. - 3. Characterized with a 1 kHz sine wave. - The ADC module is functional at VBORMIN < VDD < VDDMIN, but with degraded performance. Unless otherwise stated, module functionality is ensured, but not characterized.</li> - 5. For the dedicated core, the throughput includes 4 TADCORE sampling time and 13 TADCORE conversion time. - 6. For the shared core, the throughput includes 10 TADCORE sampling time and 13 TADCORE conversion time. - 7. Data in the "Typ" column are 3.3V, +25°C. Parameters are for design guidance only and are not tested. ## Table 33-40. High-Speed Analog Comparator Module Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated)(2) Operating temperature -40°C $\leq$ T<sub>A</sub> $\leq$ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Тур. | Max. | Units | Comments | |--------------|-------------------|---------------------------------------------------|------------------|------|-----------|-------|--------------------------------------------------------------------------------| | CM09 | F <sub>IN</sub> | Input Frequency | 400 | 500 | 550 | MHz | | | CM10 | V <sub>IOFF</sub> | Input Offset Voltage | -20 | _ | +20 | mV | | | CM11 | V <sub>ICM</sub> | Input Common-Mode<br>Voltage Range <sup>(1)</sup> | AV <sub>SS</sub> | _ | $AV_{DD}$ | V | | | CM13 | CMRR | Common-Mode<br>Rejection Ratio | 60 | _ | _ | dB | | | CM14 | T <sub>RESP</sub> | Large Signal Response | _ | 15 | _ | ns | V+ input step of<br>100 mV while<br>V- input is held at<br>AV <sub>DD</sub> /2 | | CM15 | V <sub>HYST</sub> | Input Hysteresis | 15 | 30 | 45 | mV | Depends on<br>HYSSEL[1:0] | #### Notes: - 1. These parameters are for design guidance only and are not tested in manufacturing. - 2. The comparator module is functional at $V_{BORMIN} < V_{DD} < V_{DDMIN}$ , but with degraded performance. Unless otherwise stated, module functionality is tested, but not characterized. Table 33-41. DACx Module Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Symbol | Characteristic | Min. Typ. <sup>(1)</sup> Max. | | Units | Comments | | | |-------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | CV <sub>RES</sub> | Resolution | | 12 | | bits | | | | INL | Integral Nonlinearity Error | -43 | _ | 0 | LSB | | | | DNL | Differential Nonlinearity Error -5 | | ·— | 5 | LSB | | | | EOFF | Offset Error | -3.5 | _ | 25 | LSB | Internal node at comparator input | | | EG | Gain Error | 0 | - | 41 | % | Internal node at comparator input | | | T <sub>SET</sub> | Settling Time | _ | 750 | _ | ns | Output with 2% of desired output voltage with a 5-95% or 95-5% step | | | V <sub>OUT</sub> | Voltage Output Range | 0.165 — 3.135 | | V | V <sub>DD</sub> = 3.3V | | | | | CV <sub>RES</sub> INL DNL EOFF EG T <sub>SET</sub> | CV <sub>RES</sub> Resolution INL Integral Nonlinearity Error DNL Differential Nonlinearity Error EOFF Offset Error EG Gain Error T <sub>SET</sub> Settling Time | CV <sub>RES</sub> Resolution INL Integral Nonlinearity Error -43 DNL Differential Nonlinearity Error -5 EOFF Offset Error -3.5 EG Gain Error 0 T <sub>SET</sub> Settling Time — | CV <sub>RES</sub> Resolution 12 INL Integral Nonlinearity Error -43 — DNL Differential Nonlinearity Error -5 — EOFF Offset Error -3.5 — EG Gain Error 0 — T <sub>SET</sub> Settling Time — 750 | CV <sub>RES</sub> Resolution 12 INL Integral Nonlinearity Error -43 — 0 DNL Differential Nonlinearity Error -5 — 5 EOFF Offset Error -3.5 — 25 EG Gain Error 0 — 41 T <sub>SET</sub> Settling Time — 750 — | CV <sub>RES</sub> Resolution 12 bits INL Integral Nonlinearity Error -43 — 0 LSB DNL Differential Nonlinearity Error -5 — 5 LSB EOFF Offset Error -3.5 — 25 LSB EG Gain Error 0 — 41 % T <sub>SET</sub> Settling Time — 750 — ns | | #### Note: 1. Parameters are for design guidance only and are not tested in manufacturing. ## Table 33-42. DACx Output (DACOUT1 and DACOUT2 Pins) Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated)(1) Operating temperature -40°C $\leq T_A \leq +85$ °C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Symbol | Characteristic | Min. | Тур. | Max. | Units | Comments | |--------------|-------------------|----------------------------------|------|------|------|-------|----------------------------------| | DA11 | R <sub>LOAD</sub> | Resistive Output Load Impedance | 10K | _ | _ | Ohm | | | DA11a | C <sub>LOAD</sub> | Output Load Capacitance | _ | _ | 30 | pF | Including output pin capacitance | | DA12 | Гоит | Output Current Drive<br>Strength | _ | 3 | _ | mA | Sink and source | #### Note: The DACx module is functional at V<sub>BORMIN</sub> < V<sub>DD</sub> < V<sub>DDMIN</sub>, but with degraded performance. Unless otherwise stated, module functionality is tested, but not characterized. #### **Table 33-43. Constant-Current Source Specifications** Operating Conditions: 3.0V to 3.6V (unless otherwise stated)(1) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param No. | Symbol | Characteristic | Min. | Тур. | Max. | Units | Conditions | |-----------|------------------|----------------------|------|------|------|-------|------------| | CC02 | I <sub>REG</sub> | Current Regulation | _ | ±3 | _ | % | IBIASx pin | | CC03 | I10SRC | 10 μA Source Current | 8.8 | _ | 11.2 | μA | ISRCx pin | | CC04 | I50SRC | 50 μA Source Current | 44 | _ | 56 | μA | IBIASx pin | | CC05 | I50SNK | 50 μA Sink Current | -44 | _ | -56 | μA | IBIASx pin | #### Note: The constant-current source module is functional at V<sub>BORMIN</sub> < V<sub>DD</sub> < V<sub>DDMIN</sub>, but with degraded performance. Unless otherwise stated, module functionality is tested, but not characterized. ### Table 33-44. Operational Amplifier Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Sym | Characteristic | Min | Тур(1) | Max | Units | Comments | |--------------|------|---------------------------|-----|--------|-----|-------|----------| | OA01 | GBWP | Gain Bandwidth<br>Product | _ | 20 | _ | MHz | | | OA02 | SR | Slew Rate | _ | 40 | _ | V/µs | | # **Electrical Characteristics** # .....continued Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +85°C for Industrial -40°C ≤ T<sub>A</sub> ≤ +125°C for Extended | Param<br>No. | Sym | Characteristic | Min | Typ(1) | Max | Units | Comments | |--------------|-------------------|----------------------------------|-------------------|--------|------------------------|--------|-----------------------------------------------------------| | OA03 | VIOFF | Input Offset<br>Voltage | <sub>-3</sub> (3) | -1/+1 | +3(3) | mV | Unity gain configuration | | | | | <sub>-8</sub> (3) | -3/+3 | +8(3) | mV | Open-loop configuration | | OA04 | VIBC | Input Bias<br>Current | _ | _ | _ | nA | Note 2 | | OA05 | VICM | Common-Mode | AVSS | _ | AVDD | V | NCHDISx = 0 | | | | Input Voltage<br>Range | AVSS | _ | AV <sub>DD</sub> – 1.4 | V | NCHDISx = 1 | | OA07 | CMRR | Common-Mode<br>Rejection Ratio | _ | 68 | _ | dB | | | OA08 | PSRR | Power Supply<br>Rejection Ratio | _ | 74 | _ | dB | | | OA09 | Vor | Output Voltage<br>Range | AVSS | _ | AVDD | mV | 0.5V input<br>overdrive, no<br>output loading<br>(Note 1) | | OA11 | C <sub>LOAD</sub> | Output Load<br>Capacitance | _ | _ | 30 | pF | Including output pin capacitance (Note 1) | | OA12 | lout | Output Current<br>Drive Strength | _ | 3 | _ | mA | Sink and source | | OA13 | PMARGIN | Phase Margin | 44 | _ | _ | degree | Unity gain (Note 1) | | OA14 | GMARGIN | Gain Margin | 7 | _ | _ | dB | Unity gain (Note 1) | | OA15 | OLG | Open-Loop Gain | 68 | 75 | _ | dB | Note 1 | - 1. These parameters are for design guidance only and are not tested in manufacturing. - 2. The op amps use CMOS input circuitry with negligible input bias current. The maximum "effective bias current" is the I/O pin leakage specified by electrical Parameter DI50. - 3. Parameters are characterized but not tested in manufacturing. # 34. High-Temperature Electrical Characteristics This section provides an overview of the dsPIC33CK512MP608 family devices operating in an ambient temperature range of -40°C to +150°C. The specifications between -40°C to +150°C are identical to those shown in 33.1 DC Characteristics for operation between -40°C to +125°C, with the exception of the parameters listed in this section. Parameters in this section begin with an H, which denotes High temperature. Absolute maximum ratings for the dsPIC33CK512MP608 family high-temperature devices are listed below. Exposure to these maximum rating conditions for extended periods can 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. Table 34-1. Absolute Maximum Ratings(1) | -40°C to +150°C | |-----------------------------------| | -65°C to +150°C | | -0.3V to +4.0V | | -0.3V to (V <sub>DD</sub> + 0.3V) | | -0.3V to +5.5V | | -0.3V to +3.6V | | 300 mA | | 300 mA | | 15 mA | | 25 mA | | 75 mA | | 75 mA | | 200 mA | | 200 mA | | | - 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. - Maximum allowable current is a function of device maximum power dissipation (see 34.1 DC Characteristics. - 3. See the "Pin Diagrams" section for the 5V tolerant pins. - Not applicable to AV<sub>DD</sub> and AV<sub>SS</sub> pins. # 34.1 DC Characteristics # Table 34-2. Operating MIPS vs. Voltage | V <sub>DD</sub> Range | Temperature Range | Maximum CPU Clock Frequency | |-----------------------|-------------------|-----------------------------| | 3.0V to 3.6V | -40°C to +150°C | 70 MIPS | # Table 34-3. Thermal Operating Conditions | Rating | Symbol | Min. | Max. | Unit | |-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------|----------------------------------|------| | High-Temperature Devices | | | | | | Operating Junction Temperature Range | TJ | -40 | +165 | °C | | Operating Ambient Temperature Range | T <sub>A</sub> | -40 | +150 | °C | | Power Dissipation:<br>Internal Chip Power Dissipation:<br>Pint = $V_{DD} \times (I_{DD} - \Sigma I_{OH})$ | P <sub>D</sub> | P <sub>INT</sub> | + P <sub>I/O</sub> | W | | I/O Pin Power Dissipation: I/O = $\Sigma$ ({V <sub>DL</sub> - V <sub>OH</sub> } x I <sub>OH</sub> ) + $\Sigma$ (V <sub>OL</sub> x I <sub>OL</sub> ) | | | | | | Maximum Allowed Power Dissipation | P <sub>DMAX</sub> | (T <sub>J</sub> – | T <sub>A</sub> )/θ <sub>JA</sub> | W | # Table 34-4. Thermal Packaging Characteristics<sup>(1)</sup> | Characteristic | Symbol | Тур. | Unit | |------------------------------------------------------|---------------|-------|------| | Package Thermal Resistance, 80-Pin TQFP 12x12x1 mm | $\theta_{JA}$ | 50.67 | °C/W | | Package Thermal Resistance, 64-Pin TQFP 10x10x1.0 mm | $\theta_{JA}$ | 45.7 | °C/W | | Package Thermal Resistance, 64-Pin QFN 9x9 mm | $\theta_{JA}$ | 18.7 | °C/W | | Package Thermal Resistance, 48-Pin TQFP 7x7 mm | $\theta_{JA}$ | 62.76 | °C/W | | Package Thermal Resistance, 48-Pin UQFN 6x6 mm | $\theta_{JA}$ | 27.6 | °C/W | ### Note: 1. Junction to ambient thermal resistance, Theta- $_{JA}$ ( $\theta_{JA}$ ) numbers are achieved by package simulations. # Table 34-5. Operating Voltage Specifications<sup>(2)</sup> Operating Conditions: 3.0V to 3.6V (unless otherwise stated)(1) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C Param No. Characteristic Units Conditions Symbol Min. Тур. Max. **Operating Voltage** HDC10 3.0 VDD Supply Voltage 3.6 V HDC11 Supply Voltage Lesser of: ٧ The difference **AVDD** Greater of: between AVDD $V_{DD} - 0.3$ VDD + 0.3 or or 3.0 3.6 supply and V<sub>DD</sub> supply must not exceed ±300 mV at all times, including during device power-up HDC16 **VPOR VDD Start** Vss ٧ Voltage to Ensure Internal Power-on Reset Signal 0V-3V in 100 ms HDC17 SVDD **VDD Rise Rate** 0.03 V/ms to Ensure Internal Power-on Reset Signal **HBO10 BOR** Event on 2.68 2.84 2.99 V **VBOR** VDD **Transition** High-to-Low(2) - Device is functional at VBORMIN < VDD < VDDMIN. Analog modules (ADC and comparators) may have degraded performance. - Parameters are characterized but not tested. Table 34-6. DC Characteristics: Operating Current (I<sub>DD</sub>)<sup>(2)</sup> | Operating Conditions: 3.0V to 3.6V (unless otherwise stated)<br>Operating temperature -40°C $\leq$ T <sub>A</sub> $\leq$ +150°C | | | | | | | | | | |---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | Parameter No. Typ. <sup>(1)</sup> Max. Units Conditions | | | | | | | | | | | HDC20 | HDC20 16.5 33.5 mA +150°C 3.3V 10 MIPS (N1 = 1, N2 = 5, N3 = 2, M = 50, $F_{VCO}$ = 400 MHz, $F_{PLLO}$ = 40 MHz) | | | | | | | | | | HDC21 18.4 36 mA +150°C 3.3V 20 MIPS (N1 = 1, N2 = 5, N3 = 1, M = 50, F <sub>VCO</sub> = 400 MHz, F <sub>PLLO</sub> = 80 MHz) | | | | | | | | | | # **High-Temperature Electrical Characteristics** #### .....continued Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter No. | Typ. <sup>(1)</sup> | Max. | Units | Conditions | | | | |---------------|---------------------|-------|-------|------------|------|---------------------------------------------------------------------------------------------------------|--| | HDC22 | 22.7 | 40 | mA | +150°C | 3.3V | 40 MIPS (N1 = 1, N2 = 3, N3 = 1,<br>M = 60, F <sub>VCO</sub> = 480 MHz,<br>F <sub>PLLO</sub> = 160 MHz) | | | HDC23 | 28.7 | 47.75 | mA | +150°C | 3.3V | 70 MIPS (N1 = 1, N2 = 2, N3 = 1,<br>M = 70, $F_{VCO}$ = 560 MHz,<br>$F_{PLLO}$ = 280 MHz) | | #### Notes: - 1. Data in the "Typ." column are for design guidance only and are not tested. - 2. Base Run current (IDD) is measured as follows: - Oscillator is switched to EC+PLL mode in software - OSC1 pin is driven with external 8 MHz square wave with levels from 0.3V to V<sub>DD</sub> 0.3V - OSC2 is configured as an I/O in the Configuration Words (OSCIOFNC (FOSC[2]) = 0) - FSCM is disabled (FCKSM[1:0] (FOSC[7:6]) = 01) - Watchdog Timer is disabled (FWDT[15] = 0 and WDTCONL[15] = 0) - All I/O pins (except OSC1) are configured as outputs and driving low - No peripheral modules are operating or being clocked (defined PMDx bits are all '1's) - JTAG is disabled (JTAGEN (FICD[5]) = 0) - NOP instructions are executed in while (1) loop ## Table 34-7. DC Characteristics: Idle Current (I<sub>IDLE</sub>)(2) Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter No. | Typ.(1) | Max. | Units | | Conditions | | |---------------|---------|-------|-------|--------|------------|-----------------------------| | HDC40 | 15.4 | 33.25 | mA | +150°C | 3.3V | 10 MIPS (N1 = 1,<br>N2 = 5, | | | | | | | | N3 = 2, M = 50, | | | | | | | | F <sub>VCO</sub> = 400 MHz, | | | | | | | | F <sub>PLLO</sub> = 40 MHz) | - 1. Data in the "Typ." column are for design guidance only and are not tested. - 2. Base Idle current (IDLE) is measured as follows: - Oscillator is switched to EC+PLL mode in software - OSC1 pin is driven with external 8 MHz square wave with levels from 0.3V to $V_{DD}-0.3V$ - OSC2 is configured as an I/O in the Configuration Words (OSCIOFNC (FOSC[2]) = 0) - FSCM is disabled (FCKSM[1:0] (FOSC[7:6]) = 01) - Watchdog Timer is disabled (FWDT[15] = 0 and WDTCONL[15] = 0) - All I/O pins (except OSC1) are configured as outputs and driving low - No peripheral modules are operating or being clocked (defined PMDx bits are all '1's) - JTAG is disabled (JTAGEN (FICD[5]) = 0) - Flash in standby with NVMSIDL (NVMCON[12]) = 1 # **High-Temperature Electrical Characteristics** #### .....continued Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter No. | Typ.(1) | Max. | Units | | Conditions | | |---------------|---------|-------|-------|--------|------------|-----------------------------| | HDC41 | 16.1 | 33.75 | mA | +150°C | 3.3V | 20 MIPS (N1 = 1,<br>N2 = 5, | | | | | | | | N3 = 1,<br>M = 50, | | | | | | | | F <sub>VCO</sub> = 400 MHz, | | | | | | | | F <sub>PLLO</sub> = 80 MHz) | | HDC42 | 17.9 | 36.3 | mA | +150°C | 3.3V | 40 MIPS (N1 = 1,<br>N2 = 3, | | | | | | | | N3 = 1,<br>M = 60, | | | | | | | | F <sub>VCO</sub> = 480 MHz, | | | | | | | | FPLLO = 160<br>MHz) | | HDC43 | 20.4 | 39.75 | mA | +150°C | 3.3V | 70 MIPS (N1 = 1,<br>N2 = 2, | | | | | | | | N3 = 1,<br>M = 70, | | | | | | | | F <sub>VCO</sub> = 560 MHz, | | | | | | | | FPLLO = 280<br>MHz) | - 1. Data in the "Typ." column are for design guidance only and are not tested. - 2. Base Idle current (IDLE) is measured as follows: - Oscillator is switched to EC+PLL mode in software - $-\,$ OSC1 pin is driven with external 8 MHz square wave with levels from 0.3V to $V_{\mbox{DD}}$ 0.3V - OSC2 is configured as an I/O in the Configuration Words (OSCIOFNC (FOSC[2]) = 0) - FSCM is disabled (FCKSM[1:0] (FOSC[7:6]) = 01) - Watchdog Timer is disabled (FWDT[15] = 0 and WDTCONL[15] = 0) - All I/O pins (except OSC1) are configured as outputs and driving low - No peripheral modules are operating or being clocked (defined PMDx bits are all '1's) - JTAG is disabled (JTAGEN (FICD[5]) = ○) - Flash in standby with NVMSIDL (NVMCON[12]) = 1 # **High-Temperature Electrical Characteristics** # Table 34-8. Power-Down Current (IPD)(2) Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter No. | Characteristic | Typ. <sup>(1)</sup> | Max. | Units | Condit | ions | |---------------|----------------------------|---------------------|------|-------|--------|------| | HDC60 | Base Power-Down<br>Current | 11.6 | 29.2 | mA | +150°C | 3.3V | #### Notes: - 1. Data in the "Typ." column are for design guidance only and are not tested. - 2. IPD (Sleep) current is measured as follows: - CPU core is off, oscillator is configured in EC mode and External Clock is active; OSCI is driven with external square wave from rail-to-rail (EC clock overshoot/undershoot < 250 mV required) - · CLKO is configured as an I/O input pin in the Configuration Word - · All I/O pins are configured as output low - MCLR = V<sub>DD</sub>, WDT and FSCM are disabled - · All peripheral modules are disabled (PMDx bits are all set) - The VREGS bit (RCON[8]) = 0 (i.e., core regulator is set to standby while the device is in Sleep mode) - · JTAG is disabled #### Table 34-9. Doze Current (IDOZE) Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter<br>No. | Typ.(1) | Max. | Doze<br>Ratio | Units | Conditions | | | | |------------------|---------|------|---------------|-------|------------|-------|-------------------------------------|--| | HDC70 | 23.6 | 43 | 1:2 | mA | | | 70 MIPS (N = 1, | | | | 18.5 | 38.7 | 1:128 | mA | .45000 | 2.21/ | N2 = 2, N3 = 1, | | | | | | | | +150°C | 3.3V | M = 70, F <sub>VCO</sub> = 560 MHz, | | | | | | | | | | F <sub>PLLO</sub> = 280 MHz) | | #### Note: 1. Data in the "Typ." column are for design guidance only and are not tested. #### Table 34-10. PWM Delta Current(1) | Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T <sub>A</sub> ≤ +150°C | | | | | | | | | | |---------------------------------------------------------------------------------------------------------------------|------|------|-------|--------|----------|-------------------------------------------------------------------------------------------------------------|--|--|--| | Parameter No. | Тур. | Max. | Units | | Conditio | ns | | | | | HDC100 | 7 | 10 | mA | +150°C | 3.3V | PWM Output Frequency = 500 kHz, PWM Input (AFPLLO = 500 MHz) (AVCO = 1000 MHz, PLLFBD = 125, APLLDIV1 = 2) | | | | # **High-Temperature Electrical Characteristics** | continued | | continued | | | | | | | | | |-------------------------------------------------------|--------------------|------------------|-------------|--------|----------|--------------------------------------------------------------------------------------------------------------|--|--|--|--| | Operating Condi | tions: 3.0V to 3.6 | V (unless otherw | ise stated) | | | | | | | | | Operating temperature -40°C ≤ T <sub>A</sub> ≤ +150°C | | | | | | | | | | | | Parameter No. | Тур. | Max. | Units | | Conditio | ons | | | | | | HDC101 | 6 | 7.5 | mA | +150°C | 3.3V | PWM Output Frequency = 500 kHz, PWM Input (AFPLLO = 400 MHz) (AVCO = 400 MHz, PLLFBD = 50, APLLDIV1 = 1) | | | | | | HDC102 | 3 | 4 | mA | +150°C | 3.3V | PWM Output Frequency = 500 kHz, PWM Input (AFPLLO = 200 MHz) (AVCO = 400 MHz, PLLFBD = 50, APLLDIV1 = 2) | | | | | | HDC103 | 2 | 2.5 | mA | +150°C | 3.3V | PWM Output Frequency = 500 kHz, PWM Input (AFPLLO = 100 MHz) (AVCO = 400 MHz, PLLFBD = 50, APLLDIV1 = 4) | | | | | #### Note: 1. APLL current is not included. The APLL current will be the same if more than one PWM is running. Listed delta currents are for only one PWM instance when HREN = 0 (PGxCONL[7]). All parameters are characterized but not tested during manufacturing. ## Table 34-11. APLL Delta Current Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter No. | Тур. | Max. | Units | | Condition | ıs <sup>(1)</sup> | |---------------|------|------|-------|--------|-----------|---------------------------------------------------------------------------------------| | HDC110 | 9 | 18 | mA | +150°C | 3.3V | $AF_{PLLO} = 500 \text{ MHz}$<br>(AVCO = 1000 MHz,<br>PLLFBD = 125,<br>APLLDIV1 = 2) | | HDC111 | 6 | 9 | mA | +150°C | 3.3V | $AF_{PLLO} = 400 \text{ MHz}$<br>(AVCO = 400 MHz,<br>PLLFBD = 50,<br>APLLDIV1 = 1) | | HDC112 | 5 | 8 | mA | +150°C | 3.3V | $AF_{PLLO} = 200 \text{ MHz}$<br>(AVCO = 400 MHz,<br>PLLFBD = 50,<br>APLLDIV1 = 2) | | HDC113 | 4 | 8 | mA | +150°C | 3.3V | $AF_{PLLO} = 100 \text{ MHz}$<br>(AVCO = 400 MHz,<br>PLLFBD = 50,<br>APLLDIV1 = 4) | ### Note: 1. The APLL current will be the same if more than one PWM or DAC is run to the APLL clock. All parameters are characterized but not tested during manufacturing. ## Table 34-12. ADC Delta Current **Operating Conditions: 3.0V to 3.6V (unless otherwise stated)** Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter No. | Тур. | Max. | Units | Conditions | | | | | |---------------|------|------|-------|------------|------|---------------------------------------------------------|--|--| | HDC120 | _ | 8.5 | mA | +150°C | 3.3V | T <sub>AD</sub> = 14.3 ns<br>(3.5 Msps conversion rate) | | | ## Table 34-13. Comparator + DAC Delta Current Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Parameter No. | Тур. | Max. | Units | Conditions | | | |---------------|------|------|-------|------------|------|---------------------------------------------| | HDC130 | _ | 5 | mA | +150°C | 3.3V | AF <sub>PLLO</sub> @ 500 MHz <sup>(1)</sup> | ### Note: APLL current is not included. Listed delta currents are for only one comparator + DAC instance. All parameters are characterized but not tested during manufacturing. ### Table 34-14. I/O Pin Input Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Param<br>No. | Symbol | Characteristic | Min. <sup>(4)</sup> | Typ. <sup>(1)</sup> | Max. <sup>(5)</sup> | Units | Conditions | |--------------|-----------------|-----------------------------------------|---------------------|---------------------|---------------------|-------|-----------------| | HDI50 | I <sub>IL</sub> | Input Leakage Current <sup>(2)</sup> | | | | | | | | | I/O Pins 5V Tolerant <sup>(3)</sup> | -1500 | = | 1500 | nA | | | | | I/O Pins Not 5V Tolerant <sup>(3)</sup> | -700 | _ | 700 | nA | | | | | MCLR | -1500 | _ | 1500 | nA | | | | | OSCI | -750 | _ | 750 | nA | XT and HS modes | #### Notes: - 1. Data in the "Typ." column are at 3.3V, +25°C unless otherwise stated. - 2. Negative current is defined as current sourced by the pin. - 3. See the "Pin Diagrams" section for the 5V tolerant I/O pins. - 4. $V_{PIN} = V_{SS}$ . - 5. $V_{PIN} = V_{DD}$ . ### Table 34-15. Internal FRC Accuracy Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Param No. | Characteristic | Min. | Max. | Units | Conditions | | | | |--------------------------------------------------------------|----------------|------|------|-------|---------------------------------|--|--|--| | Internal FRC Accuracy @ FRC Frequency = 8 MHz <sup>(1)</sup> | | | | | | | | | | HF20 | FRC | 3 | 3 | % | -40°C ≤ T <sub>A</sub> ≤ +150°C | | | | | N-4 | | | | | | | | | ### Note: 1. Frequency is calibrated at +25°C and 3.3V. ### Table 34-16. Internal LPRC Accuracy Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | about the second | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------|------|-------|---------------------------------|--|--|--| | Param<br>No. | Characteristic | Min. | Max. | Units | Conditions | | | | | LPRC @ 32 kHz | | | | | | | | | | HF21 | LPRC | -27 | +27 | % | -40°C ≤ T <sub>A</sub> ≤ +150°C | | | | | | | -25 | +25 | % | -40°C ≤ T <sub>A</sub> ≤ 0°C | | | | | | | -10 | +10 | % | 0°C ≤ T <sub>A</sub> ≤ +85°C | | | | | | | -15 | +15 | % | +85°C ≤ T <sub>A</sub> ≤ +125°C | | | | #### Table 34-17. DACx Module Specifications Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ T<sub>A</sub> ≤ +150°C | Param<br>No. | Symbol | Characteristic | Min. | Typ. <sup>(1)</sup> | Max. | Units | Comments | |--------------|--------|-----------------------------|------|---------------------|------|-------|-----------------------------------| | HDA03 | INL | Integral Nonlinearity Error | -50 | _ | 0 | LSB | | | HDA05 | EOFF | Offset Error | 0 | _ | 45 | LSB | Internal node at comparator input | | HDA06 | EG | Gain Error | 0 | _ | 50 | % | Internal node at comparator input | #### Note: 1. Parameters are for design guidance only and are not tested in manufacturing. ## 35. Packaging Information ### 35.1 Package Marking Information 48-Lead TQFP (7x7 mm) Example 48-Lead VQFN (6x6 mm) Example 64-Lead TQFP (10x10x1 mm) Example Legend: XX...X Customer-specific information 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 **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. ## 35.2 Package Marking Information (Continued) 64-Lead QFN (9x9x0.9 mm) Example 80-Lead TQFP (12x12x1 mm) Example ## 35.3 Package Details ## 48-Lead Plastic Thin Quad Flatpack (PT) - 7x7x1.0 mm Body [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-300-PT Rev D Sheet 1 of 2 ## 48-Lead Plastic Thin Quad Flatpack (PT) - 7x7x1.0 mm Body [TQFP] For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | MILLIMETERS | | | | |--------------------------|----------------|----------|----------|------| | Dim | nension Limits | MIN | NOM | MAX | | Number of Terminals | N | | 48 | | | Pitch | е | | 0.50 BSC | | | Overall Height | Α | - | - | 1.20 | | Standoff | A1 | 0.05 | 9 | 0.15 | | Molded Package Thickness | A2 | 0.95 | 1.00 | 1.05 | | Overall Length | D | | 9.00 BSC | | | Molded Package Length | D1 | | 7.00 BSC | | | Overall Width | E | 9.00 BSC | | | | Molded Package Width | E1 | 7.00 BSC | | | | Terminal Width | b | 0.17 | 0.22 | 0.27 | | Terminal Thickness | С | 0.09 | = | 0.16 | | Terminal Length | L. | 0.45 | 0.60 | 0.75 | | Footprint | L1 | | 1.00 REF | | | Lead Bend Radius | R1 | 0.08 | × | - | | Lead Bend Radius | R2 | 0.08 | - | 0.20 | | Foot Angle | θ | 0° | 3.5° | 7° | | Lead Angle | <del>0</del> 1 | 0° | <b>2</b> | × | | Mold Draft Angle | ⊖2 | 11° | 12° | 13° | #### Notes: - Pin 1 visual index feature may vary, but must be located within the hatched area. 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-300-PT Rev D Sheet 2 of 2 ## 48-Lead Plastic Thin Quad Flatpack (PT) - 7x7x1.0 mm Body [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 | |--------------------------|------------|----------|------|------| | Dimens | ion Limits | MIN | NOM | MAX | | Contact Pitch | E | 0.50 BSC | | | | Contact Pad Spacing | C1 | | 8.40 | | | Contact Pad Spacing | C2 | | 8.40 | | | Contact Pad Width (X48) | X1 | | | 0.30 | | Contact Pad Length (X48) | 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. - 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-2300-PT Rev D ## 48-Lead Very Thin Plastic Quad Flat, No Lead Package (6MX) - 6x6 mm Body [VQFN] With 4.1x4.1 mm Exposed Pad and Stepped Wettable Flanks **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-504 Rev A Sheet 1 of 2 ## 48-Lead Very Thin Plastic Quad Flat, No Lead Package (6MX) - 6x6 mm Body [VQFN] With 4.1x4.1 mm Exposed Pad and Stepped Wettable Flanks **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 Terminals | N | | 48 | | | | Pitch | е | | 0.40 BSC | | | | Overall Height | Α | 0.80 | 0.85 | 0.90 | | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | | Terminal Thickness | A3 | | 0.20 REF | | | | Overall Length | D | | 6.00 BSC | | | | Exposed Pad Length | D2 | 4.00 4.10 4.20 | | | | | Overall Width | Е | | 6.00 BSC | | | | Exposed Pad Width | E2 | 4.00 | 4.10 | 4.20 | | | Exposed Pad Corner Chamfer | CH | | 0.35 REF | | | | Terminal Width | b | 0.15 | 0.20 | 0.25 | | | Terminal Length | L | 0.30 0.40 0.50 | | | | | Terminal-to-Exposed-Pad | K | 0.55 REF | | | | | Wettable Flank Step Length | D3 | 0.085 | | | | | Wettable Flank Step Height | A4 | 0.10 | ( <b>-</b> 8 | 0.19 | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 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-504 Rev A Sheet 1 of 2 ## 48-Lead Very Thin Plastic Quad Flat, No Lead Package (6MX) - 6x6 mm Body [VQFN] With 4.1x4.1 mm Exposed Pad and Stepped Wettable Flanks **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging #### RECOMMENDED LAND PATTERN | | MILLIMETERS | | | | |----------------------------------|-------------|------|----------|------| | Dimension | Limits | MIN | NOM | MAX | | Contact Pitch | E | | 0.40 BSC | | | Optional Center Pad Width | X2 | | | 4.20 | | Optional Center Pad Length | Y2 | | | 4.20 | | Contact Pad Spacing | C1 | | 5.90 | | | Contact Pad Spacing | C2 | | 5.90 | | | Contact Pad Width (X48) | X1 | | | 0.20 | | Contact Pad Length (X48) | Y1 | | | 0.85 | | Contact Pad to Center Pad (X48) | G1 | 0.20 | | | | Contact Pad to Contact Pad (X44) | G2 | 0.20 | | | | Thermal Via Diameter | V | | 0.30 | | | Thermal Via Pitch | EV | | 1.00 | | #### Notes - 1. 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-2504 Rev A **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging **TOP VIEW** SIDE VIEW Microchip Technology Drawing C04-085C Sheet 1 of 2 **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging **TOP VIEW** SIDE VIEW Microchip Technology Drawing C04-085C Sheet 1 of 2 **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 | | 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 | E | | 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. - 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 **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | | MILLIMETERS | | | | |--------------------------|-------------|----------|-------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | E | 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 # 64-Lead Plastic Quad Flat, No Lead Package (MR) – 9x9x0.9 mm Body with 5.40 x 5.40 Exposed Pad [QFN] For the most current package drawings, please see the Microchip Packaging Specification located at Note: http://www.microchip.com/packaging D ○ 0.25 C NOTE 1 0.25 C **TOP VIEW** 0.10 C SEATING PLANE C (A3) -0.08 C ♦ 0.10M C A B D2 → 0.10M C A B (DATUM B) E2 NOTE 1 e/2 (DATUM A) 0.10M C A B Microchip Technology Drawing C04-154A Sheet 1 of 2 **BOTTOM VIEW** 0.05M C # 64-Lead Plastic Quad Flat, No Lead Package (MR) – 9x9x0.9 mm Body with 5.40 x 5.40 Exposed Pad [QFN] Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | | S | |------------------------|----------|----------|----------|------| | Dimension | n 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 | 5.30 | 5.40 | 5.50 | | Overall Length | D | | 9.00 BSC | | | Exposed Pad Length | D2 | 5.30 | 5.40 | 5.50 | | Contact Width | b | 0.20 | 0.25 | 0.30 | | Contact Length | L | 0.30 | 0.40 | 0.50 | | Contact-to-Exposed Pad | K | 0.20 | - | - | #### Notes: - Pin 1 visual index feature may vary, but must be located within the hatched area. 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-154A Sheet 2 of 2 64-Lead Plastic Quad Flat, No Lead Package (MR) – 9x9x0.9 mm Body [QFN] With 0.40 mm Contact Length and 5.40x5.40mm Exposed Pad **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | MILLIMETERS | | | | | |----------------------------|-------------|------|----------|------|--| | Dimension | n Limits | MIN | NOM | MAX | | | Contact Pitch | Е | | 0.50 BSC | | | | Optional Center Pad Width | W2 | | | 5.50 | | | Optional Center Pad Length | T2 | | | 5.50 | | | Contact Pad Spacing | C1 | | 8.90 | | | | Contact Pad Spacing | C2 | | 8.90 | | | | Contact Pad Width (X64) | X1 | | | 0.30 | | | Contact Pad Length (X64) | Y1 | | | 0.85 | | | 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 No. C04-2154A ### 80-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 | Units | | MILLIMETERS | | | |--------------------------|------------------|-------------|------|------| | | Dimension Limits | MIN | NOM | MAX | | Number of Leads | N | 80 | | | | 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 | E | 14.00 BSC | | | | Overall Length | D | 14.00 BSC | | | | Molded Package Width | E1 | 12.00 BSC | | | | Molded Package Length | D1 | 12.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.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-092B **lote:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | Units MILLIMETERS | | | |--------------------------|-------|-------------------|-------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | E | 0.50 BSC | | | | Contact Pad Spacing | C1 | | 13.40 | | | Contact Pad Spacing | C2 | | 13.40 | | | Contact Pad Width (X80) | X1 | | | 0.30 | | Contact Pad Length (X80) | 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 No. C04-2092B ## 36. Revision History Revision A (May 2021) This is the initial version of the document. #### Revision B (July 2021) This revision incorporates the following updates: - Sections - Updates "Qualification Support", Section 9.6 "Low-Power RC Oscillator", Section 29.6 "Power-Saving Control Registers", Section 29.6.1 "Peripheral Module Disable Control Register Low" and Section 30.5.1 "Voltage Regulator Control Register". - Tables: - Updates Table 3, Table 4, Table 33-7, Table 33-8, Table 33-9, Table 33-10, Table 33-18, Table 33-20, Table 33-26, Table 33-39, Table 33-44, Table 34-2, Table 34-6, Table 34-7, Table 34-10, Table 34-12, Table 34-13, Table 34-18. Table 34-19 and Table 34-20. - Removes Table 33-40, Table 34-7, Table 34-8, Table 34-9, Table 34-11 and Table 34-21. - Adds Table 34-9. - Removed Table 34-10. - · Figures: - Updates Figure 2. - · Equations: - Updates Equation 18-1. ## The Microchip Website Microchip provides online support via our website at <a href="www.microchip.com">www.microchip.com</a>/. This website is used to make files and information easily available to customers. Some of the content available includes: - 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 (FAQs), technical support requests, online discussion groups, Microchip design partner 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 ## **Product Change Notification Service** Microchip's product change notification service helps keep customers current on Microchip products. Subscribers will receive email notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest. To register, go to www.microchip.com/pcn and follow the registration instructions. ## **Customer Support** Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - · Embedded Solutions Engineer (ESE) - · Technical Support Customers should contact their distributor, representative or ESE for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in this document. Technical support is available through the website at: www.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. PIS TABLE | Device: | dsPIC33CK512MP608, dsPIC33CK512MP606, dsPIC33CK512MP605, dsPIC33CK256MP608, dsPIC33CK256MP606, dsPIC33CK256MP605, dsPIC33CK512MP308, dsPIC33CK512MP306, dsPIC33CK512MP305, dsPIC33CK256MP308, dsPIC33CK256MP306, dsPIC33CK256MP305 | | | |-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--| | Architecture: | 33 | = 16-Bit Digital Signal Controller | | | Flash Memory Family: | СК | = Single Core | | | Product Group: | MP | = Motor Control/Power Supply | | | Tape and Reel Option: | Т | = Tape and Reel | | | Temperature Range: | I | = -40°C to +85°C (Industrial) | | | | Е | = -40°C to +125°C (Extended) | | | | Н | = -40°C to +150°C (High) | | | Package | PT | = 48-Lead TQFP | | | | 6MX | = 48-Lead VQFN | | | | PT | = 64-Lead TQFP | | | | MR | = 64-Lead QFN | | | | PT | = 80-Lead TQFP | | #### Example: • dsPIC33CK512MP608-I/PT: dsPIC33, Enhanced Performance, 512-Kbyte Program Memory, 80-Pin, Industrial temperature, TQFP package. #### Notes: - Tape and Reel identifier only appears in the catalog part number description. This identifier is used for ordering purposes and is not printed on the device package. Check with your Microchip Sales Office for package availability with the Tape and Reel option. - 2. Small form-factor packaging options may be available. Please check www.microchip.com/packaging for small-form factor package availability, or contact your local Sales Office. ## **Microchip Devices Code Protection Feature** 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. © 2021 Microchip Technology Inc. Datasheet 70005452B-page 994 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. ## **Legal Notice** 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 INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL 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. ### **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, Anyln, AnyOut, Augmented Switching, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.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 countries. 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. ## dsPIC33CK512MP608 Family 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. © 2021, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved. ISBN: 978-1-5224-8687-9 AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamlQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. ## **Quality Management System** For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality. 70005452B-page 996 **Datasheet** ## **Worldwide Sales and Service** | AMERICAS | ASIA/PACIFIC | ASIA/PACIFIC | EUROPE | |---------------------------|-----------------------|-------------------------|-----------------------| | Corporate Office | Australia - Sydney | India - Bangalore | Austria - Wels | | 2355 West Chandler Blvd. | Tel: 61-2-9868-6733 | Tel: 91-80-3090-4444 | Tel: 43-7242-2244-39 | | Chandler, AZ 85224-6199 | China - Beijing | India - New Delhi | Fax: 43-7242-2244-393 | | Tel: 480-792-7200 | Tel: 86-10-8569-7000 | Tel: 91-11-4160-8631 | Denmark - Copenhagen | | Fax: 480-792-7277 | China - Chengdu | India - Pune | Tel: 45-4485-5910 | | Technical Support: | Tel: 86-28-8665-5511 | Tel: 91-20-4121-0141 | Fax: 45-4485-2829 | | www.microchip.com/support | China - Chongqing | Japan - Osaka | Finland - Espoo | | Web Address: | Tel: 86-23-8980-9588 | Tel: 81-6-6152-7160 | Tel: 358-9-4520-820 | | www.microchip.com | China - Dongguan | Japan - Tokyo | France - Paris | | Atlanta | Tel: 86-769-8702-9880 | Tel: 81-3-6880- 3770 | Tel: 33-1-69-53-63-20 | | Duluth, GA | China - Guangzhou | Korea - Daegu | Fax: 33-1-69-30-90-79 | | Tel: 678-957-9614 | Tel: 86-20-8755-8029 | Tel: 82-53-744-4301 | Germany - Garching | | Fax: 678-957-1455 | China - Hangzhou | Korea - Seoul | Tel: 49-8931-9700 | | Austin, TX | Tel: 86-571-8792-8115 | Tel: 82-2-554-7200 | Germany - Haan | | Tel: 512-257-3370 | China - Hong Kong SAR | Malaysia - Kuala Lumpur | Tel: 49-2129-3766400 | | Boston | Tel: 852-2943-5100 | Tel: 60-3-7651-7906 | Germany - Heilbronn | | Westborough, MA | China - Nanjing | Malaysia - Penang | Tel: 49-7131-72400 | | Tel: 774-760-0087 | Tel: 86-25-8473-2460 | Tel: 60-4-227-8870 | Germany - Karlsruhe | | Fax: 774-760-0088 | China - Qingdao | Philippines - Manila | Tel: 49-721-625370 | | Chicago | Tel: 86-532-8502-7355 | Tel: 63-2-634-9065 | Germany - Munich | | Itasca, IL | China - Shanghai | Singapore | Tel: 49-89-627-144-0 | | Tel: 630-285-0071 | Tel: 86-21-3326-8000 | Tel: 65-6334-8870 | Fax: 49-89-627-144-44 | | Fax: 630-285-0075 | China - Shenyang | Taiwan - Hsin Chu | Germany - Rosenheim | | Dallas | Tel: 86-24-2334-2829 | Tel: 886-3-577-8366 | Tel: 49-8031-354-560 | | Addison, TX | China - Shenzhen | Taiwan - Kaohsiung | Israel - Ra'anana | | Tel: 972-818-7423 | Tel: 86-755-8864-2200 | Tel: 886-7-213-7830 | Tel: 972-9-744-7705 | | Fax: 972-818-2924 | China - Suzhou | Taiwan - Taipei | Italy - Milan | | Detroit | Tel: 86-186-6233-1526 | Tel: 886-2-2508-8600 | Tel: 39-0331-742611 | | Novi, MI | China - Wuhan | Thailand - Bangkok | Fax: 39-0331-466781 | | Tel: 248-848-4000 | Tel: 86-27-5980-5300 | Tel: 66-2-694-1351 | Italy - Padova | | Houston, TX | China - Xian | Vietnam - Ho Chi Minh | Tel: 39-049-7625286 | | Tel: 281-894-5983 | Tel: 86-29-8833-7252 | Tel: 84-28-5448-2100 | Netherlands - Drunen | | Indianapolis | China - Xiamen | | Tel: 31-416-690399 | | Noblesville, IN | Tel: 86-592-2388138 | | Fax: 31-416-690340 | | Tel: 317-773-8323 | China - Zhuhai | | Norway - Trondheim | | Fax: 317-773-5453 | Tel: 86-756-3210040 | | Tel: 47-72884388 | | Tel: 317-536-2380 | | | Poland - Warsaw | | Los Angeles | | | Tel: 48-22-3325737 | | Mission Viejo, CA | | | Romania - Bucharest | | Tel: 949-462-9523 | | | Tel: 40-21-407-87-50 | | Fax: 949-462-9608 | | | Spain - Madrid | | Tel: 951-273-7800 | | | Tel: 34-91-708-08-90 | | Raleigh, NC | | | Fax: 34-91-708-08-91 | | Tel: 919-844-7510 | | | Sweden - Gothenberg | | New York, NY | | | Tel: 46-31-704-60-40 | | Tel: 631-435-6000 | | | Sweden - Stockholm | | San Jose, CA | | | Tel: 46-8-5090-4654 | | Tel: 408-735-9110 | | | UK - Wokingham | | Tel: 408-436-4270 | | | Tel: 44-118-921-5800 | | Canada - Toronto | | | Fax: 44-118-921-5820 | | Canada - Toronto | | | 1 42. 44 110 021 0020 | | Tel: 905-695-1980 | | | 1 un. 44 110 321 3023 |