# General Purpose, 16-Bit Flash Microcontrollers with XLP Technology Data Sheet ### **Analog Peripheral Features** - Up to Two 8-Bit Digital-to-Analog Converters (DACs): - Soft Reset disable function allows DAC to retain its output value through non-VDD Resets - Support for Idle mode - Support for left and right justified input data - · Two Operational Amplifiers (Op Amps): - Differential inputs - Selectable power/speed levels: - Low power/low speed - High power/high speed - Up to 22-Channel, 10/12-Bit Analog-to-Digital Converter: - 100k samples/second at 12-bit conversion rate (single Sample-and-Hold) - Auto-scan with Threshold Detect - Can operate during Sleep - Dedicated band gap reference and temperature sensor input - · Up to Three Rail-to-Rail Analog Comparators: - Programmable reference voltage for comparators - Band gap reference input - Flexible input multiplexing - Low-power or high-speed selection options - · Charge Time Measurement Unit (CTMU): - Capacitive measurement, up to 22 channels - Time measurement down to 200 ps resolution - Up to 16 external trigger pairs - Internal Temperature Sensor with Dedicated A/D Converter Input ### **High-Performance RISC CPU** - · Modified Harvard Architecture - · Operating Speed: - DC 32 MHz clock input - 16 MIPS at 32 MHz clock input - 8 MHz Internal Oscillator: - 4x PLL option - Multiple clock divide options - Fast start-up - 17-Bit x 17-Bit Single-Cycle Hardware Fractional/Integer Multiplier - · 32-Bit by 16-Bit Hardware Divider - · 16 x 16-Bit Working Register Array - · C Compiler Optimized Instruction Set Architecture - · 24-Bit Wide Instructions - · 16-Bit Wide Data Path - Linear Program Memory Addressing, Up to 6 Mbytes - · Linear Data Memory Addressing, Up to 64 Kbytes - Two Address Generation Units (AGUs) for Separate Read and Write Addressing of Data Memory ## Multiple/Single Capture Compare Peripheral (MCCP/SCCP) Features - · 16 or 32-Bit Time Base - · 16 or 32-Bit Capture: - 4-deep capture buffer - 16 or 32-Bit Compare: - Single Edge Compare modes - Dual Edge Compare/PWM modes - Center-Aligned Compare mode - Variable Frequency Pulse mode - · Single Output Steerable mode (MCCP only) - Brush DC Forward and Reverse modes (MCCP only) - Half-Bridge with Dead-Time Delay (MCCP only) - · Push-Pull PWM mode (MCCP only) - Auto-Shutdown with Programmable Source and Shutdown State - · Programmable Output Polarity | | | N | lemory | , | | Memory Peripherals | | | | | | | | | | | | |----------------|------|-----------------------|--------------|-----------------|-------------------|--------------------|------------------|------|------|---------------------|-----------|--------|-------------|------|------|-----|-----------| | Device | Pins | Flash Program (bytes) | SRAM (bytes) | EE Data (bytes) | Voltage Range (V) | 16-Bit Timer | 16-Bit MCCP/SCCP | MSSP | UART | 12-Bit A/D Channels | 8-Bit DAC | Op Amp | Comparators | СТМИ | RTCC | CLC | ICD BRKPT | | | | | | | | 5V | Devic | es | | | | | | | | | | | PIC24FV16KM204 | 44 | 16K | 2K | 512 | 2.0-5.5 | 1 | 3/2 | 2 | 2 | 22 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24FV16KM202 | 28 | 16K | 2K | 512 | 2.0-5.5 | 1 | 3/2 | 2 | 2 | 19 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24FV08KM204 | 44 | 8K | 2K | 512 | 2.0-5.5 | 1 | 3/2 | 2 | 2 | 22 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24FV08KM202 | 28 | 8K | 2K | 512 | 2.0-5.5 | 1 | 3/2 | 2 | 2 | 19 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24FV16KM104 | 44 | 16K | 1K | 512 | 2.0-5.5 | 1 | 1/1 | 1 | 1 | 22 | _ | _ | 1 | Yes | _ | 1 | 3 | | PIC24FV16KM102 | 28 | 16K | 1K | 512 | 2.0-5.5 | 1 | 1/1 | 1 | 1 | 19 | _ | _ | 1 | Yes | _ | 1 | 3 | | PIC24FV08KM102 | 28 | 8K | 1K | 512 | 2.0-5.5 | 1 | 1/1 | 1 | 1 | 19 | _ | _ | 1 | Yes | _ | 1 | 3 | | PIC24FV08KM101 | 20 | 8K | 1K | 512 | 2.0-5.5 | 1 | 1/1 | 1 | 1 | 16 | _ | _ | 1 | Yes | _ | 1 | 3 | | | | | | | | 3V | Devic | es | | | | | | | | | | | PIC24F16KM204 | 44 | 16K | 2K | 512 | 1.8-3.6 | 1 | 3/2 | 2 | 2 | 22 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24F16KM202 | 28 | 16K | 2K | 512 | 1.8-3.6 | 1 | 3/2 | 2 | 2 | 19 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24F08KM204 | 44 | 8K | 2K | 512 | 1.8-3.6 | 1 | 3/2 | 2 | 2 | 22 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24F08KM202 | 28 | 8K | 2K | 512 | 1.8-3.6 | 1 | 3/2 | 2 | 2 | 19 | 2 | 2 | 3 | Yes | Yes | 2 | 3 | | PIC24F16KM104 | 44 | 16K | 1K | 512 | 1.8-3.6 | 1 | 1/1 | 1 | 1 | 22 | _ | _ | 1 | Yes | _ | 1 | 3 | | PIC24F16KM102 | 28 | 16K | 1K | 512 | 1.8-3.6 | 1 | 1/1 | 1 | 1 | 19 | _ | _ | 1 | Yes | _ | 1 | 3 | | PIC24F08KM102 | 28 | 8K | 1K | 512 | 1.8-3.6 | 1 | 1/1 | 1 | 1 | 19 | _ | _ | 1 | Yes | _ | 1 | 3 | | PIC24F08KM101 | 20 | 8K | 1K | 512 | 1.8-3.6 | 1 | 1/1 | 1 | 1 | 16 | _ | _ | 1 | Yes | _ | 1 | 3 | ### **Peripheral Features** - · High-Current Sink/Source, 18 mA/18 mA All Ports - Independent Ultra-Low Power, 32 kHz Timer Oscillator - Up to Two Master Synchronous Serial Ports (MSSPs) with SPI and I<sup>2</sup>C modes: #### In SPI mode: - User-configurable SCKx and SDOx pin outputs - Daisy-chaining of SPI Slave devices #### In I<sup>2</sup>C mode: - Serial clock synchronization (clock stretching) - Bus collision detection and will arbitrate accordingly - Support for 16-bit read/write interface - Up to Two Enhanced Addressable UARTs: - LIN/J2602 bus support (auto-wake-up, Auto-Baud Detect, Break character support) - High and low speed (SCI) - IrDA<sup>®</sup> mode (hardware encoder/decoder function) - · Two External Interrupt Pins - Hardware Real-Time Clock and Calendar (RTCC) - Configurable Reference Clock Output (REFO) - · Two Configurable Logic Cells (CLCs) - Up to Two Single Output Capture/Compare/PWM (SCCP) modules and Up to Three Multiple Output Capture/Compare/PWM (MCCP) modules ### **Special Microcontroller Features** - · Wide Operating Voltage Range Options: - 1.8V to 3.6V (PIC24F devices) - 2.0V to 5.0V (PIC24FV devices) - · Selectable Power Management modes: - Idle: CPU shuts down, allowing for significant power reduction - Sleep: CPU and peripherals shut down for substantial power reduction and fast wake-up - Retention Sleep mode: PIC24FV devices can enter Sleep mode, employing the Retention Regulator, further reducing power consumption - Doze: CPU can run at a lower frequency than peripherals, a user-programmable feature - Alternate Clock modes allow on-the-fly switching to a lower clock speed for selective power reduction - Fail-Safe Clock Monitor: - Detects clock failure and switches to on-chip, low-power RC Oscillator - Ultra Low-Power Wake-up Pin Provides an External Trigger for Wake from Sleep - 10,000 Erase/Write Cycle Endurance Flash Program Memory, Typical - 100,000 Erase/Write Cycle Endurance Data EEPROM, Typical - Flash and Data EEPROM Data Retention: 20 Years Minimum - · Self-Programmable under Software Control - Power-on Reset (POR), Power-up Timer (PWRT) and Oscillator Start-up Timer (OST) - Watchdog Timer (WDT) with its Own On-Chip RC Oscillator for Reliable Operation - · On-Chip Regulator for 5V Operation - · Selectable Windowed WDT Feature - · Selectable Oscillator Options including: - 4x Phase-Locked Loop (PLL) - 8 MHz (FRC) Internal RC Oscillator: - HS/EC, High-Speed Crystal/Resonator Oscillator or External Clock - In-Circuit Serial Programming™ (ICSP™) and In-Circuit Emulation (ICE) – via Two Pins - · In-Circuit Debugging - Programmable High/Low-Voltage Detect (HLVD) module - Programmable Brown-out Reset (BOR): - Software enable feature - Configurable shutdown in Sleep - Auto-configures power mode and sensitivity based on device operating speed - LPBOR available for re-arming of the POR ### **Pin Diagrams** | Б. | Pin | Features | | | | | | | |-----|-------------------------------------------------|--------------------------------------------|--|--|--|--|--|--| | Pin | PIC24F08KM101 | PIC24FV08KM101 | | | | | | | | 1 | MCLR/VPP/RA5 | | | | | | | | | 2 | PGEC2/CVREF+/VREF+/AN0/CN2/RA0 | | | | | | | | | 3 | PGED2/CVREF-/VREF-/AN1/CN3/RA1 | | | | | | | | | 4 | PGED1/AN2/CTCMP/ULPWU/C1IND/OC2A/CN4/RB0 | | | | | | | | | 5 | PGEC1/AN3/C1INC/CTED12/CN5/RB1 | | | | | | | | | 6 | AN4/U1RX/TCKIB/CTED13/CN6/RB2 | | | | | | | | | 7 | OSCI/CLKI/AN13/C1INB/CN30/RA2 | | | | | | | | | 8 | OSCO/CLKO/AN14/C1INA/CN29/RA3 | | | | | | | | | 9 | PGED3/SOSCI/AN15/CLCINA/CN1/RB4 | | | | | | | | | 10 | PGEC3/SOSCO/SCLKI/AN16/PWRLCLK/CLCINB/CN0/RA4 | | | | | | | | | 11 | AN19/U1TX/CTED1/INT0/CN23/RB7 | AN19/U1TX/IC1/OC1A/CTED1/INT0/CN23/RB7 | | | | | | | | 12 | AN20/SCL1/U1CTS/OC1B/CTED10/CN22/RB8 | | | | | | | | | 13 | AN21/SDA1/T1CK/U1RTS/U1BCLK/IC2/CLC10/CTED4/CN2 | 1/RB9 | | | | | | | | 14 | IC1/OC1A/INT2/CN8/RA6 | VCAP OR VDDCORE | | | | | | | | 15 | AN12/HLVDIN/SCK1/OC1C/CTED2/CN14/RB12 | AN12/HLVDIN/SCK1/OC1C/CTED2/INT2/CN14/RB12 | | | | | | | | 16 | AN11/SDO1/OCFB/OC1D/CTPLS/CN13/RB13 | | | | | | | | | 17 | CVREF/AN10/SDI1/C1OUT/OCFA/CTED5/INT1/CN12/RB14 | | | | | | | | | 18 | AN9/REFO/SS1/TCKIA/CTED6/CN11/RB15 | | | | | | | | | 19 | Vss/AVss | | | | | | | | | 20 | VDD/AVDD | | | | | | | | ### **Pin Diagrams (Continued)** | | Pin Features | | | | | | | | | | |-----|----------------------------------------------------------------------------------------------------------|------------------------------------|--|--|--|--|--|--|--|--| | Pin | PIC24FXXKMX02 | PIC24FVXXKMX02 | | | | | | | | | | 1 | MCLR/Vpp/RA5 | | | | | | | | | | | 2 | CVREF+/VREF+/DAC1REF+/AN0/C3INC/CN2/RA0 | | | | | | | | | | | 3 | CVREF-/VREF-/AN1/CN3/RA1 CVREF-/VREF-/AN1/RA1 | | | | | | | | | | | 4 | PGED1/AN2/CTCMP/ULPWU/C1IND/C2INB/C3IND/U2TX/CN4/RB0 | | | | | | | | | | | 5 | PGEC1/OA1INA/OA2INA/AN3/C1INC/C2INA/U2RX/CTED12/CN5/RB1 | | | | | | | | | | | 6 | OA1INB/OA2INB/AN4/C1INB/C2IND/SDA2/U1RX/TCKIB/CTED1: | 3/CN6/RB2 | | | | | | | | | | 7 | OA1OUT/AN5/C1INA/C2INC/SCL2/CN7/RB3 | | | | | | | | | | | 8 | Vss | | | | | | | | | | | 9 | OSCI/CLKI/AN13/CN30/RA2 | | | | | | | | | | | 10 | OSCO/CLKO/AN14/CN29/RA3 | | | | | | | | | | | 11 | SOSCI/AN15/U2RTS/U2BCLK/CN1/RB4 | | | | | | | | | | | 12 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/CN0/RA4 | | | | | | | | | | | 13 | VDD | | | | | | | | | | | 14 | PGED3/AN17/ASDA1/SCK2/IC4/OC1E/CLCINA/CN27/RB5 | | | | | | | | | | | 15 | PGEC3/AN18/ASCL1/SDO2/IC5/OC1F/CLCINB/CN24/RB6 | | | | | | | | | | | 16 | AN19/U1TX/INT0/CN23/RB7 | AN19/U1TX/C2OUT/OC1A/INT0/CN23/RB7 | | | | | | | | | | 17 | AN20/SCL1/U1CTS/C3OUT/OC1B/CTED10/CN22/RB8 | • | | | | | | | | | | 18 | AN21/SDA1/T1CK/U1RTS/U1BCLK/IC2/OC4/CLC1O/CTED4/CN | 21/RB9 | | | | | | | | | | 19 | SDI2/IC1/OC5/CLC2O/CTED3/CN9/RA7 | | | | | | | | | | | 20 | C2OUT/OC1A/CTED1/INT2/CN8/RA6 | VCAP OR VDDCORE | | | | | | | | | | 21 | PGED2/SDI1/OC3A/OC1C/CTED11/CN16/RB10 | | | | | | | | | | | 22 | PGEC2/SCK1/OC2A/CTED9/CN15/RB11 | | | | | | | | | | | 23 | DAC10UT/AN12/HLVDIN/SS2/IC3/OC2B/CTED2/CN14/RB12 DAC10UT/AN12/HLVDIN/SS2/IC3/OC2B/CTED2/INT2/CN14/ RB12 | | | | | | | | | | | 24 | OA1INC/OA2INC/AN11/SDO1/OCFB/OC3B/OC1D/CTPLS/CN13/ | /RB13 | | | | | | | | | | 25 | DAC2OUT/CVREF/OA1IND/OA2IND/AN10/C3INB/RTCC/C1OUT/ | OCFA/CTED5/INT1/CN12/RB14 | | | | | | | | | | 26 | DAC2REF+/OA2OUT/AN9/C3INA/REFO/SS1/TCKIA/CTED6/CN | 11/RB15 | | | | | | | | | | 27 | Vss/AVss | | | | | | | | | | | 28 | VDD/AVDD | | | | | | | | | | Legend: Values in red indicate pin function differences between PIC24F(V)XXKM202 and PIC24F(V)XXKM102 devices. ### Pin Diagrams (Continued) | | Pin Features | Pin Features | | | | | | | | |-----|--------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|--|--| | Pin | PIC24FXXKMX02 | PIC24FVXXKMX02 | | | | | | | | | 1 | PGED1/AN2/CTCMP/ULPWU/C1IND/C2INB/C3IND/U2TX/CN4/RB0 | | | | | | | | | | 2 | PGEC1/OA1INA/OA2INA/AN3/C1INC/C2INA/U2RX/CTED12/CN5/RB1 | | | | | | | | | | 3 | OA1INB/OA2INB/AN4/C1INB/C2IND/SDA2/U1RX/TCKIB/CTED13/CN6/RB2 | | | | | | | | | | 4 | OA1OUT/AN5/C1INA/C2INC/SCL2/CN7/RB3 | | | | | | | | | | 5 | Vss | | | | | | | | | | 6 | OSCI/CLKI/AN13/CN30/RA2 | | | | | | | | | | 7 | OSCO/CLKO/AN14/CN29/RA3 | | | | | | | | | | 8 | SOSCI/AN15/U2RTS/U2BCLK/CN1/RB4 | | | | | | | | | | 9 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/CN0/RA4 | | | | | | | | | | 10 | VDD | | | | | | | | | | 11 | PGED3/AN17/ASDA1/SCK2/IC4/OC1E/CLCINA/CN27/RB5 | | | | | | | | | | 12 | PGEC3/AN18/ASCL1/SDO2/IC5/OC1F/CLCINB/CN24/RB6 | | | | | | | | | | 13 | AN19/U1TX/INT0/CN23/RB7 | AN19/U1TX/C2OUT/OC1A/INT0/CN23/RB7 | | | | | | | | | 14 | AN20/SCL1/U1CTS/C3OUT/OC1B/CTED10/CN22/RB8 | | | | | | | | | | 15 | AN21/SDA1/T1CK/U1RTS/U1BCLK/IC2/OC4/CLC10/CTED4/C | N21/RB9 | | | | | | | | | 16 | SDI2/IC1/OC5/CLC2O/CTED3/CN9/RA7 | | | | | | | | | | 17 | C2OUT/OC1A/CTED1/INT2/CN8/RA6 | VDDCORE/VCAP | | | | | | | | | 18 | PGED2/SDI1/OC3A/OC1C/CTED11/CN16/RB10 | | | | | | | | | | 19 | PGEC2/SCK1/OC2A/CTED9/CN15/RB11 | | | | | | | | | | 20 | DAC1OUT/AN12/HLVDIN/SS2/IC3/OC2B/CTED2/CN14/RB12 | DAC1OUT/AN12/HLVDIN/SS2/IC3/OC2B/CTED2/INT2/CN14/RB12 | | | | | | | | | 21 | OA1INC/OA2INC/AN11/SDO1/OCFB/OC3B/OC1D/CTPLS/CN1 | 3/RB13 | | | | | | | | | 22 | DAC2OUT/CVREF/OA1IND/OA2IND/AN10/C3INB/RTCC/C1OUT | T/OCFA/CTED5/INT1/CN12/RB14 | | | | | | | | | 23 | DAC2REF+/OA2OUT/AN9/C3INA/REFO/SS1/TCKIA/CTED6/CN | N11/RB15 | | | | | | | | | 24 | AVss | | | | | | | | | | 25 | AVDD | | | | | | | | | | 26 | MCLR/VPP/RA5 | | | | | | | | | | 27 | CVREF+/VREF+/DAC1REF+/AN0/C3INC/CN2/RA0 | CVREF+/VREF+/DAC1REF+/AN0/C3INC/CTED1/CN2/RA0 | | | | | | | | | 28 | CVREF-/VREF-/AN1/CN3/RA1 | | | | | | | | | Legend: Values in red indicate pin function differences between PIC24F(V)XXKM202 and PIC24F(V)XXKM102 devices. Note 1: Exposed pad on underside of device is connected to Vss. ### **Pin Diagrams (Continued)** | <b>.</b> | Pin Features | | | | | | | | |----------|-------------------------------------------------------------------------------------------|---------------------------------------------------|--|--|--|--|--|--| | Pin | PIC24FXXKMX04 | PIC24FVXXKMX04 | | | | | | | | 1 | AN21/SDA1/T1CK/U1RTS/U1BCLK/IC2/OC4/ | CLC10/CTED4/CN21/RB9 | | | | | | | | 2 | U1RX/OC2C/CN18/RC6 | | | | | | | | | 3 | U1TX/OC2D/CN17/RC7 | | | | | | | | | 4 | OC2E/CN20/RC8 | | | | | | | | | 5 | IC4/OC2F/CTED7/CN19/RC9 | | | | | | | | | 6 | IC1/OC5/CLC2O/CTED3/CN9/RA7 | | | | | | | | | 7 | C2OUT/OC1A/CTED1/INT2/CN8/RA6 | VCAP or VDDCORE | | | | | | | | 8 | PGED2/SDI1/OC1C/CTED11/CN16/RB10 | | | | | | | | | 9 | PGEC2/SCK1/OC2A/CTED9/CN15/RB11 | | | | | | | | | 10 | DAC1OUT/AN12/HLVDIN/OC2B/CTED2/<br>CN14/RB12 | DAC1OUT/AN12/HLVDIN/OC2B/CTED2/INT2/<br>CN14/RB12 | | | | | | | | 11 | OA1INC/OA2INC/AN11/SDO1/OC1D/CTPLS/ | CN13/RB13 | | | | | | | | 12 | IC5/OC3A/CN35/RA10 | | | | | | | | | 13 | IC3/OC3B/CTED8/CN36/RA11 | | | | | | | | | 14 | DAC2OUT/CVREF/OA1IND/OA2IND/AN10/C3<br>RB14 | INB/RTCC/C1OUT/OCFA/CTED5/INT1/CN12/ | | | | | | | | 15 | DAC2REF+/OA2OUT/AN9/C3INA/REFO/SS1 | /TCKIA/CTED6/CN11/RB15 | | | | | | | | 16 | AVss | | | | | | | | | 17 | AVDD | | | | | | | | | 18 | MCLR/Vpp/RA5 | | | | | | | | | 19 | CVREF+/VREF+/DAC1REF+/AN0/C3INC/CN2/<br>CVREF+/VREF+/DAC1REF+/AN0/C3INC/<br>CTED1/CN2/RA0 | | | | | | | | | 20 | CVREF-/VREF-/AN1/CN3/RA1 | | | | | | | | | 21 | PGED1/AN2/CTCMP/ULPWU/C1IND/C2INB/0 | C3IND/U2TX/CN4/RB0 | | | | | | | | 22 | PGEC1/OA1INA/OA2INA/AN3/C1INC/C2INA/ | U2RX/CTED12/CN5//RB1 | | | | | | | | 23 | OA1INB/OA2INB/AN4/C1INB/C2IND/SDA2/T0 | CKIB/CTED13/CN6/RB2 | | | | | | | | 24 | OA1OUT/AN5/C1INA/C2INC/SCL2/CN7/RB3 | | | | | | | | | 25 | AN6/CN32/RC0 | | | | | | | | | 26 | AN7/CN31/RC1 | | | | | | | | | 27 | AN8/CN10/RC2 | | | | | | | | | 28 | VDD | | | | | | | | | 29 | Vss | | | | | | | | | 30 | OSCI/CLKI/AN13/CN30/RA2 | | | | | | | | | 31 | OSCO/CLKO/AN14/CN29/RA3 | | | | | | | | | 32 | OCFB/CN33/RA8 | | | | | | | | | 33 | SOSCI/AN15/U2RTS/U2BCLK/CN1/RB4 | | | | | | | | | 34 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/CN0 | )/RA4 | | | | | | | | 35 | SS2/CN34/RA9 | | | | | | | | | 36 | SDI2/CN28/RC3 | | | | | | | | | 37 | SDO2/CN25/RC4 | | | | | | | | | 38 | SCK2/CN26/RC5 | | | | | | | | | 39 | Vss | | | | | | | | | 40 | VDD | | | | | | | | | 41 | PGED3/AN17/ASDA1/OC1E/CLCINA/CN27/R | RB5 | | | | | | | | 42 | PGEC3/AN18/ASCL1/OC1F/CLCINB/CN24/R | B6 | | | | | | | | 43 | AN19/INT0/CN23/RB7 | AN19/C2OUT/OC1A/INT0/CN23/RB7 | | | | | | | | 44 | AN20/SCL1/U1CTS/C3OUT/OC1B/CTED10/C | CN22/RB8 | | | | | | | **Legend:** Values in red indicate pin function differences between PIC24F(V)XXKM202 and PIC24F(V)XXKM102 devices. Note 1: Exposed pad on underside of device is connected to Vss. ### Pin Diagrams (Continued) | <b>.</b> | Pin Features | | | | | | | | |----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--|--|--|--|--|--| | Pin | PIC24FXXKMX04 | PIC24FVXXKMX04 | | | | | | | | 1 | AN21/SDA1/T1CK/U1RTS/U1BCLK/IC2/OC | 4/CLC10/CTED4/CN21/RB9 | | | | | | | | 2 | U1RX/OC2C/CN18/RC6 | | | | | | | | | 3 | U1TX/OC2D/CN17/RC7 | | | | | | | | | 4 | OC2/CN20/RC8 | | | | | | | | | 5 | IC4/OC2F/CTED7/CN19/RC9 | | | | | | | | | 6 | IC1/OC5/CLC2O/CTED3/CN9/RA7 | | | | | | | | | 7 | C2OUT/OC1A/CTED1/INT2/CN8/RA6 | VDDCORE or VCAP | | | | | | | | 8 | n/c | n/c | | | | | | | | 9 | PGED2/SDI1/OC1C/CTED11/CN16/RB10 | 1 | | | | | | | | 10 | PGEC2/SCK1/OC2A/CTED9/CN15/RB11 | | | | | | | | | 11 | DAC1OUT/AN12/HLVDIN/OC2B/CTED2/<br>CN14/RB12 | DAC1OUT/AN12/HLVDIN/OC2B/CTED2/<br>INT2/CN14/RB12 | | | | | | | | 12 | OA1INC/OA2INC/AN11/SDO1/OC1D/CTPL | S/CN13/RB13 | | | | | | | | 13 | IC5/OC3A/CN35/RA10 | | | | | | | | | 14 | IC3/OC3B/CTED8/CN36/RA11 | | | | | | | | | 15 | DAC2OUT/CVREF/OA1IND/OA2IND/AN10/C<br>CN12/RB14 | C3INB/RTCC/C1OUT/OCFA/CTED5/INT1/ | | | | | | | | 16 | DAC2REF+/OA2OUT/AN9/C3INA/REFO/S | S1/TCKIA/CTED6/CN11/RB15 | | | | | | | | 17 | Vss/AVss | | | | | | | | | 18 | VDD/AVDD | | | | | | | | | 19 | MCLR/Vpp/RA5 | | | | | | | | | 20 | n/c | | | | | | | | | 21 | CVREF+/VREF+/DAC1REF+/AN0/C3INC/<br>CN2/RA0 | CVREF+/VREF+/DAC1REF+/AN0/C3INC/<br>CTED1/CN2/RA0 | | | | | | | | 22 | CVREF-/VREF-/AN1/CN3/RA1 | | | | | | | | | 23 | PGED1/AN2/CTCMP/ULPWU/C1IND/C2INB/C3IND/U2TX/CN4/RB0 | | | | | | | | | 24 | PGEC1/OA1INA/OA2INA/AN3/C1INC/C2IN | A/U2RX/CTED12/CN5/RB1 | | | | | | | | 25 | OA1INB/OA2INB/AN4/C1INB/C2IND/SDA2 | TCKIB/CTED13/CN6/RB2 | | | | | | | | 26 | OA1OUT/AN5/C1INA/C2INC/SCL2/CN7/RE | 33 | | | | | | | | 27 | AN6/CN32/RC0 | | | | | | | | | 28 | AN7/CN31/RC1 | | | | | | | | | 29 | AN8/CN10/RC2 | | | | | | | | | 30 | VDD | | | | | | | | | 31 | Vss | | | | | | | | | 32 | n/c | | | | | | | | | 33 | OSCI/AN13/CLKI/CN30/RA2 | | | | | | | | | 34 | OSCO/CLKO/AN14/CN29/RA3 | | | | | | | | | 35 | OCFB/CN33/RA8 | | | | | | | | | J | | | | | | | | | | 36 | SOSCI/AN15/U2RTS/U2BCLK/CN1/RB4 | | | | | | | | | | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C | N0/RA4 | | | | | | | | 36<br>37 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C | N0/RA4 | | | | | | | | 36<br>37<br>38 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/CI<br>SS2/CN34/RA9 | N0/RA4 | | | | | | | | 36<br>37 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SDI2/CN28/RC3 | N0/RA4 | | | | | | | | 36<br>37<br>38<br>39<br>40 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SD12/CN28/RC3<br>SD02/CN25/RC4 | N0/RA4 | | | | | | | | 36<br>37<br>38<br>39<br>40<br>41 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SD12/CN28/RC3<br>SD02/CN25/RC4<br>SCK2/CN26/RC5 | N0/RA4 | | | | | | | | 36<br>37<br>38<br>39<br>40 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SD12/CN28/RC3<br>SD02/CN25/RC4<br>SCK2/CN26/RC5<br>Vss | N0/RA4 | | | | | | | | 36<br>37<br>38<br>39<br>40<br>41<br>42<br>43 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SDI2/CN28/RC3<br>SDO2/CN25/RC4<br>SCK2/CN26/RC5<br>Vss | N0/RA4 | | | | | | | | 36<br>37<br>38<br>39<br>40<br>41<br>42<br>43 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SDI2/CN28/RC3<br>SDO2/CN25/RC4<br>SCK2/CN26/RC5<br>Vss<br>VDD<br>n/c | | | | | | | | | 36<br>37<br>38<br>39<br>40<br>41<br>42<br>43<br>44<br>45 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SDI2/CN28/RC3<br>SDO2/CN25/RC4<br>SCK2/CN26/RC5<br>Vss<br>VDD<br>n/c<br>PGED3/AN17/ASDA1/OC1E/CLCINA/CN27 | <sup>1</sup> /RB5 | | | | | | | | 36<br>37<br>38<br>39<br>40<br>41<br>42<br>43 | SOSCO/SCLKI/AN16/PWRLCLK/U2CTS/C<br>SS2/CN34/RA9<br>SDI2/CN28/RC3<br>SDO2/CN25/RC4<br>SCK2/CN26/RC5<br>Vss<br>VDD<br>n/c | <sup>1</sup> /RB5 | | | | | | | Legend: Values in red indicate pin function differences between PIC24F(V)XXKM202 and PIC24F(V)XXKM102 devices. **Note 1:** Exposed pad on underside of device is connected to Vss. ### **Table of Contents** | 1.0 | Device Overview | | |-------|-------------------------------------------------------------|-----| | 2.0 | Guidelines for Getting Started with 16-Bit Microcontrollers | 27 | | 3.0 | CPU | | | 4.0 | Memory Organization | 39 | | 5.0 | Flash Program Memory | 65 | | 6.0 | Data EEPROM Memory | 71 | | 7.0 | Resets | 77 | | 8.0 | Interrupt Controller | 83 | | 9.0 | Oscillator Configuration | 119 | | 10.0 | Power-Saving Features | 129 | | 11.0 | I/O Ports | 135 | | 12.0 | | | | 13.0 | Capture/Compare/PWM/Timer Modules (MCCP and SCCP) | 141 | | 14.0 | | | | 15.0 | Universal Asynchronous Receiver Transmitter (UART) | 173 | | 16.0 | Real-Time Clock and Calendar (RTCC) | 181 | | 17.0 | | | | 18.0 | High/Low-Voltage Detect (HLVD) | 207 | | 19.0 | 12-Bit A/D Converter with Threshold Detect | | | 20.0 | 8-Bit Digital-to-Analog Converter (DAC) | 229 | | 21.0 | Dual Operational Amplifier Module | 233 | | 22.0 | Comparator Module | 235 | | 23.0 | Comparator Voltage Reference | 239 | | 24.0 | Charge Time Measurement Unit (CTMU) | 241 | | 25.0 | Special Features | 249 | | 26.0 | Development Support | 261 | | 27.0 | Electrical Characteristics | 263 | | | Packaging Information | | | Appe | endix A: Revision History | 323 | | Index | X | | | The I | Microchip Website | 331 | | | omer Change Notification Service | | | Custo | omer Support | 331 | | | luct Identification System | 333 | ### 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: http://www.microchip.com You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000000A is version A of document DS30000000). #### **Errata** An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies. To determine if an errata sheet exists for a particular device, please check with one of the following: - · Microchip's Worldwide Website; http://www.microchip.com - Your local Microchip sales office (see last page) When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using #### **Customer Notification System** Register on our website at www.microchip.com to receive the most current information on all of our products. ### 1.0 DEVICE OVERVIEW This document contains device-specific information for the following devices: - PIC24FV08KM101 - PIC24F08KM101 - PIC24FV08KM102 - PIC24F08KM102 - PIC24FV16KM102 - PIC24F16KM102 - PIC24FV16KM104 - PIC24F16KM104 - PIC24FV08KM202 - PIC24F08KM202 - PIC24FV08KM204 - PIC24F08KM204 - PIC24FV16KM202 - PIC24F16KM202 - PIC24FV16KM204 - PIC24F16KM204 The PIC24FV16KM204 family introduces many new analog features to the extreme low-power Microchip devices. This is a 16-bit microcontroller family with a broad peripheral feature set and enhanced computational performance. This family also offers a new migration option for those high-performance applications which may be outgrowing their 8-bit platforms, but do not require the numerical processing power of a Digital Signal Processor (DSC). #### 1.1 Core Features #### 1.1.1 16-BIT ARCHITECTURE Central to all PIC24F devices is the 16-bit modified Harvard architecture, first introduced with Microchip's dsPIC<sup>®</sup> Digital Signal Controllers (DSCs). The PIC24F CPU core offers a wide range of enhancements, such as: - 16-bit data and 24-bit address paths with the ability to move information between data and memory spaces - Linear Addressing of up to 16 Mbytes (program space) and 16 Kbytes (data) - A 16-element Working register array with built-in software stack support - A 17 x 17 hardware multiplier with support for integer math - · Hardware support for 32-bit by 16-bit division - An instruction set that supports multiple addressing modes and is optimized for high-level languages, such as C - · Operational performance up to 16 MIPS #### 1.1.2 POWER-SAVING TECHNOLOGY All of the devices in the PIC24FV16KM204 family incorporate a range of features that can significantly reduce power consumption during operation. Key features include: - On-the-Fly Clock Switching, to allow the device clock to be changed under software control to the Timer1 source or the internal, low-power RC Oscillator during operation, allowing users to incorporate power-saving ideas into their software designs. - Doze Mode Operation, when timing-sensitive applications, such as serial communications, require the uninterrupted operation of peripherals, the CPU clock speed can be selectively reduced, allowing incremental power savings without missing a beat. - Instruction-Based Power-Saving Modes, to allow the microcontroller to suspend all operations or selectively shut down its core while leaving its peripherals active with a single instruction in software. ### 1.1.3 OSCILLATOR OPTIONS AND FEATURES The PIC24FV16KM204 family offers five different oscillator options, allowing users a range of choices in developing application hardware. These include: - Two Crystal modes using crystals or ceramic resonators. - Two External Clock (EC) modes offering the option of a divide-by-2 clock output. - Two Fast Internal Oscillators (FRCs), one with a nominal 8 MHz output and the other with a nominal 500 kHz output. These outputs can also be divided under software control to provide clock speed as low as 31 kHz or 2 kHz. - A Phase-Locked Loop (PLL) frequency multiplier, available to the external oscillator modes and the 8 MHz FRC Oscillator, which allows clock speeds of up to 32 MHz. - A separate internal RC Oscillator (LPRC) with a fixed 31 kHz output, which provides a low-power option for timing-insensitive applications. The internal oscillator block also provides a stable reference source for the Fail-Safe Clock Monitor (FSCM). This option constantly monitors the main clock source against a reference signal provided by the internal oscillator and enables the controller to switch to the internal oscillator, allowing for continued low-speed operation or a safe application shutdown. #### 1.1.4 EASY MIGRATION The PIC24FV16KM204 family devices have two variants. The KM20X variant provides the full feature set of the device, while the KM10X offers a reduced peripheral set, allowing for the balance of features and cost (refer to Table 1-1). Both variants allow for a smooth migration path as applications grow and evolve. The consistent pinout scheme used throughout the entire family also helps in migrating to the next larger device. This is true when moving between devices with the same pin count, different die variants, or even moving from 20-pin or 28-pin devices to 44-pin/48-pin devices. The PIC24F family is pin compatible with devices in the dsPIC33 family, and shares some compatibility with the pinout schema for PIC18 and dsPIC30. This extends the ability of applications to grow from the relatively simple to the powerful and complex, yet still selecting a Microchip device. ### 1.2 Other Special Features - Communications: The PIC24FV16KM204 family incorporates a range of serial communication peripherals to handle a range of application requirements. There is an MSSP module which implements both SPI and I<sup>2</sup>C protocols, and supports both Master and Slave modes of operation for each. Devices also include one of two UARTs with built-in IrDA<sup>®</sup> encoders/decoders. - Analog Features: Select members of the PIC24FV16KM204 family include two 8-bit Digital-to-Analog Converters (DACs) which offer support in Idle mode, and left and right justified input data, as well as up to two operational amplifiers with selectable power and speed modes. - Real-Time Clock/Calendar (RTCC): This module implements a full-featured clock and calendar with alarm functions in hardware, freeing up timer resources and program memory space for use of the core application. - 12-Bit A/D Converter: This module incorporates programmable acquisition time, allowing for a channel to be selected and a conversion to be initiated without waiting for a sampling period, and faster sampling speed. The 16-deep result buffer can be used either in Sleep, to reduce power, or in Active mode to improve throughput. - Charge Time Measurement Unit (CTMU) Interface: The PIC24FV16KM204 family includes the new CTMU interface module, which can be used for capacitive touch sensing, proximity sensing, and also for precision time measurement and pulse generation. The CTMU can also be connected to the operational amplifiers to provide active guarding, which provides increased robustness in the presence of noise in capacitive touch applications. ## 1.3 Details on Individual Family Members Devices in the PIC24FV16KM204 family are available in 20-pin, 28-pin, 44-pin and 48-pin packages. The general block diagram for all devices is shown in Figure 1-1. Members of the PIC24FV16KM204 family are available as both standard and high-voltage devices. High-voltage devices, designated with an "FV" in the part number (such as PIC24FV16KM204), accommodate an operating VDD range of 2.0V to 5.5V and have an on-board voltage regulator that powers the core. Peripherals operate at VDD. Standard devices, designated by "F" (such as PIC24F16KM204), function over a lower VDD range of 1.8V to 3.6V. These parts do not have an internal regulator, and both the core and peripherals operate directly from VDD. The PIC24FV16KM204 family may be thought of as two different device groups, both offering slightly different sets of features. These differ from each other in multiple ways: - · The size of the Flash program memory - · The number of external analog channels available - · The number of Digital-to-Analog Converters - · The number of operational amplifiers - · The number of analog comparators - The presence of a Real-Time Clock and Calendar (RTCC) - The number and type of CCP modules (i.e., MCCP vs. SCCP) - The number of serial communication modules (both MSSPs and UARTs) - The number of Configurable Logic Cell (CLC) modules The general differences between the different sub-families are shown in Table 1-1 and Table 1-2. A list of the pin features available on the PIC24FV16KM204 family devices, sorted by function, is provided in Table 1-5. TABLE 1-1: DEVICE FEATURES FOR THE PIC24F16KM204 FAMILY | IABLE 1-1: DEVICE FEATURES FOI | 111E 1 102+1 10 | | | | | | | |--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------------|-----------------|--|--|--| | Features | PIC24F16KM204 | PIC24F08KM204 | PIC24F16KM202 | PIC24F08KM202 | | | | | Operating Frequency | DC-32 MHz | | | | | | | | Program Memory (bytes) | 16K | 8K | 16K 8K | | | | | | Program Memory (instructions) | 5632 | 2816 | 5632 | 2816 | | | | | Data Memory (bytes) | | 20 | )48 | | | | | | Data EEPROM Memory (bytes) | | 5 | 12 | | | | | | Interrupt Sources (soft vectors/NMI traps) | | 40 ( | 36/4) | | | | | | Voltage Range | | 1.8- | 3.6V | | | | | | I/O Ports | PORTA<br>PORTB<br>PORTC | [15:0] | PORTA[7:0]<br>PORTB[15:0] | | | | | | Total I/O Pins | 38 | | 24 | | | | | | Timers | 11 (One 16-bit timer, five MCCPs/SCCPs with up to two 16/32 timers each) | | | | | | | | Capture/Compare/PWM modules MCCP SCCP | 3<br>2 | | | | | | | | Serial Communications MSSP UART | 2<br>2 | | | | | | | | Input Change Notification Interrupt | 37 23 | | | | | | | | 12-Bit Analog-to-Digital Module (input channels) | 22 | 22 | 19 | 19 | | | | | Analog Comparators | 3 | | | | | | | | 8-Bit Digital-to-Analog Converters | 2 | | | | | | | | Operational Amplifiers | 2 | | | | | | | | Charge Time Measurement Unit (CTMU) | | Y | es es | | | | | | Real-Time Clock and Calendar (RTCC) | | Y | es es | | | | | | Configurable Logic Cell (CLC) | | | 2 | | | | | | Resets (and delays) | POR, BOR, RESET Instruction, MCLR, WDT, Illegal Opcode, REPEAT Instruction, Hardware Traps, Configuration Word Mismatch (PWRT, OST, PLL Lock) | | | | | | | | Instruction Set | 76 Base Inst | ructions, Multiple | e Addressing M | lode Variations | | | | | Packages | 44-Pin QFI<br>48-Pin U | 28-Pin<br>SOP/SOIC/QFN | | | | | | TABLE 1-2: DEVICE FEATURES FOR THE PIC24F16KM104 FAMILY | TABLE 1-2: DEVICE FEATURES F | OR THE PIC24F | TONIVITU4 FAIL | IIL Y | | | | | |--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------------|--------------------------------------|--|--|--| | Features | PIC24F16KM104 | PIC24F16KM102 | PIC24F08KM102 | PIC24F08KM101 | | | | | Operating Frequency | DC-32 MHz | | | | | | | | Program Memory (bytes) | 16K | 16K | 8K | 8K | | | | | Program Memory (instructions) | 5632 | 5632 | 2816 | 2816 | | | | | Data Memory (bytes) | | | 1024 | | | | | | Data EEPROM Memory (bytes) | | | 512 | | | | | | Interrupt Sources (soft vectors/NMI traps) | | 25 | 5 (21/4) | | | | | | Voltage Range | | 1. | 8-3.6V | | | | | | I/O Ports | PORTA[11:0]<br>PORTB[15:0]<br>PORTC[9:0] | PORTA<br>PORTE | | PORTA[6:0]<br>PORTB[15:12,9:7,4,2:0] | | | | | Total I/O Pins | 38 | 24 | ļ | 18 | | | | | Timers | 5 (One 16-bit timer, two MCCPs/SCCPs with up to two 16/32 timers each) | | | | | | | | Capture/Compare/PWM modules<br>MCCP<br>SCCP | 1<br>1 | | | | | | | | Serial Communications<br>MSSP<br>UART | 1<br>1 | | | | | | | | Input Change Notification Interrupt | 37 | 23 | 3 | 17 | | | | | 12-Bit Analog-to-Digital Module (input channels) | 22 | 19 | ) | 16 | | | | | Analog Comparators | 1 | | | | | | | | 8-Bit Digital-to-Analog Converters | _ | | | | | | | | Operational Amplifiers | _ | | | | | | | | Charge Time Measurement Unit (CTMU) | Yes | | | | | | | | Real-Time Clock and Calendar (RTCC) | _ | | | | | | | | Configurable Logic Cell (CLC) | 1 | | | | | | | | Resets (and delays) | POR, BOR, RESET Instruction, MCLR, WDT, Illegal Opcode, REPEAT Instruction, Hardware Traps, Configuration Word Mismatch (PWRT, OST, PLL Lock) | | | | | | | | Instruction Set | 76 Base Instructions, Multiple Addressing Mode Variations | | | | | | | | Packages | 44-Pin<br>QFN/TQFP,<br>48-Pin UQFN | 28-F<br>SPDIP/SSOF | | 20-Pin<br>SOIC/SSOP/PDIP | | | | TABLE 1-3: DEVICE FEATURES FOR THE PIC24FV16KM204 FAMILY | IABLE 1-3. DEVICE FEATURES FO | 14 1112 1 102 11 7 1 | | ·— · | | | | | |--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------|-----------------------------|--|--|--| | Features | PIC24FV16KM204 | PIC24FV08KM204 | PIC24FV16KM202 | PIC24FV08KM202 | | | | | Operating Frequency | DC-32 MHz | | | | | | | | Program Memory (bytes) | 16K | 8K | 16K | | | | | | Program Memory (instructions) | 5632 | 2816 | 5632 | 2816 | | | | | Data Memory (bytes) | | 20 | )48 | | | | | | Data EEPROM Memory (bytes) | | 5 | 12 | | | | | | Interrupt Sources (soft vectors/NMI traps) | | 40 ( | 36/4) | | | | | | Voltage Range | | 2.0- | -5.5V | | | | | | I/O Ports | PORTA[1<br>PORTB<br>PORTC | [15:0] | | PORTA[7,5:0]<br>PORTB[15:0] | | | | | Total I/O Pins | 37 | | 23 | | | | | | Timers | 11<br>(One 16-bit timer, five MCCPs/SCCPs with up to two 16/32 timers each) | | | | | | | | Capture/Compare/PWM modules MCCP SCCP | 3<br>2 | | | | | | | | Serial Communications<br>MSSP<br>UART | 2<br>2 | | | | | | | | Input Change Notification Interrupt | 36 | | | 22 | | | | | 12-Bit Analog-to-Digital Module (input channels) | 22 | | 19 | | | | | | Analog Comparators | 3 | | | | | | | | 8-Bit Digital-to-Analog Converters | 2 | | | | | | | | Operational Amplifiers | 2 | | | | | | | | Charge Time Measurement Unit (CTMU) | | Y | 'es | | | | | | Real-Time Clock and Calendar (RTCC) | | Y | 'es | | | | | | Configurable Logic Cell (CLC) | | | 2 | | | | | | Resets (and delays) | POR, BOR, RESET Instruction, MCLR, WDT, Illegal Opcode, REPEAT Instruction, Hardware Traps, Configuration Word Mismatch (PWRT, OST, PLL Lock) | | | | | | | | Instruction Set | 76 Base Inst | tructions, Multiple | e Addressing M | lode Variations | | | | | Packages | 44-Pin QFI<br>48-Pin U | | | 28-Pin<br>SOP/SOIC/QFN | | | | TABLE 1-4: DEVICE FEATURES FOR THE PIC24FV16KM104 FAMILY | TABLE 1-4: DEVICE FEATURES FO | R THE PIC24FV | 16KW1U4 FAI | VIIL Y | | | | | |--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------|--------------------------------------|--|--|--| | Features | PIC24FV16KM104 | PIC24FV16KM102 | PIC24FV08KM102 | PIC24FV08KM101 | | | | | Operating Frequency | DC-32 MHz | | | | | | | | Program Memory (bytes) | 16K | 16K | 8K | 8K | | | | | Program Memory (instructions) | 5632 | 5632 | 2816 | 2816 | | | | | Data Memory (bytes) | | • | 1024 | | | | | | Data EEPROM Memory (bytes) | | | 512 | | | | | | Interrupt Sources (soft vectors/NMI traps) | | 25 | (21/4) | | | | | | Voltage Range | | 2.0 | 0-5.5V | | | | | | I/O Ports | PORTA[11:7,5:0]<br>PORTB[15:0]<br>PORTC[9:0] | PORTA<br>PORTB | | PORTA[5:0]<br>PORTB[15:12,9:7,4,2:0] | | | | | Total I/O Pins | 37 23 | | | 17 | | | | | Timers | 5 (One 16-bit timer, two MCCPs/SCCPs with up to two 16/32 timers each) | | | | | | | | Capture/Compare/PWM modules<br>MCCP<br>SCCP | 1<br>1 | | | | | | | | Serial Communications MSSP UART | 1<br>1 | | | | | | | | Input Change Notification Interrupt | 36 | 22 | 2 | 16 | | | | | 12-Bit Analog-to-Digital Module (input channels) | 22 | ) | 16 | | | | | | Analog Comparators | 1 | | | | | | | | 8-Bit Digital-to-Analog Converters | _ | | | | | | | | Operational Amplifiers | | | | | | | | | Charge Time Measurement Unit (CTMU) | Yes | | | | | | | | Real-Time Clock and Calendar (RTCC) | _ | | | | | | | | Configurable Logic Cell (CLC) | | | 1 | | | | | | Resets (and delays) | POR, BOR, RESET Instruction, MCLR, WDT, Illegal Opcode, REPEAT Instruction, Hardware Traps, Configuration Word Mismatch (PWRT, OST, PLL Lock) | | | | | | | | Instruction Set | 76 Base Ins | tructions, Multip | ole Addressing | Mode Variations | | | | | Packages | 44-Pin<br>QFN/TQFP,<br>48-Pin UQFN | 28-F<br>SPDIP/SSOP | | 20-Pin<br>SOIC/SSOP/PDIP | | | | © 2013-2020 Microchip Technology Inc. **TABLE 1-5**: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION | | | | F | | | | | FV | | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|----------------------------------|----------------------------------|---------------|------------------------|----------------|-----|------------------|-----------------------------------| | | | | Pin Numb | er | | | ı | Pin Numb | er | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | I/O | Buffer | Description | | AN0 | 2 | 2 | 27 | 19 | 21 | 2 | 2 | 27 | 19 | 21 | I | ANA | A/D Analog Inputs | | AN1 | 3 | 3 | 28 | 20 | 22 | 3 | 3 | 28 | 20 | 22 | I | ANA | A/D Analog Inputs | | AN2 | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | I | ANA | A/D Analog Inputs | | AN3 | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | I | ANA | A/D Analog Inputs | | AN4 | 6 | 6 | 3 | 23 | 25 | 6 | 6 | 3 | 23 | 25 | ı | ANA | A/D Analog Inputs | | AN5 | _ | 7 | 4 | 24 | 26 | _ | 7 | 4 | 24 | 26 | ı | ANA | A/D Analog Inputs | | AN6 | _ | _ | _ | 25 | 27 | _ | _ | _ | 25 | 27 | ı | ANA | A/D Analog Inputs | | AN7 | _ | _ | _ | 26 | 28 | _ | _ | _ | 26 | 28 | ı | ANA | A/D Analog Inputs | | AN8 | _ | _ | _ | 27 | 29 | _ | _ | _ | 27 | 29 | ı | ANA | A/D Analog Inputs | | AN9 | 18 | 26 | 23 | 15 | 16 | 18 | 26 | 23 | 15 | 16 | ı | ANA | A/D Analog Inputs | | AN10 | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | ı | ANA | A/D Analog Inputs | | AN11 | 16 | 24 | 21 | 11 | 12 | 16 | 24 | 21 | 11 | 12 | ı | ANA | A/D Analog Inputs | | AN12 | 15 | 23 | 20 | 10 | 11 | 15 | 23 | 20 | 10 | 11 | ı | ANA | A/D Analog Inputs | | AN13 | 7 | 9 | 6 | 30 | 33 | 7 | 9 | 6 | 30 | 33 | ı | ANA | A/D Analog Inputs | | AN14 | 8 | 10 | 7 | 31 | 34 | 8 | 10 | 7 | 31 | 34 | ı | ANA | A/D Analog Inputs | | AN15 | 9 | 11 | 8 | 33 | 36 | 9 | 11 | 8 | 33 | 36 | ı | ANA | A/D Analog Inputs | | AN16 | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | ı | ANA | A/D Analog Inputs | | AN17 | _ | 14 | 11 | 41 | 45 | _ | 14 | 11 | 41 | 45 | ı | ANA | A/D Analog Inputs | | AN18 | _ | 15 | 12 | 42 | 46 | _ | 15 | 12 | 42 | 46 | ı | ANA | A/D Analog Inputs | | AN19 | 11 | 16 | 13 | 43 | 47 | 11 | 16 | 13 | 43 | 47 | I | ANA | A/D Analog Inputs | | AN20 | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | I | ANA | A/D Analog Inputs | | AN21 | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | I | ANA | A/D Analog Inputs | | ASCL1 | _ | 15 | 12 | 42 | 46 | _ | 15 | 12 | 42 | 46 | I/O | I <sup>2</sup> C | Alternate I2C1 Clock Input/Output | | ASDA1 | _ | 14 | 11 | 41 | 45 | _ | 14 | 11 | 41 | 45 | I/O | I <sup>2</sup> C | Alternate I2C1 Data Input/Output | | AVDD | 20 | 28 | 25 | 17 | 18 | 20 | 28 | 25 | 17 | 18 | Р | _ | A/D Supply Pins | | AVss | 19 | 27 | 24 | 16 | 17 | 19 | 27 | 24 | 16 | 17 | Р | _ | A/D Supply Pins | | C1INA | 8 | 7 | 4 | 24 | 26 | 8 | 7 | 4 | 24 | 26 | ı | ANA | Comparator 1 Input A (+) | | C1INB | 7 | 6 | 3 | 23 | 25 | 7 | 6 | 3 | 23 | 25 | ı | ANA | Comparator 1 Input B (-) | | C1INC | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | ı | ANA | Comparator 1 Input C (+) | | C1IND | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | I | ANA | Comparator 1 Input D (-) | ANA = Analog level input/output, ST = Schmitt Trigger input buffer, $I^2C = I^2C/SMBus$ input buffer DS30003030C-page 19 **TABLE 1-5**: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) | | F | | | | | FV | | | | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|----------------------------------|----------------------------------|---------------|------------------------|----------------|-----|--------|----------------------------| | | | ı | Pin Numb | er | | | ı | Pin Numb | er | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | I/O | Buffer | Description | | C1OUT | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | 0 | _ | Comparator 1 Output | | C2INA | _ | 5 | 2 | 22 | 24 | _ | 5 | 2 | 22 | 24 | ı | ANA | Comparator 2 Input A (+) | | C2INB | _ | 4 | 1 | 21 | 23 | _ | 4 | 1 | 21 | 23 | ı | ANA | Comparator 2 Input B (-) | | C2INC | _ | 7 | 4 | 24 | 26 | _ | 7 | 4 | 24 | 26 | ı | ANA | Comparator 2 Input C (+) | | C2IND | _ | 6 | 3 | 23 | 25 | _ | 6 | 3 | 23 | 25 | ı | ANA | Comparator 2 Input D (-) | | C2OUT | _ | 20 | 17 | 7 | 7 | _ | 16 | 13 | 43 | 47 | 0 | _ | Comparator 2 Output | | C3INA | _ | 26 | 23 | 15 | 16 | _ | 26 | 23 | 15 | 16 | ı | ANA | Comparator 3 Input A (+) | | C3INB | _ | 25 | 22 | 14 | 15 | _ | 25 | 22 | 14 | 15 | ı | ANA | Comparator 3 Input B (-) | | C3INC | _ | 2 | 27 | 19 | 21 | _ | 2 | 27 | 19 | 21 | ı | ANA | Comparator 3 Input C (+) | | C3IND | _ | 4 | 1 | 21 | 23 | _ | 4 | 1 | 21 | 23 | ı | ANA | Comparator 3 Input D (-) | | C3OUT | _ | 17 | 14 | 44 | 48 | _ | 17 | 14 | 44 | 48 | 0 | _ | Comparator 3 Output | | CLC1O | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | 0 | _ | CLC1 Output | | CLC2O | _ | 19 | 16 | 6 | 6 | _ | 19 | 16 | 6 | 6 | 0 | _ | CLC2 Output | | CLCINA | 9 | 14 | 11 | 41 | 45 | 9 | 14 | 11 | 41 | 45 | ı | ST | CLC External Input A | | CLCINB | 10 | 15 | 12 | 42 | 46 | 10 | 15 | 12 | 42 | 46 | ı | ST | CLC External Input B | | CLKI | 7 | 9 | 6 | 30 | 33 | 7 | 9 | 6 | 30 | 33 | ı | ANA | Primary Clock Input | | CLKO | 8 | 10 | 7 | 31 | 34 | 8 | 10 | 7 | 31 | 34 | 0 | _ | System Clock Output | | CN0 | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | ı | ST | Interrupt-on-Change Inputs | | CN1 | 9 | 11 | 8 | 33 | 36 | 9 | 11 | 8 | 33 | 36 | ı | ST | Interrupt-on-Change Inputs | | CN2 | 2 | 2 | 27 | 19 | 21 | 2 | 2 | 27 | 19 | 21 | ı | ST | Interrupt-on-Change Inputs | | CN3 | 3 | 3 | 28 | 20 | 22 | 3 | 3 | 28 | 20 | 22 | ı | ST | Interrupt-on-Change Inputs | | CN4 | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | ı | ST | Interrupt-on-Change Inputs | | CN5 | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | ı | ST | Interrupt-on-Change Inputs | | CN6 | 6 | 6 | 3 | 23 | 25 | 6 | 6 | 3 | 23 | 25 | ı | ST | Interrupt-on-Change Inputs | | CN7 | _ | 7 | 4 | 24 | 26 | _ | 7 | 4 | 24 | 26 | I | ST | Interrupt-on-Change Inputs | | CN8 | 14 | 20 | 17 | 7 | 7 | _ | _ | _ | 1 | _ | I | ST | Interrupt-on-Change Inputs | | CN9 | _ | 19 | 16 | 6 | 6 | _ | 19 | 16 | 6 | 6 | ı | ST | Interrupt-on-Change Inputs | | CN10 | _ | _ | _ | 27 | 29 | _ | _ | _ | 27 | 29 | ı | ST | Interrupt-on-Change Inputs | | CN11 | 18 | 26 | 23 | 15 | 16 | 18 | 26 | 23 | 15 | 16 | I | ST | Interrupt-on-Change Inputs | | CN12 | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | ı | ST | Interrupt-on-Change Inputs | ANA = Analog level input/output, ST = Schmitt Trigger input buffer, $I^2C = I^2C/SMBus$ input buffer © 2013-2020 Microchip Technology Inc. **TABLE 1-5**: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) | | | F FV | | | | | | | | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|----------------------------------|----------------------------------|---------------|------------------------|----------------|-----|--------|----------------------------| | | | i | Pin Numb | er | | | F | Pin Numb | er | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | I/O | Buffer | Description | | CN13 | 16 | 24 | 21 | 11 | 12 | 16 | 24 | 21 | 11 | 12 | I | ST | Interrupt-on-Change Inputs | | CN14 | 15 | 23 | 20 | 10 | 11 | 15 | 23 | 20 | 10 | 11 | I | ST | Interrupt-on-Change Inputs | | CN15 | _ | 22 | 19 | 9 | 10 | _ | 22 | 19 | 9 | 10 | I | ST | Interrupt-on-Change Inputs | | CN16 | _ | 21 | 18 | 8 | 9 | _ | 21 | 18 | 8 | 9 | I | ST | Interrupt-on-Change Inputs | | CN17 | _ | _ | _ | 3 | 3 | _ | _ | _ | 3 | 3 | I | ST | Interrupt-on-Change Inputs | | CN18 | _ | _ | _ | 2 | 2 | _ | _ | _ | 2 | 2 | ı | ST | Interrupt-on-Change Inputs | | CN19 | _ | _ | _ | 5 | 5 | | _ | _ | 5 | 5 | I | ST | Interrupt-on-Change Inputs | | CN20 | _ | _ | _ | 4 | 4 | _ | _ | _ | 4 | 4 | ı | ST | Interrupt-on-Change Inputs | | CN21 | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | ı | ST | Interrupt-on-Change Inputs | | CN22 | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | ı | ST | Interrupt-on-Change Inputs | | CN23 | 11 | 16 | 13 | 43 | 47 | 11 | 16 | 13 | 43 | 47 | I | ST | Interrupt-on-Change Inputs | | CN24 | _ | 15 | 12 | 42 | 46 | _ | 15 | 12 | 42 | 46 | ı | ST | Interrupt-on-Change Inputs | | CN25 | _ | _ | _ | 37 | 40 | | _ | _ | 37 | 40 | I | ST | Interrupt-on-Change Inputs | | CN26 | _ | _ | _ | 38 | 41 | _ | _ | _ | 38 | 41 | I | ST | Interrupt-on-Change Inputs | | CN27 | _ | 14 | 11 | 41 | 45 | _ | 14 | 11 | 41 | 45 | I | ST | Interrupt-on-Change Inputs | | CN28 | _ | _ | _ | 36 | 39 | _ | _ | _ | 36 | 39 | I | ST | Interrupt-on-Change Inputs | | CN29 | 8 | 10 | 7 | 31 | 34 | 8 | 10 | 7 | 31 | 34 | ı | ST | Interrupt-on-Change Inputs | | CN30 | 7 | 9 | 6 | 30 | 33 | 7 | 9 | 6 | 30 | 33 | ı | ST | Interrupt-on-Change Inputs | | CN31 | _ | _ | _ | 26 | 28 | _ | _ | _ | 26 | 28 | I | ST | Interrupt-on-Change Inputs | | CN32 | _ | _ | _ | 25 | 27 | _ | _ | _ | 25 | 27 | I | ST | Interrupt-on-Change Inputs | | CN33 | _ | _ | _ | 32 | 35 | _ | _ | _ | 32 | 35 | I | ST | Interrupt-on-Change Inputs | | CN34 | _ | _ | _ | 35 | 38 | _ | _ | _ | 35 | 38 | I | ST | Interrupt-on-Change Inputs | | CN35 | _ | _ | _ | 12 | 13 | _ | _ | _ | 12 | 13 | I | ST | Interrupt-on-Change Inputs | | CN36 | _ | _ | _ | 13 | 14 | _ | _ | _ | 13 | 14 | I | ST | Interrupt-on-Change Inputs | | CTCMP | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | I | ANA | CTMU Comparator Input | ANA = Analog level input/output, ST = Schmitt Trigger input buffer, I<sup>2</sup>C = I<sup>2</sup>C/SMBus input buffer PIC24FV16KM204 FAMILY TABLE 1-5: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) | | F | | | | | | - | FV | - | | | | | |----------|----------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----|--------|-------------|----------|----|----|-----|-----|---------------------------------------------| | | | ı | Pin Numb | er | | | ı | Pin Numb | er | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 1P/ 28-Pin QFN/ QFN TQFP 48-Pin UQFN SSOP/ SSOP/ SOIC SOIC QFN TQFP UQFN | 48-Pin<br>UQFN | I/O | Buffer | Description | | | | | | | | CTED1 | 11 | 20 | 17 | 7 | 7 | 11 | 2 | 27 | 19 | 21 | ı | ST | CTMU Trigger Edge Inputs | | CTED2 | 15 | 23 | 20 | 10 | 11 | 15 | 23 | 20 | 10 | 11 | - 1 | ST | CTMU Trigger Edge Inputs | | CTED3 | _ | 19 | 16 | 6 | 6 | _ | 19 | 16 | 6 | 6 | I | ST | CTMU Trigger Edge Inputs | | CTED4 | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | I | ST | CTMU Trigger Edge Inputs | | CTED5 | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | I | ST | CTMU Trigger Edge Inputs | | CTED6 | 18 | 26 | 23 | 15 | 16 | 18 | 26 | 23 | 15 | 16 | I | ST | CTMU Trigger Edge Inputs | | CTED7 | _ | _ | _ | 5 | 5 | _ | _ | _ | 5 | 5 | I | ST | CTMU Trigger Edge Inputs | | CTED8 | _ | _ | _ | 13 | 14 | _ | _ | _ | 13 | 14 | I | ST | CTMU Trigger Edge Inputs | | CTED9 | _ | 22 | 19 | 9 | 10 | _ | 22 | 19 | 9 | 10 | I | ST | CTMU Trigger Edge Inputs | | CTED10 | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | I | ST | CTMU Trigger Edge Inputs | | CTED11 | _ | 21 | 18 | 8 | 9 | _ | 21 | 18 | 8 | 9 | ı | ST | CTMU Trigger Edge Inputs | | CTED12 | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | ı | ST | CTMU Trigger Edge Inputs | | CTED13 | 6 | 6 | 3 | 23 | 25 | 6 | 6 | 3 | 23 | 25 | ı | ST | CTMU Trigger Edge Inputs | | CTPLS | 16 | 24 | 21 | 11 | 12 | 16 | 24 | 21 | 11 | 12 | 0 | _ | CTMU Pulse Output | | CVREF | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | 0 | ANA | Comparator Voltage Reference Output | | CVREF+ | 2 | 2 | 27 | 19 | 21 | 2 | 2 | 27 | 19 | 21 | ı | ANA | Comparator Voltage Reference Positive Input | | CVREF- | 3 | 3 | 28 | 20 | 22 | 3 | 3 | 28 | 20 | 22 | ı | ANA | Comparator Voltage Reference Negative Input | | DAC1OUT | _ | 23 | 20 | 10 | 11 | _ | 23 | 20 | 10 | 11 | 0 | ANA | DAC1 Output | | DAC1REF+ | _ | 2 | 27 | 19 | 21 | _ | 2 | 27 | 19 | 21 | ı | ANA | DAC1 Positive Voltage Reference Input | | DAC2OUT | _ | 25 | 22 | 14 | 15 | _ | 25 | 22 | 14 | 15 | 0 | ANA | DAC2 Output | | DAC2REF+ | _ | 26 | 23 | 15 | 16 | _ | 26 | 23 | 15 | 16 | 1 | ANA | DAC2 Positive Voltage Reference Input | | HLVDIN | 15 | 23 | 20 | 10 | 11 | 15 | 23 | 20 | 10 | 11 | I | ANA | External High/Low-Voltage Detect Input | | IC1 | 14 | 19 | 16 | 6 | 6 | 11 | 19 | 16 | 6 | 6 | I | ST | MCCP1 Input Capture Input | | IC2 | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | ı | ST | MCCP2 Input Capture Input | | IC3 | _ | 23 | 20 | 13 | 14 | _ | 23 | 20 | 13 | 14 | I | ST | MCCP3 Input Capture Input | | IC4 | _ | 14 | 11 | 5 | 5 | _ | 14 | 11 | 5 | 5 | I | ST | SCCP4 Input Capture Input | | IC5 | _ | 15 | 12 | 12 | 13 | _ | 15 | 12 | 12 | 13 | I | ST | SCCP5 Input Capture Input | | INT0 | 11 | 16 | 13 | 43 | 47 | 11 | 16 | 13 | 43 | 47 | I | ST | External Interrupt 0 Input | | INT1 | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | I | ST | External Interrupt 1 Input | | INT2 | 14 | 20 | 17 | 7 | 7 | 15 | 23 | 20 | 10 | 11 | - | ST | External Interrupt 2 Input | **Legend:** ANA = Analog level input/output, ST = Schmitt Trigger input buffer, $I^2C = I^2C/SMBus$ input buffer © 2013-2020 Microchip Technology Inc. PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) **TABLE 1-5**: | | F | | | | FV | | | | | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|-----------------------------------------------------------|----|----------|-------------|----|---|-----|------------------------------------------------| | | | ı | Pin Numb | er | | | F | Pin Numb | er | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | 48-Pin PDIP/ PDIP/ 28-Pin QFN/ TQFP 48-Pin UQFN SOIC SOIC | | Buffer | Description | | | | | | MCLR | 1 | 1 | 26 | 18 | 19 | 1 | 1 | 26 | 18 | 19 | I | ST | Master Clear (Device Reset) Input (active-low) | | OA1INA | _ | 5 | 2 | 22 | 24 | _ | 5 | 2 | 22 | 24 | I | ANA | Op Amp 1 Input A | | OA1INB | _ | 6 | 3 | 23 | 25 | _ | 6 | 3 | 23 | 25 | I | ANA | Op Amp 1 Input B | | OA1INC | _ | 24 | 21 | 11 | 12 | _ | 24 | 21 | 11 | 12 | I | ANA | Op Amp 1 Input C | | OA1IND | _ | 25 | 22 | 14 | 15 | _ | 25 | 22 | 14 | 15 | I | ANA | Op Amp 1 Input D | | OA1OUT | _ | 7 | 4 | 24 | 26 | _ | 7 | 4 | 24 | 26 | 0 | ANA | Op Amp 1 Analog Output | | OA2INA | _ | 5 | 2 | 22 | 24 | _ | 5 | 2 | 22 | 24 | I | ANA | Op Amp 2 Input A | | OA2INB | _ | 6 | 3 | 23 | 25 | _ | 6 | 3 | 23 | 25 | I | ANA | Op Amp 2 Input B | | OA2INC | _ | 24 | 21 | 11 | 12 | _ | 24 | 21 | 11 | 12 | I | ANA | Op Amp 2 Input C | | OA2IND | _ | 25 | 22 | 14 | 15 | _ | 25 | 22 | 14 | 15 | I | ANA | Op Amp 2 Input D | | OA2OUT | _ | 26 | 23 | 15 | 16 | _ | 26 | 23 | 15 | 16 | 0 | ANA | Op Amp 2 Analog Output | | OC1A | 14 | 20 | 17 | 7 | 7 | 11 | 16 | 13 | 43 | 47 | 0 | _ | MCCP1 Output Compare A | | OC1B | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | 0 | _ | MCCP1 Output Compare B | | OC1C | 15 | 21 | 18 | 8 | 9 | 15 | 21 | 18 | 8 | 9 | 0 | _ | MCCP1 Output Compare C | | OC1D | 16 | 24 | 21 | 11 | 12 | 16 | 24 | 21 | 11 | 12 | 0 | _ | MCCP1 Output Compare D | | OC1E | _ | 14 | 11 | 41 | 45 | _ | 14 | 11 | 41 | 45 | 0 | _ | MCCP1 Output Compare E | | OC1F | _ | 15 | 12 | 42 | 46 | _ | 15 | 12 | 42 | 46 | 0 | _ | MCCP1 Output Compare F | | OC2A | 4 | 22 | 19 | 9 | 10 | 4 | 22 | 19 | 9 | 10 | 0 | _ | MCCP2 Output Compare A | | OC2B | _ | 23 | 20 | 10 | 11 | _ | 23 | 20 | 10 | 11 | 0 | _ | MCCP2 Output Compare B | | OC2C | _ | _ | — | 2 | 2 | _ | _ | _ | 2 | 2 | 0 | _ | MCCP2 Output Compare C | | OC2D | _ | _ | — | 3 | 3 | _ | _ | _ | 3 | 3 | 0 | _ | MCCP2 Output Compare D | | OC2E | _ | _ | — | 4 | 4 | _ | _ | _ | 4 | 4 | 0 | _ | MCCP2 Output Compare E | | OC2F | _ | _ | _ | 5 | 5 | _ | | _ | 5 | 5 | 0 | _ | MCCP2 Output Compare F | | OC3A | _ | 21 | 18 | 12 | 13 | _ | 21 | 18 | 12 | 13 | 0 | _ | MCCP3 Output Compare A | | OC3B | _ | 24 | 21 | 13 | 14 | _ | 24 | 21 | 13 | 14 | 0 | _ | MCCP3 Output Compare B | | OC4 | _ | 18 | 15 | 1 | 1 | _ | 18 | 15 | 1 | 1 | 0 | _ | SCCP4 Output Compare | | OC5 | _ | 19 | 16 | 6 | 6 | _ | 19 | 16 | 6 | 6 | 0 | _ | SCCP5 Output Compare | | OCFA | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | I | ST | MCCP/SCCP Output Compare Fault Input A | | OCFB | 16 | 24 | 21 | 32 | 35 | 16 | 24 | 21 | 32 | 35 | I | ST | MCCP/SCCP Output Compare Fault Input B | ANA = Analog level input/output, ST = Schmitt Trigger input buffer, $I^2C = I^2C/SMBus$ input buffer TABLE 1-5: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) | | F<br>Din Number | | | | | | | FV | | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|----------------------------------|----------------------------------|---------------|------------------------|----------------|-----|--------|-----------------------------| | | | ı | Pin Numb | er | | | ı | Pin Numb | er | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | I/O | Buffer | Description | | OSCI | 7 | 9 | 6 | 30 | 33 | 7 | 9 | 6 | 30 | 33 | I | ANA | Primary Oscillator Input | | osco | 8 | 10 | 7 | 31 | 34 | 8 | 10 | 7 | 31 | 34 | 0 | ANA | Primary Oscillator Output | | PGEC1 | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | I/O | ST | ICSP™ Clock 1 | | PGED1 | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | I/O | ST | ICSP Data 1 | | PGEC2 | 2 | 22 | 19 | 9 | 10 | 2 | 22 | 19 | 9 | 10 | I/O | ST | ICSP Clock 2 | | PGED2 | 3 | 21 | 18 | 8 | 9 | 3 | 21 | 18 | 8 | 9 | I/O | ST | ICSP Data 2 | | PGEC3 | 10 | 15 | 12 | 42 | 46 | 10 | 15 | 12 | 42 | 46 | I/O | ST | ICSP Clock 3 | | PGED3 | 9 | 14 | 11 | 41 | 45 | 9 | 14 | 11 | 41 | 45 | I/O | ST | ICSP Data 3 | | PWRLCLK | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | I | ST | RTCC Power Line Clock Input | | RA0 | 2 | 2 | 27 | 19 | 21 | 2 | 2 | 27 | 19 | 21 | I/O | ST | PORTA Pins | | RA1 | 3 | 3 | 28 | 20 | 22 | 3 | 3 | 28 | 20 | 22 | I/O | ST | PORTA Pins | | RA2 | 7 | 9 | 6 | 30 | 33 | 7 | 9 | 6 | 30 | 33 | I/O | ST | PORTA Pins | | RA3 | 8 | 10 | 7 | 31 | 34 | 8 | 10 | 7 | 31 | 34 | I/O | ST | PORTA Pins | | RA4 | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | I/O | ST | PORTA Pins | | RA5 | 1 | 1 | 26 | 18 | 19 | 1 | 1 | 26 | 18 | 19 | I/O | ST | PORTA Pins | | RA6 | 14 | 20 | 17 | 7 | 7 | _ | _ | _ | _ | _ | I/O | ST | PORTA Pins | | RA7 | _ | 19 | 16 | 6 | 6 | _ | 19 | 16 | 6 | 6 | I/O | ST | PORTA Pins | | RA8 | _ | _ | _ | 32 | 35 | _ | - | _ | 32 | 35 | I/O | ST | PORTA Pins | | RA9 | _ | _ | _ | 35 | 38 | _ | - | _ | 35 | 38 | I/O | ST | PORTA Pins | | RA10 | _ | | _ | 12 | 13 | _ | - | _ | 12 | 13 | I/O | ST | PORTA Pins | | RA11 | _ | | _ | 13 | 14 | _ | - | _ | 13 | 14 | I/O | ST | PORTA Pins | | RB0 | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | I/O | ST | PORTB Pins | | RB1 | 5 | 5 | 2 | 22 | 24 | 5 | 5 | 2 | 22 | 24 | I/O | ST | PORTB Pins | | RB2 | 6 | 6 | 3 | 23 | 25 | 6 | 6 | 3 | 23 | 25 | I/O | ST | PORTB Pins | | RB3 | _ | 7 | 4 | 24 | 26 | _ | 7 | 4 | 24 | 26 | I/O | ST | PORTB Pins | | RB4 | 9 | 11 | 8 | 33 | 36 | 9 | 11 | 8 | 33 | 36 | I/O | ST | PORTB Pins | | RB5 | _ | 14 | 11 | 41 | 45 | _ | 14 | 11 | 41 | 45 | I/O | ST | PORTB Pins | | RB6 | _ | 15 | 12 | 42 | 46 | _ | 15 | 12 | 42 | 46 | I/O | ST | PORTB Pins | | RB7 | 11 | 16 | 13 | 43 | 47 | 11 | 16 | 13 | 43 | 47 | I/O | ST | PORTB Pins | | RB8 | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | I/O | ST | PORTB Pins | **Legend:** ANA = Analog level input/output, ST = Schmitt Trigger input buffer, $I^2C = I^2C/SMBus$ input buffer © 2013-2020 Microchip Technology Inc. **TABLE 1-5**: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) | | F<br>Pin Number | | | | | | | FV | | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|----------------------------------|----------------------------------|---------------|------------------------|----------------|-----|--------|---------------------------------| | | | i | Pin Numb | er | | | ı | Pin Numb | er | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | I/O | Buffer | Description | | RB9 | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | I/O | ST | PORTB Pins | | RB10 | _ | 21 | 18 | 8 | 9 | _ | 21 | 18 | 8 | 9 | I/O | ST | PORTB Pins | | RB11 | _ | 22 | 19 | 9 | 10 | _ | 22 | 19 | 9 | 10 | I/O | ST | PORTB Pins | | RB12 | 15 | 23 | 20 | 10 | 11 | 15 | 23 | 20 | 10 | 11 | I/O | ST | PORTB Pins | | RB13 | 16 | 24 | 21 | 11 | 12 | 16 | 24 | 21 | 11 | 12 | I/O | ST | PORTB Pins | | RB14 | 17 | 25 | 22 | 14 | 15 | 17 | 25 | 22 | 14 | 15 | I/O | ST | PORTB Pins | | RB15 | 18 | 26 | 23 | 15 | 16 | 18 | 26 | 23 | 15 | 16 | I/O | ST | PORTB Pins | | RC0 | _ | _ | _ | 25 | 27 | _ | _ | _ | 25 | 27 | I/O | ST | PORTC Pins | | RC1 | _ | _ | _ | 26 | 28 | _ | _ | _ | 26 | 28 | I/O | ST | PORTC Pins | | RC2 | _ | _ | _ | 27 | 29 | _ | _ | _ | 27 | 29 | I/O | ST | PORTC Pins | | RC3 | _ | _ | _ | 36 | 39 | _ | _ | _ | 36 | 39 | I/O | ST | PORTC Pins | | RC4 | _ | _ | _ | 37 | 40 | _ | - | _ | 37 | 40 | I/O | ST | PORTC Pins | | RC5 | _ | _ | _ | 38 | 41 | _ | - | _ | 38 | 41 | I/O | ST | PORTC Pins | | RC6 | _ | _ | _ | 2 | 2 | _ | - | _ | 2 | 2 | I/O | ST | PORTC Pins | | RC7 | _ | _ | _ | 3 | 3 | _ | - | _ | 3 | 3 | I/O | ST | PORTC Pins | | RC8 | _ | _ | _ | 4 | 4 | _ | - | _ | 4 | 4 | I/O | ST | PORTC Pins | | RC9 | _ | _ | _ | 5 | 5 | _ | - | _ | 5 | 5 | I/O | ST | PORTC Pins | | REFO | 18 | 26 | 23 | 15 | 16 | 18 | 26 | 23 | 15 | 16 | 0 | _ | Reference Clock Output | | RTCC | _ | 25 | 22 | 14 | 15 | _ | 25 | 22 | 14 | 15 | 0 | _ | Real-Time Clock/Calendar Output | | SCK1 | 15 | 22 | 19 | 9 | 10 | 15 | 22 | 19 | 9 | 10 | I/O | ST | MSSP1 SPI Clock | | SDI1 | 17 | 21 | 18 | 8 | 9 | 17 | 21 | 18 | 8 | 9 | I | ST | MSSP1 SPI Data Input | | SDO1 | 16 | 24 | 21 | 11 | 12 | 16 | 24 | 21 | 11 | 12 | 0 | _ | MSSP1 SPI Data Output | | SS1 | 18 | 26 | 23 | 15 | 16 | 18 | 26 | 23 | 15 | 16 | I | ST | MSSP1 SPI Slave Select Input | | SCK2 | _ | 14 | 11 | 38 | 41 | _ | 14 | 11 | 38 | 41 | I/O | ST | MSSP2 SPI Clock | | SDI2 | _ | 19 | 16 | 36 | 39 | _ | 19 | 16 | 36 | 39 | I | ST | MSSP2 SPI Data Input | | SDO2 | _ | 15 | 12 | 37 | 40 | _ | 15 | 12 | 37 | 40 | 0 | _ | MSSP2 SPI Data Output | | SS2 | _ | 23 | 20 | 35 | 38 | _ | 23 | 20 | 35 | 38 | I | ST | MSSP2 SPI Slave Select Input | ANA = Analog level input/output, ST = Schmitt Trigger input buffer, $I^2C = I^2C/SMBus$ input buffer DS30003030C-page 25 **TABLE 1-5**: PIC24FV16KM204 FAMILY PINOUT DESCRIPTION (CONTINUED) | | | | F | | | | • | FV | , | | | | | |----------|----------------------------------|----------------------------------|---------------|------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|-------------|----------|-----|-----|------------------------------------------------| | | | ı | Pin Numb | er | | Pin Number 1/O | | | | | | | | | Function | 20-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>PDIP/<br>SSOP/<br>SOIC | 28-Pin<br>QFN | 44-Pin<br>QFN/<br>TQFP | 48-Pin<br>UQFN | PDIP/ PDIP/ SSOP/ SSOP/ SOIC SOI | | Buffer | Description | | | | | | SCL1 | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | I/O | I2C | MSSP1 I <sup>2</sup> C Clock | | SDA1 | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | I/O | I2C | MSSP1 I <sup>2</sup> C Data | | SCL2 | _ | 7 | 4 | 24 | 26 | _ | 7 | 4 | 24 | 26 | I/O | I2C | MSSP2 I <sup>2</sup> C Clock | | SDA2 | _ | 6 | 3 | 23 | 25 | _ | 6 | 3 | 23 | 25 | I/O | I2C | MSSP2 I <sup>2</sup> C Data | | SCLKI | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | ı | ST | Secondary Clock Digital Input | | SOSCI | 9 | 11 | 8 | 33 | 36 | 9 | 11 | 8 | 33 | 36 | ı | ANA | Secondary Oscillator Input | | SOSCO | 10 | 12 | 9 | 34 | 37 | 10 | 12 | 9 | 34 | 37 | ı | ANA | Secondary Oscillator Output | | T1CK | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | ı | ST | Timer1 Digital Input Cock | | TCKIA | 18 | 26 | 23 | 15 | 16 | 18 | 26 | 23 | 15 | 16 | ı | ST | MCCP/SCCP Time Base Clock Input A | | TCKIB | 6 | 6 | 3 | 23 | 25 | 6 | 6 | 3 | 23 | 25 | ı | ST | MCCP/SCCP Time Base Clock Input B | | U1CTS | 12 | 17 | 14 | 44 | 48 | 12 | 17 | 14 | 44 | 48 | ı | ST | UART1 Clear-to-Send Input | | U1RTS | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | 0 | _ | UART1 Request-to-Send Output | | U1BCLK | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | 0 | _ | UART1 16x Baud Rate Clock Output | | U1RX | 6 | 6 | 3 | 2 | 2 | 6 | 6 | 3 | 2 | 2 | ı | ST | UART1 Receive | | U1TX | 11 | 16 | 13 | 3 | 3 | 11 | 16 | 13 | 3 | 3 | 0 | _ | UART1 Transmit | | U2CTS | _ | 12 | 9 | 34 | 37 | _ | 12 | 9 | 34 | 37 | ı | ST | UART2 Clear-to-Send Input | | U2RTS | _ | 11 | 8 | 33 | 36 | _ | 11 | 8 | 33 | 36 | 0 | _ | UART2 Request-to-Send Output | | U2BCLK | 13 | 18 | 15 | 1 | 1 | 13 | 18 | 15 | 1 | 1 | 0 | _ | UART2 16x Baud Rate Clock Output | | U2RX | _ | 5 | 2 | 22 | 24 | _ | 5 | 2 | 22 | 24 | ı | ST | UART2 Receive | | U2TX | _ | 4 | 1 | 21 | 23 | _ | 4 | 1 | 21 | 23 | 0 | _ | UART2 Transmit | | ULPWU | 4 | 4 | 1 | 21 | 23 | 4 | 4 | 1 | 21 | 23 | ı | ANA | Ultra Low-Power Wake-up Input | | VCAP | _ | _ | _ | _ | _ | 14 | 20 | 17 | 7 | 7 | Р | _ | Regulator External Filter Capacitor Connection | | VDD | 20 | 28 | 25 | 17,28,28 | 18,30,30 | 20 | 28 | 25 | 17,28,28 | 18,30,30 | Р | _ | Device Positive Supply Voltage | | VDDCORE | _ | | _ | _ | | 14 | 20 | 17 | 7 | 7 | Р | _ | Microcontroller Core Supply Voltage | | VPP | 1 | 1 | 26 | 18 | 19 | 1 | 1 | 26 | 18 | 19 | Р | _ | High-Voltage Programming Pin | | VREF+ | 2 | 2 | 27 | 19 | 21 | 2 | 2 | 27 | 19 | 21 | ı | ANA | A/D Reference Voltage Positive Input | | VREF- | 3 | 3 | 28 | 20 | 22 | 3 | 3 | 28 | 20 | 22 | ı | ANA | A/D Reference Voltage Negative Input | | Vss | 19 | 27 | 24 | 16,29,29 | 17,31,31 | 19 | 27 | 24 | 16,29,29 | 17,31,31 | Р | _ | Device Ground Return Voltage | ANA = Analog level input/output, ST = Schmitt Trigger input buffer, $I^2C = I^2C/SMBus$ input buffer NOTES: ### 2.0 GUIDELINES FOR GETTING STARTED WITH 16-BIT MICROCONTROLLERS #### 2.1 Basic Connection Requirements Getting started with the PIC24FV16KM204 family of 16-bit microcontrollers requires attention to a minimal set of device pin connections before proceeding with development. The following pins must always be connected: - All VDD and VSS pins (see Section 2.2 "Power Supply Pins") - All AVDD and AVSs pins, regardless of whether or not the analog device features are used (see Section 2.2 "Power Supply Pins") - MCLR pin (see Section 2.3 "Master Clear (MCLR) Pin") - VCAP pins (see Section 2.4 "Voltage Regulator Pin (VCAP)") These pins must also be connected if they are being used in the end application: - PGECx/PGEDx pins used for In-Circuit Serial Programming™ (ICSP™) and debugging purposes (see Section 2.5 "ICSP Pins") - OSCI and OSCO pins when an external oscillator source is used (see Section 2.6 "External Oscillator Pins") Additionally, the following pins may be required: VREF+/VREF- pins are used when external voltage reference for analog modules is implemented **Note:** The AVDD and AVSS pins must always be connected, regardless of whether any of the analog modules are being used. The minimum mandatory connections are shown in Figure 2-1. ## FIGURE 2-1: RECOMMENDED MINIMUM CONNECTIONS #### Key (all values are recommendations): C1 through C6: 0.1 μF, 20V ceramic C7: 10 μF, 16V tantalum or ceramic R1: $10 \text{ k}\Omega$ R2: $100\Omega$ to $470\Omega$ Note 1: See Section 2.4 "Voltage Regulator Pin (VCAP)" for an explanation of VCAP pin connections. 2: The example shown is for a PIC24F device with five VDD/Vss and AVDD/AVss pairs. Other devices may have more or less pairs; adjust the number of decoupling capacitors appropriately. ### 2.2 Power Supply Pins #### 2.2.1 DECOUPLING CAPACITORS The use of decoupling capacitors on every pair of power supply pins, such as VDD, VSS, AVDD and AVSs, is required. Consider the following criteria when using decoupling capacitors: - Value and type of capacitor: A 0.1 µF (100 nF), 10-20V capacitor is recommended. The capacitor should be a low-ESR device, with a resonance frequency in the range of 200 MHz and higher. Ceramic capacitors are recommended. - 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 no greater than 0.25 inch (6 mm). - Handling high-frequency noise: If the board is experiencing high-frequency noise (upward of tens of MHz), add a second ceramic type capacitor in parallel to the above described decoupling capacitor. The value of the second capacitor can be in the range of 0.01 μF to 0.001 μF. Place this second capacitor next to each 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 (e.g., 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 trace inductance. #### 2.2.2 TANK CAPACITORS On boards with power traces running longer than six inches in length, it is suggested to use a tank capacitor for integrated circuits, including microcontrollers, to supply a local power source. The value of the tank 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 tank capacitor so that it meets the acceptable voltage sag at the device. Typical values range from 4.7 $\mu F$ to 47 $\mu F$ ### 2.3 Master Clear (MCLR) Pin The MCLR pin provides two specific device functions: device Reset, and device programming and debugging. If programming and debugging are not required in the end application, a direct connection to VDD may be all that is required. The addition of other components, to help increase the application's resistance to spurious Resets from voltage sags, may be beneficial. A typical configuration is shown in Figure 2-1. Other circuit designs may be implemented, depending on the application's requirements. During programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the MCLR pin. Consequently, specific voltage levels (VIH and VIL) and fast signal transitions must not be adversely affected. Therefore, specific values of R1 and C1 will need to be adjusted based on the application and PCB requirements. For example, it is recommended that the capacitor, C1, be isolated from the MCLR pin during programming and debugging operations by using a jumper (Figure 2-2). The jumper is replaced for normal run-time operations. Any components associated with the $\overline{\text{MCLR}}$ pin should be placed within 0.25 inch (6 mm) of the pin. ## FIGURE 2-2: EXAMPLE OF MCLR PIN CONNECTIONS - Note 1: R1 ≤ 10 kΩ is recommended. A suggested starting value is 10 kΩ. Ensure that the MCLR pin VIH and VIL specifications are met - 2: R2 ≤ 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 VIH and VIL specifications are met. ### 2.4 Voltage Regulator Pin (VCAP) **Note:** This section applies only to PIC24FV16KM devices with an on-chip voltage regulator. Some of the PIC24FV16KM devices have an internal voltage regulator. These devices have the voltage regulator output brought out on the VCAP pin. On the PIC24F K devices with regulators, a low-ESR (< $5\Omega$ ) capacitor is required on the VCAP pin to stabilize the voltage regulator output. The VCAP pin must not be connected to VDD and must use a capacitor of 10 $\mu F$ connected to ground. The type can be ceramic or tantalum. Suitable examples of capacitors are shown in Table 2-1. Capacitors with equivalent specifications can be used. Designers may use Figure 2-3 to evaluate ESR equivalence of candidate devices. The placement of this capacitor should be close to VCAP. It is recommended that the trace length not exceed 0.25 inch (6 mm). Refer to Section 27.0 "Electrical Characteristics" for additional information. Refer to **Section 27.0 "Electrical Characteristics"** for information on VDD and VDDCORE. FIGURE 2-3: FREQUENCY vs. ESR PERFORMANCE FOR SUGGESTED VCAP TABLE 2-1: SUITABLE CAPACITOR EQUIVALENTS | Make | Part # | Nominal<br>Capacitance | Base Tolerance | Rated Voltage | Temp. Range | |-----------|--------------------|------------------------|----------------|---------------|---------------| | TDK | C3216X7R1C106K | 10 μF | ±10% | 16V | -55 to +125°C | | TDK | C3216X5R1C106K | 10 μF | ±10% | 16V | -55 to +85°C | | Panasonic | ECJ-3YX1C106K | 10 μF | ±10% | 16V | -55 to +125°C | | Panasonic | ECJ-4YB1C106K | 10 μF | ±10% | 16V | -55 to +85°C | | Murata | GRM32DR71C106KA01L | 10 μF | ±10% | 16V | -55 to +125°C | | Murata | GRM31CR61C106KC31L | 10 μF | ±10% | 16V | -55 to +85°C | ## 2.4.1 CONSIDERATIONS FOR CERAMIC CAPACITORS In recent years, large value, low-voltage, surface-mount ceramic capacitors have become very cost effective in sizes up to a few tens of microfarad. The low-ESR, small physical size and other properties make ceramic capacitors very attractive in many types of applications. Ceramic capacitors are suitable for use with the internal voltage regulator of this microcontroller. However, some care is needed in selecting the capacitor to ensure that it maintains sufficient capacitance over the intended operating range of the application. Typical low-cost, $10~\mu F$ ceramic capacitors are available in X5R, X7R and Y5V dielectric ratings (other types are also available, but are less common). The initial tolerance specifications for these types of capacitors are often specified as $\pm 10\%$ to $\pm 20\%$ (X5R and X7R), or -20%/+80% (Y5V). However, the effective capacitance that these capacitors provide in an application circuit will also vary based on additional factors, such as the applied DC bias voltage and the temperature. The total in-circuit tolerance is, therefore, much wider than the initial tolerance specification. The X5R and X7R capacitors typically exhibit satisfactory temperature stability (ex: ±15% over a wide temperature range, but consult the manufacturer's data sheets for exact specifications). However, Y5V capacitors typically have extreme temperature tolerance specifications of +22%/-82%. Due to the extreme temperature tolerance, a 10 µF nominal rated Y5V type capacitor may not deliver enough total capacitance to meet minimum internal voltage regulator stability and transient response requirements. Therefore, Y5V capacitors are not recommended for use with the internal regulator if the application must operate over a wide temperature range. In addition to temperature tolerance, the effective capacitance of large value ceramic capacitors can vary substantially, based on the amount of DC voltage applied to the capacitor. This effect can be very significant, but is often overlooked or is not always documented. A typical DC bias voltage vs. capacitance graph for X7R type capacitors is shown in Figure 2-4. FIGURE 2-4: DC BIAS VOLTAGE vs. CAPACITANCE CHARACTERISTICS When selecting a ceramic capacitor to be used with the internal voltage regulator, it is suggested to select a high-voltage rating, so that the operating voltage is a small percentage of the maximum rated capacitor voltage. For example, choose a ceramic capacitor rated at 16V for the 3.3V or 2.5V core voltage. Suggested capacitors are shown in Table 2-1. #### 2.5 ICSP Pins The PGECx and PGEDx pins are used for In-Circuit Serial Programming $^{\text{TM}}$ (ICSP $^{\text{TM}}$ ) 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\Omega$ . Pull-up resistors, series diodes, and capacitors on the PGECx and PGEDx pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits, and pins, Voltage Input High (VIH) and Voltage Input Low (VIL) requirements. For device emulation, ensure that the "Communication Channel Select" (i.e., PGECx/PGEDx pins), programmed into the device, matches the physical connections for the ICSP to the Microchip debugger/emulator tool. For more information on available Microchip development tools connection requirements, refer to **Section 26.0 "Development Support"**. #### 2.6 External Oscillator Pins Many microcontrollers have options for at least two oscillators: a high-frequency Primary Oscillator and a low-frequency Secondary Oscillator (refer to for Section 9.0 "Oscillator Configuration" details). The oscillator circuit should be placed on the same side of the board as the device. Place the oscillator circuit close to the respective oscillator pins with no more than 0.5 inch (12 mm) between the circuit components and the pins. 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 it from surrounding circuits. The grounded copper pour should be routed directly to the MCU ground. Do not run any signal traces or power traces inside the ground pour. Also, if using a two-sided board, avoid any traces on the other side of the board where the crystal is placed. Layout suggestions are shown in Figure 2-5. In-line packages may be handled with a single-sided layout that completely encompasses the oscillator pins. 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. In planning the application's routing and I/O assignments, ensure that adjacent port pins and other signals, in close proximity to the oscillator, are benign (i.e., free of high frequencies, short rise and fall times, and other similar noise). For additional information and design guidance on oscillator circuits, please refer to these Microchip Application Notes, available at the corporate website (www.microchip.com): - AN826, "Crystal Oscillator Basics and Crystal Selection for rfPIC™ and PICmicro® Devices" - AN849, "Basic PICmicro® Oscillator Design" - AN943, "Practical PICmicro<sup>®</sup> Oscillator Analysis and Design" - · AN949, "Making Your Oscillator Work" #### 2.7 Unused I/Os Unused I/O pins should be configured as outputs and driven to a Logic Low state. Alternatively, connect a 1 k $\Omega$ to 10 k $\Omega$ resistor to Vss on unused pins and drive the output to logic low. FIGURE 2-5: SUGGESTED PLACEMENT OF THE OSCILLATOR CIRCUIT NOTES: #### 3.0 CPU Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the CPU, refer to "CPU" (www.microchip.com/DS39703) in the "dsPIC33/PIC24F Family Reference Manual". The PIC24F CPU has a 16-bit (data) modified Harvard architecture with an enhanced instruction set and a 24-bit instruction word with a variable length opcode field. The Program Counter (PC) is 23 bits wide and addresses up to 4M instructions of user program memory space. A single-cycle instruction prefetch mechanism is used to help maintain throughput and provides predictable execution. All instructions execute in a single cycle, with the exception of instructions that change the program flow, the double-word move (MOV.D) instruction and the table instructions. Overhead-free program loop constructs are supported using the REPEAT instructions, which are interruptible at any point. PIC24F 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 16<sup>th</sup> Working register (W15) operates as a Software Stack Pointer (SSP) for interrupts and calls. The upper 32 Kbytes of the Data Space (DS) memory map can optionally be mapped into program space at any 16K word boundary of either program memory or data EEPROM memory, defined by the 8-bit Program Space Visibility Page Address (PSVPAG) register. The program to Data Space mapping feature lets any instruction access program space as if it were Data Space. The Instruction Set Architecture (ISA) has been significantly enhanced beyond that of the PIC18, but maintains an acceptable level of backward compatibility. All PIC18 instructions and addressing modes are supported, either directly, or through simple macros. Many of the ISA enhancements have been driven by compiler efficiency needs. The core supports Inherent (no operand), Relative, Literal, Memory Direct and three groups of addressing modes. All modes support Register Direct and various Register Indirect modes. Each group offers up to seven addressing modes. Instructions are associated with predefined addressing modes depending upon their functional requirements. For most instructions, the core is capable of executing a data (or program data) memory read, a Working register (data) read, a data memory write and a program (instruction) memory read per instruction cycle. As a result, three parameter instructions can be supported, allowing trinary operations (i.e., A + B = C) to be executed in a single cycle. A high-speed, 17-bit by 17-bit multiplier has been included to significantly enhance the core arithmetic capability and throughput. The multiplier supports Signed, Unsigned and Mixed mode, 16-bit by 16-bit or 8-bit by 8-bit integer multiplication. All multiply instructions execute in a single cycle. The 16-bit ALU has been enhanced with integer divide assist hardware that supports an iterative non-restoring divide algorithm. It operates in conjunction with the REPEAT instruction looping mechanism and a selection of iterative divide instructions to support 32-bit (or 16-bit), divided by 16-bit integer signed and unsigned division. All divide operations require 19 cycles to complete but are interruptible at any cycle boundary. The PIC24F has a vectored exception scheme with up to eight sources of non-maskable traps and up to 118 interrupt sources. Each interrupt source can be assigned to one of seven priority levels. A block diagram of the CPU is illustrated in Figure 3-1. ### 3.1 Programmer's Model Figure 3-2 displays the programmer's model for the PIC24F. All registers in the programmer's model are memory mapped and can be manipulated directly by instructions. Table 3-1 provides a description of each register. All registers associated with the programmer's model are memory mapped. FIGURE 3-1: PIC24F CPU CORE BLOCK DIAGRAM TABLE 3-1: CPU CORE REGISTERS | Register(s) Name | Description | |------------------|------------------------------------------------| | W0 through W15 | Working Register Array | | PC | 23-Bit Program Counter | | SR | ALU STATUS Register | | SPLIM | Stack Pointer Limit Value Register | | TBLPAG | Table Memory Page Address Register | | PSVPAG | Program Space Visibility Page Address Register | | RCOUNT | REPEAT Loop Counter Register | | CORCON | CPU Control Register | ### 3.2 CPU Control Registers #### REGISTER 3-1: SR: ALU STATUS REGISTER | U-0 HSC/R/W-0 | |--------|-----|-----|-----|-----|-----|-----|-----------| | _ | _ | _ | _ | _ | _ | _ | DC | | bit 15 | | | | | | | bit 8 | | HSC/R/W-0 <sup>(1)</sup> | HSC/R/W-0 <sup>(1)</sup> | HSC/R/W-0 <sup>(1)</sup> | HSC/R-0 | HSC/R/W-0 | HSC/R/W-0 | HSC/R/W-0 | HSC/R/W-0 | |--------------------------|--------------------------|--------------------------|---------|-----------|-----------|-----------|-----------| | IPL2 <sup>(2)</sup> | IPL1 <sup>(2)</sup> | IPL0 <sup>(2)</sup> | RA | N | OV | Z | С | | bit 7 | | | | | | | bit 0 | | Legend: | HSC = Hardware Settable/Clearable bit | | | | | | | | |-------------------|---------------------------------------|----------------------------|--------------------|--|--|--|--|--| | R = Readable bit | W = Writable bit | U = Unimplemented bit, rea | ad as '0' | | | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | | | | | bit 15-9 **Unimplemented:** Read as '0' bit 8 **DC:** ALU Half Carry/Borrow bit 1 = A carry-out from the 4<sup>th</sup> low-order bit (for byte-sized data) or 8<sup>th</sup> low-order bit (for word-sized data) of the result occurred 0 = No carry-out from the 4<sup>th</sup> or 8<sup>th</sup> low-order bit of the result has occurred bit 7-5 **IPL[2:0]:** CPU Interrupt Priority Level Status bits<sup>(1,2)</sup> 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 1 = REPEAT loop in progress 0 = REPEAT loop not in progress bit 3 **N:** ALU Negative bit 1 = Result was negative 0 = Result was non-negative (zero or positive) bit 2 **OV:** ALU Overflow bit 1 = Overflow occurred for signed (two's complement) arithmetic in this arithmetic operation 0 = No overflow has occurred bit 1 Z: ALU Zero bit 1 = An operation, which effects the Z bit, has set it at some time in the past 0 = The most recent operation, which effects the Z bit, has cleared it (i.e., a non-zero result) bit 0 C: ALU Carry/Borrow bit 1 = A carry-out from the Most Significant bit (MSb) of the result occurred 0 = No carry-out from the Most Significant bit (MSb) of the result occurred **Note 1:** The IPLx Status bits are read-only when NSTDIS (INTCON1[15]) = 1. 2: The IPL[2:0] Status bits are concatenated with the IPL3 bit (CORCON[3]) to form the CPU Interrupt Priority Level (IPL). The value in parentheses indicates the IPL when IPL3 = 1. #### REGISTER 3-2: CORCON: CPU CONTROL REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | | | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | HSC/R/C-0 | R/W-0 | U-0 | U-0 | |-------|-----|-----|-----|---------------------|-------|-----|-------| | _ | _ | _ | _ | IPL3 <sup>(1)</sup> | PSV | _ | _ | | bit 7 | | | | | | | bit 0 | | Legend: | C = Clearable bit | HSC = Hardware Settab | ole/Clearable bit | |-------------------|-------------------|------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, | read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15-4 **Unimplemented:** Read as '0' bit 3 IPL3: CPU Interrupt Priority Level Status bit<sup>(1)</sup> 1 = CPU Interrupt Priority Level is greater than 7 0 = CPU Interrupt Priority Level is 7 or less bit 2 **PSV:** Program Space Visibility in Data Space Enable bit 1 = Program space is visible in Data Space0 = Program space is not visible in Data Space bit 1-0 **Unimplemented:** Read as '0' **Note 1:** User interrupts are disabled when IPL3 = 1. #### 3.3 Arithmetic Logic Unit (ALU) The PIC24F 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 may 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. The PIC24F CPU incorporates hardware support for both multiplication and division. This includes a dedicated hardware multiplier and support hardware division for 16-bit divisor. #### 3.3.1 MULTIPLIER The ALU contains a high-speed, 17-bit x 17-bit multiplier. It supports unsigned, signed or mixed sign operation in several multiplication modes: - 16-bit x 16-bit signed - 16-bit x 16-bit unsigned - 16-bit signed x 5-bit (literal) unsigned - 16-bit unsigned 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.3.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: - 1. 32-bit signed/16-bit signed divide - 2. 32-bit unsigned/16-bit unsigned divide - 3. 16-bit signed/16-bit signed divide - 4. 16-bit unsigned/16-bit unsigned divide The quotient for all divide instructions ends up in W0 and the remainder in W1. Sixteen-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. #### 3.3.3 MULTIBIT SHIFT SUPPORT The PIC24F ALU supports both single bit and single-cycle, multibit arithmetic and logic shifts. Multibit shifts are implemented using a shifter block, capable of performing up to a 15-bit arithmetic right shift, or up to a 15-bit left shift, in a single cycle. All multibit shift instructions only support Register Direct Addressing for both the operand source and result destination. A full summary of instructions that use the shift operation is provided in Table 3-2. TABLE 3-2: INSTRUCTIONS THAT USE THE SINGLE AND MULTIBIT SHIFT OPERATION | Instruction | Description | |-------------|-------------------------------------------------------------| | ASR | Arithmetic shift right source register by one or more bits. | | SL | Shift left source register by one or more bits. | | LSR | Logical shift right source register by one or more bits. | #### 4.0 **MEMORY ORGANIZATION** As with Harvard architecture devices, the PIC24F microcontrollers feature separate program and data memory space and busing. 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 PIC24F devices is 4M instructions. The space is addressable by a 24-bit value derived from either the 23-bit Program Counter (PC) during program execution, or from a table operation or Data Space remapping, as described in Section 4.3 "Interfacing Program and Data Memory Spaces". The user access to the program memory space is restricted to the lower half of the address range (000000h to 7FFFFFh). The exception is the use of TBLRD/TBLWT operations, which use TBLPAG[7] to permit access to the Configuration bits and Device ID sections of the configuration memory space. Memory maps for the PIC24FV16KM204 family of devices are displayed in Figure 4-1. FIGURE 4-1: PROGRAM SPACE MEMORY MAP FOR PIC24FXXXXX FAMILY DEVICES # 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 (Figure 4-2). Program memory addresses are always word-aligned on the lower word, and addresses are incremented or decremented by two during code execution. This arrangement also provides compatibility with Data Memory Space Addressing and makes it possible to access data in the program memory space. #### 4.1.2 HARD MEMORY VECTORS All PIC24F devices reserve the addresses between 00000h and 000200h 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 at 000000h with the actual address for the start of code at 000002h. PIC24F devices also have two Interrupt Vector Tables, located from 000004h to 0000FFh, and 000104h to 0001FFh. These vector tables allow each of the many device interrupt sources to be handled by separate ISRs. Section 8.1 "Interrupt Vector Table (IVT)" discusses the Interrupt Vector Tables in more detail. #### 4.1.3 DATA EEPROM In the PIC24FV16KM204 family, the data EEPROM is mapped to the top of the user program memory space, starting at address, 7FFE00, and expanding up to address, 7FFFFF. The data EEPROM is organized as 16-bit wide memory and 256 words deep. This memory is accessed using Table Read and Write operations similar to the user code memory. #### 4.1.4 DEVICE CONFIGURATION WORDS Table 4-1 provides the addresses of the device Configuration Words for the PIC24FV16KM204 family. Their location in the memory map is displayed in Figure 4-1. Refer to **Section 25.1 "Configuration Bits"** for more information on device Configuration Words. TABLE 4-1: DEVICE CONFIGURATION WORDS FOR PIC24FXXXXX FAMILY DEVICES | Configuration Word | Configuration Word<br>Addresses | |--------------------|---------------------------------| | FBS | F80000 | | FGS | F80004 | | FOSCSEL | F80006 | | FOSC | F80008 | | FWDT | F8000A | | FPOR | F8000C | | FICD | F8000E | #### 4.2 Data Address Space The PIC24F core has a separate, 16-bit wide data memory space, addressable as a single linear range. The Data Space is accessed using two Address Generation Units (AGUs), one each for read and write operations. The Data Space memory map is displayed in Figure 4-3. All Effective Addresses (EAs) in the data memory space are 16 bits wide and point to bytes within the Data Space. This gives a Data Space address range of 64 Kbytes or 32K words. The lower half of the data memory space (that is, 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) area (see Section 4.3.3 "Reading Data from Program Memory Using Program Space Visibility"). Depending on the particular device, PIC24FV16KM family devices implement either 512 or 1024 words of data memory. Should an EA point to a location outside of this area, an all zero word or byte will be returned. #### 4.2.1 DATA SPACE WIDTH The data memory space is organized in byte-addressable, 16-bit wide blocks. Data are aligned in data memory and registers as 16-bit words, but all the Data Space EAs resolve to bytes. The Least Significant Bytes (LSBs) of each word have even addresses, while the Most Significant Bytes (MSBs) have odd addresses. FIGURE 4-3: DATA SPACE MEMORY MAP FOR PIC24FXXXXX FAMILY DEVICES<sup>(3)</sup> # 4.2.2 DATA MEMORY ORGANIZATION AND ALIGNMENT To maintain backward compatibility with PIC® devices and improve Data Space memory usage efficiency, the PIC24F instruction set supports both word and byte operations. As a consequence of byte accessibility, all EA calculations are internally scaled to step through word-aligned memory. For example, the core recognizes that Post-Modified Register Indirect Addressing mode [Ws++] will result in a value of Ws + 1 for byte operations and Ws + 2 for word operations. Data byte reads will read the complete word, which 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, the data memory and the 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, which 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 will be generated. If the error occurred on a read, the instruction underway is completed; if it occurred on a write, the instruction will be executed, but the write will not occur. In either case, a trap is then executed, allowing the system and/or user 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 the users to translate 8-bit signed data to 16-bit signed values. Alternatively, for 16-bit unsigned data, users can clear the MSB of any W register by executing a Zero-Extend (ZE) instruction on the appropriate address. Although most instructions are capable of operating on word or byte data sizes, it should be noted that some instructions operate only on words. #### 4.2.3 NEAR DATA SPACE The 8-Kbyte area between 0000h and 1FFFh is referred to as the Near Data Space. Locations in this space are directly addressable via a 13-bit absolute address field within all memory direct instructions. The remainder of the Data Space is addressable indirectly. Additionally, the whole Data Space is addressable using MOV instructions, which support Memory Direct Addressing (MDA) with a 16-bit address field. For PIC24FV16KM204 family devices, the entire implemented data memory lies in Near Data Space (NDS). #### 4.2.4 SFR SPACE The first 2 Kbytes of the Near Data Space, from 0000h to 07FFh, are primarily occupied with Special Function Registers (SFRs). These are used by the PIC24F core and peripheral modules for controlling the operation of the device. SFRs are distributed among the modules that they control and are generally grouped together by that module. Much of the SFR space contains unused addresses; these are read as '0'. The SFR space, where the SFRs are actually implemented, is provided in Table 4-2. Each implemented area indicates a 32-byte region where at least one address is implemented as an SFR. A complete listing of implemented SFRs, including their addresses, is provided in Table 4-3 through Table 4-26. TABLE 4-2: IMPLEMENTED REGIONS OF SFR DATA SPACE | | | | | SFR Space A | ddress | | | | |------|--------|-----------|-----------------|-------------|--------|------------|------|-------| | | xx00 | xx20 | xx40 | xx60 | xx80 | xxA0 | xxC0 | xxE0 | | 000h | | Core | | ICN | | Interrupts | | _ | | 100h | Timers | CLC | | | MCCP. | /SCCP | | | | 200h | MSSP | UART | Op Amp | DAC | _ | _ | 1/ | 0 | | 300h | | A/D/C | CMTU | | _ | _ | _ | _ | | 400h | _ | _ | _ | _ | _ | _ | _ | ANSEL | | 500h | _ | _ | _ | _ | _ | _ | _ | _ | | 600h | _ | RTCC/Comp | _ | Band Gap | | _ | _ | | | 700h | _ | _ | System/<br>HLVD | NVM/PMD | _ | _ | _ | _ | **Legend:** — = No implemented SFRs in this block. TABLE 4-3: CPU CORE REGISTERS MAP | File<br>Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |--------------|-------|--------|-------------|--------|--------|--------|--------|-------|-------|-------------|---------|-------|-------|----------------|-------|-------|-------|---------------| | WREG0 | 0h | | | | | | | | W | REG0 | | | | | | | | 0000 | | WREG1 | 2h | | | | | | | | W | REG1 | | | | | | | | 0000 | | WREG2 | 4h | | | | | | | | W | REG2 | | | | | | | | 0000 | | WREG3 | 6h | | | | | | | | W | REG3 | | | | | | | | 0000 | | WREG4 | 8h | | | | | | | | W | REG4 | | | | | | | | 0000 | | WREG5 | Ah | | | | | | | | W | REG5 | | | | | | | | 0000 | | WREG6 | Ch | | | | | | | | W | REG6 | | | | | | | | 0000 | | WREG7 | Eh | | WREG7 WREG8 | | | | | | | | | | | | | | | 0000 | | WREG8 | 10h | | WREG8 | | | | | | | | | | | | | | 0000 | | | WREG9 | 12h | WREG9 | | | | | | | | | | | | | | | 0000 | | | WREG10 | 14h | | WREG10 | | | | | | | | | | | | | | | 0000 | | WREG11 | 16h | | | | | | | | W | REG11 | | | | | | | | 0000 | | WREG12 | 18h | | | | | | | | W | REG12 | | | | | | | | 0000 | | WREG13 | 1Ah | | | | | | | | W | REG13 | | | | | | | | 0000 | | WREG14 | 1Ch | | | | | | | | W | REG14 | | | | | | | | 0000 | | WREG15 | 1Eh | | | | | | | | W | REG15 | | | | | | | | 0800 | | SPLIM | 20h | | | | | | | | SPLI | √ Register | | | | | | | | xxxx | | PCL | 2Eh | | | | | | | | PCL | Register | | | | | | | | 0000 | | PCH | 30h | | _ | _ | _ | _ | _ | _ | _ | | | | PCH | <b>I</b> [7:0] | | | | 0000 | | TBLPAG | 32h | | _ | _ | _ | _ | _ | _ | _ | | | | TBLPA | | | | | 0000 | | PSVPAG | 34h | | _ | _ | _ | _ | _ | _ | _ | | | | PSVPA | AG[7:0] | | | | 0000 | | RCOUNT | 36h | | | | | | | | RCOU | NT Register | | | | | | | | xxxx | | SR | 42h | _ | _ | _ | _ | _ | _ | _ | DC | IPL2 | IPL1 | IPL0 | RA | N | OV | Z | С | 0000 | | CORCON | 44h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | IPL3 | PSV | _ | _ | 0000 | | DISICNT | 52h | _ | _ | | | | | | | DISICN | T[13:0] | | | | | | | xxxx | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### TABLE 4-4: ICN REGISTER MAP | File<br>Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |--------------|-------|--------------------------|---------|---------|------------------------|--------------------------|------------------------|-------------------------|--------------------------|-------------------------|---------|---------|------------------------|------------------------|------------------------|------------------------|--------------------------|---------------| | CNPD1 | 56h | CN15PDE <sup>(1,2)</sup> | CN14PDE | CN13PDE | CN12PDE | CN11PDE | CN10PDE <sup>(2)</sup> | CN9PDE <sup>(1,2)</sup> | _ | CN7PDE <sup>(1,2)</sup> | CN6PDE | CN5PDE | CN4PDE | CN3PDE | CN2PDE | CN1PDE | CN0PDE | 0000 | | CNPD2 | 58h | CN31PDE <sup>(2)</sup> | CN30PDE | CN29PDE | CN28PDE <sup>(2)</sup> | CN27PDE <sup>(1,2)</sup> | CN26PDE <sup>(2)</sup> | CN25PDE <sup>(2)</sup> | CN24PDE <sup>(1,2)</sup> | CN23PDE | CN22PDE | CN21PDE | CN20PDE <sup>(2)</sup> | CN19PDE <sup>(2)</sup> | CN18PDE <sup>(2)</sup> | CN17PDE <sup>(2)</sup> | CN16PDE <sup>(1,2)</sup> | 0000 | | CNPD3 | 5Ah | _ | - | 1 | _ | _ | - | - | _ | _ | _ | 1 | CN36PDE <sup>(2)</sup> | CN35PDE <sup>(2)</sup> | CN34PDE <sup>(2)</sup> | CN33PDE <sup>(2)</sup> | CN32PDE <sup>(2)</sup> | 0000 | | CNEN1 | 62h | CN15IE <sup>(1,2)</sup> | CN14IE | CN13IE | CN12IE | CN11IE | CN10IE <sup>(2)</sup> | CN9IE <sup>(1,2)</sup> | _ | CN7IE <sup>(1,2)</sup> | CN6IE | CN5IE | CN4IE | CN3IE | CN2IE | CN1IE | CN0IE | 0000 | | CNEN2 | 64h | CN31IE <sup>(2)</sup> | CN30IE | CN29IE | CN28IE <sup>(2)</sup> | CN27IE <sup>(1,2)</sup> | CN26IE <sup>(2)</sup> | CN25IE <sup>(2)</sup> | CN24IE <sup>(1,2)</sup> | CN23IE | CN22IE | CN21IE | CN20IE <sup>(2)</sup> | CN19IE <sup>(2)</sup> | CN18IE <sup>(2)</sup> | CN17IE <sup>(2)</sup> | CN16IE <sup>(1,2)</sup> | 0000 | | CNEN3 | 66h | _ | - | 1 | _ | _ | - | - | _ | _ | _ | 1 | CN36IE <sup>(2)</sup> | CN35IE <sup>(2)</sup> | CN34IE <sup>(2)</sup> | CN33IE <sup>(2)</sup> | CN32IE <sup>(2)</sup> | 0000 | | CNPU1 | 6Eh | CN15PUE <sup>(1,2)</sup> | CN14PUE | CN13PUE | CN12PUE | CN11PUE | CN10PUE <sup>(2)</sup> | CN9PUE <sup>(1,2)</sup> | _ | CN7PUE <sup>(1,2)</sup> | CN6PUE | CN5PUE | CN4PUE | CN3PUE | CN2PUE | CN1PUE | CN0PUE | 0000 | | CNPU2 | 70h | CN31PUE <sup>(2)</sup> | CN30PUE | CN29PUE | CN28PUE <sup>(2)</sup> | CN27PUE <sup>(1,2)</sup> | CN26PUE <sup>(2)</sup> | CN25PUE <sup>(2)</sup> | CN24PUE <sup>(1,2)</sup> | CN23PUE | CN22PUE | CN21PUE | CN20PUE <sup>(2)</sup> | CN19PUE <sup>(2)</sup> | CN18PUE <sup>(2)</sup> | CN17PUE <sup>(2)</sup> | CN16PUE <sup>(1,2)</sup> | 0000 | | CNPU3 | 72h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CN36PUE <sup>(2)</sup> | CN35PUE <sup>(2)</sup> | CN34PUE <sup>(2)</sup> | CN33PUE <sup>(2)</sup> | CN32PUE <sup>(2)</sup> | 0000 | PIC24FV16KM204 FAMILY **Legend:** x = unknown, u = unchanged, --- = unimplemented, q = value depends on condition, r = reserved. Note 1: These bits are available only on 28-pin devices 2: These bits are available only on 44-pin devices TABLE 4-5: INTERRUPT CONTROLLER REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|---------|---------|---------|--------|---------|---------|---------|--------|---------|---------|---------|---------|----------|----------|----------|---------------| | INTCON1 | 80h | NSTDIS | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | MATHERR | ADDRERR | STKERR | OSCFAIL | _ | 0000 | | INTCON2 | 82h | ALTIVT | DISI | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | INT2EP | INT1EP | INT0EP | 0000 | | IFS0 | 84h | NVMIF | _ | AD1IF | U1TXIF | U1RXIF | _ | _ | CCT2IF | CCT1IF | CCP4IF | CCP3IF | _ | T1IF | CCP2IF | CCP1IF | INT0IF | 0000 | | IFS1 | 86h | U2TXIF | U2RXIF | INT2IF | CCT4IF | CCT3IF | _ | _ | _ | _ | CCP5IF | _ | INT1IF | CNIF | CMIF | BCL1IF | SSP1IF | 0000 | | IFS2 | 88h | _ | _ | _ | _ | _ | _ | CCT5IF | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | IFS3 | 8Ah | _ | RTCIF | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | BCL2IF | SSP2IF | _ | 0000 | | IFS4 | 8Ch | DAC2IF | DAC1IF | CTMUIF | _ | _ | _ | _ | HLVDIF | _ | _ | _ | _ | _ | U2ERIF | U1ERIF | _ | 0000 | | IFS5 | 8Eh | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ULPWUIF | 0000 | | IFS6 | 90h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLC2IF | CLC1IF | 0000 | | IEC0 | 94h | NVMIE | _ | AD1IE | U1TXIE | U1RXIE | _ | _ | CCT2IE | CCT1IE | CCP4IE | CCP3IE | _ | T1IE | CCP2IE | CCP1IE | INT0IE | 0000 | | IEC1 | 96h | U2TXIE | U2RXIE | INT2IE | CCT4IE | CCT3IE | _ | _ | _ | _ | CCP5IE | _ | INT1IE | CNIE | CMIE | BCL1IE | SSP1IE | 0000 | | IEC2 | 98h | _ | _ | _ | _ | _ | _ | CCT5IE | _ | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | IEC3 | 9Ah | _ | RTCIE | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | BCL2IE | SSP2IE | _ | 0000 | | IEC4 | 9Ch | DAC2IE | DAC1IE | CTMUIE | _ | _ | _ | _ | HLVDIE | _ | _ | _ | _ | _ | U2ERIE | U1ERIE | _ | 0000 | | IEC5 | 9Eh | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ULPWUIE | 0000 | | IEC6 | A0h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLC2IE | CLC1IE | 0000 | | IPC0 | A4h | _ | T1IP2 | T1IP1 | T1IP0 | _ | CCP2IP2 | CCP2IP1 | CCP2IP0 | _ | CCP1IP2 | CCP1IP1 | CCP1IP0 | _ | INT0IP2 | INT0IP1 | INT0IP0 | 4444 | | IPC1 | A6h | _ | CCT1IP2 | CCT1IP1 | CCT1IP0 | _ | CCP4IP2 | CCP4IP1 | CCP4IP0 | _ | CCP3IP2 | CCP3IP1 | CCP3IP0 | _ | _ | _ | _ | 4440 | | IPC2 | A8h | _ | U1RXIP2 | U1RXIP1 | U1RXIP0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | CCT2IP2 | CCT2IP1 | CCT2IP0 | 4004 | | IPC3 | AAh | _ | NVMIP2 | NVMIP1 | NVMIP0 | _ | _ | _ | _ | _ | AD1IP2 | AD1IP1 | AD1IP0 | _ | U1TXIP2 | U1TXIP1 | U1TXIP0 | 4044 | | IPC4 | ACh | _ | CNIP2 | CNIP1 | CNIP0 | _ | CMIP2 | CMIP1 | CMIP0 | _ | BCL1IP2 | BCL1IP1 | BCL1IP0 | _ | SSP1IP2 | SSP1IP1 | SSP1IP0 | 4444 | | IPC5 | AEh | _ | _ | _ | _ | _ | CCP5IP2 | CCP5IP1 | CCP5IP0 | _ | _ | _ | _ | _ | INT1IP2 | INT1IP1 | INT1IP0 | 0404 | | IPC6 | B0h | _ | CCT3IP2 | CCT3IP1 | CCT3IP0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 4000 | | IPC7 | B2h | _ | U2TXIP2 | U2TXIP1 | U2TXIP0 | _ | U2RXIP2 | U2RXIP1 | U2RXIP0 | _ | INT2IP2 | INT2IP1 | INT2IP0 | _ | CCT4IP2 | CCT4IP1 | CCT4IP0 | 4444 | | IPC10 | B8h | _ | _ | _ | _ | _ | _ | _ | _ | _ | CCT5IP2 | CCT5IP1 | CCT5IP0 | _ | _ | _ | _ | 0040 | | IPC12 | BCh | _ | _ | _ | _ | _ | BCL2IP2 | BCL2IP1 | BCL2IP0 | _ | SSP2IP2 | SSP2IP1 | SSP2IP0 | _ | _ | _ | _ | 0440 | | IPC15 | C2h | _ | _ | _ | _ | _ | RTCIP2 | RTCIP1 | RTCIP0 | _ | _ | _ | _ | _ | _ | _ | _ | 0400 | | IPC16 | C4h | _ | _ | _ | _ | _ | U2ERIP2 | U2ERIP1 | U2ERIP0 | _ | U1ERIP2 | U1ERIP1 | U1ERIP0 | _ | _ | _ | _ | 0440 | | IPC18 | C8h | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | HLVDIP2 | HLVDIP1 | HLVDIP0 | 0004 | | IPC19 | CAh | _ | DAC2IP2 | DAC2IP1 | DAC2IP0 | _ | DAC1IP2 | DAC1IP1 | DAC1IP0 | _ | CTMUIP2 | CTMUIP1 | CTMUIP0 | _ | _ | _ | _ | 4440 | | IPC20 | CCh | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | ULPWUIP2 | ULPWUIP1 | ULPWUIP0 | 0004 | | IPC24 | D4h | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLC2IP2 | CLC2IP1 | CLC2IP0 | _ | CLC1IP2 | CLC1IP1 | CLC1IP0 | 0044 | | INTTREG | E0h | CPUIRQ | _ | VHOLD | _ | ILR3 | ILR2 | ILR1 | ILR0 | _ | VECNUM6 | VECNUM5 | VECNUM4 | VECNUM3 | VECNUM2 | VECNUM1 | VECNUM0 | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### **TABLE 4-6: TIMER1 REGISTER MAP** | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|------------------------|--------|--------|--------|--------|-------|-------|-------|-------|--------|--------|-------|-------|-------|-------|---------------| | TMR1 | 100h | | Timer1 Register | | | | | | | | | | | | | | xxxx | | | PR1 | 102h | | Timer1 Period Register | | | | | | | | | | | | | | FFFF | | | T1CON | 104h | TON | _ | TSIDL | _ | ı | _ | TECS1 | TECS0 | _ | TGATE | TCKPS1 | TCKPS0 | _ | TSYNC | TCS | _ | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### **CLC1-2 REGISTER MAP TABLE 4-7**: | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-------------------------|-------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|---------------| | CLC1CONL | 122h | LCEN | _ | _ | _ | INTP | INTN | _ | _ | LCOE | LCOUT | LCPOL | _ | _ | MODE2 | MODE1 | MODE0 | 0000 | | CLC1CONH | 124h | 1 | | 1 | | 1 | 1 | _ | 1 | 1 | _ | _ | 1 | G4POL | G3POL | G2POL | G1POL | 0000 | | CLC1SEL | 126h | 1 | DS42 | DS41 | DS40 | 1 | DS32 | DS31 | DS30 | 1 | DS22 | DS21 | DS20 | 1 | DS12 | DS11 | DS10 | 0000 | | CLC1GLSL | 12Ah | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | 0000 | | CLC1GLSH | 12Ch | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | 0000 | | CLC2CONL <sup>(1)</sup> | 12Eh | LCEN | 1 | 1 | _ | INTP | INTN | _ | 1 | LCOE | LCOUT | LCPOL | 1 | 1 | MODE2 | MODE1 | MODE0 | 0000 | | CLC2CONH <sup>(1)</sup> | 130h | 1 | 1 | 1 | _ | 1 | ĺ | _ | 1 | 1 | _ | _ | 1 | G4POL | G3POL | G2POL | G1POL | 0000 | | CLC2SEL <sup>(1)</sup> | 132h | 1 | DS42 | DS41 | DS40 | 1 | DS32 | DS31 | DS30 | 1 | DS22 | DS21 | DS20 | 1 | DS12 | DS11 | DS10 | 0000 | | CLC2GLSL <sup>(1)</sup> | 136h | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | 0000 | | CLC2GLSH <sup>(1)</sup> | 138h | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | 0000 | PIC24FV16KM204 FAMILY **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. TABLE 4-8: MCCP1 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|---------|--------|---------|--------|---------|---------|---------|-------------|---------------|--------------|----------------|---------|---------|---------|---------|---------|---------------| | CCP1CON1L | 140h | CCPON | _ | CCPSIDL | r | TMRSYNC | CLKSEL2 | CLKSEL1 | CLKSEL0 | TMRPS1 | TMRPS0 | T32 | CCSEL | MOD3 | MOD2 | MOD1 | MOD0 | 0000 | | CCP1CON1H | 142h | OPSSRC | RTRGEN | _ | _ | OPS3 | OPS2 | OPS1 | OPS0 | TRIGEN | ONESHOT | ALTSYNC | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | 0000 | | CCP1CON2L | 144h | PWMRSEN | ASDGM | ı | SSDG | ı | 1 | _ | 1 | ASDG7 | ASDG6 | ASDG5 | ASDG4 | ASDG3 | ASDG2 | ASDG1 | ASDG0 | 0000 | | CCP1CON2H | 146h | OENSYNC | I | OCFEN | OCEEN | OCDEN | OCCEN | OCBEN | OCAEN | ICGSM1 | ICGSM0 | _ | AUXOUT1 | AUXOUT0 | ICS2 | ICS1 | ICS0 | 0100 | | CCP1CON3L | 148h | _ | | | | | | | | | | | | | | 0000 | | | | CCP1CON3H | 14Ah | OETRIG | OSCNT2 | OSCNT1 | OSCNT0 | - | OUTM2 | OUTM1 | OUTM0 | _ | _ | POLACE | POLBDF | PSSACE1 | PSSACE0 | PSSBDF1 | PSSBDF0 | 0000 | | CCP1STATL | 14Ch | _ | | | | | | | | | | | | | | 0000 | | | | CCP1TMRL | 150h | | | | | | | MCCI | P1 Time Ba | se Register | Low Word | | | | | | | 0000 | | CCP1TMRH | 152h | | | | | | | MCCF | 1 Time Ba | se Register | High Word | | | | | | | 0000 | | CCP1PRL | 154h | | | | | | | MCCP1 | Time Base F | Period Regis | ster Low Wor | <sup>-</sup> d | | | | | | FFFF | | CCP1PRH | 156h | | | | | | | MCCP1 T | īme Base F | Period Regis | ster High Wo | rd | | | | | | FFFF | | CCP1RAL | 158h | | | | | | | Oi | utput Comp | are 1 Data \ | Word A | | | | | | | 0000 | | CCP1RBL | 15Ch | | | | | | | Oi | utput Comp | are 1 Data \ | Word B | | | | | | | 0000 | | CCP1BUFL | 160h | | | • | | • | | Input | Capture 1 I | Data Buffer | Low Word | | | | | | | 0000 | | CCP1BUFH | 162h | | | • | | • | | Input | Capture 1 [ | Data Buffer I | High Word | | | | | | | 0000 | $\textbf{Legend:} \quad x = unknown, \ u = unchanged, \\ \textbf{—} = unimplemented, \ q = value \ depends \ on \ condition, \ r = reserved.$ #### **TABLE 4-9: MCCP2 REGISTER MAP** | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|---------|---------|---------|-------------|--------------|--------------|---------|-------|-------|-------|-------|-------|---------------| | CCP2CON1L | 164h | CCPON | _ | CCPSIDL | r | TMRSYNC | CLKSEL2 | CLKSEL1 | CLKSEL0 | TMRPS1 | TMRPS0 | T32 | CCSEL | MOD3 | MOD2 | MOD1 | MOD0 | 0000 | | CCP2CON1H | 166h | OPSSRC | RTRGEN | _ | - | IOPS3 | IOPS2 | IOPS1 | IOPS0 | TRIGEN | ONESHOT | ALTSYNC | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | 0000 | | CCP2CON2L | 168h | PWMRSEN | ASDGM | _ | SSDG | | _ | _ | _ | ASDG7 | ASDG6 | ASDG5 | ASDG4 | ASDG3 | ASDG2 | ASDG1 | ASDG0 | 0000 | | CCP2CON2H | 16Ah | OENSYNC | | | | | | | | | | | | | | | | 0100 | | CCP2CON3L | 16Ch | 1 | DT[5:0] | | | | | | | | | | | | | | | 0000 | | CCP2CON3H | 16Eh | OETRIG | | | | | | | | | | | | | | | | 0000 | | CCP2STATL | 170h | 1 | RIG OSCNT2 OSCNT1 OSCNT0 — OUTM2 <sup>(1)</sup> OUTM1 <sup>(1)</sup> OUTM0 <sup>(1)</sup> — POLACE POLBDF <sup>(1)</sup> PSSACE1 PSSACE0 PSSBDF1 <sup>(1)</sup> PSSBDF0 | | | | | | | | | | | | | | | 0000 | | CCP2TMRL | 174h | | | | | | | MCC | P2 Time Ba | se Registe | r Low Word | | | | | | | 0000 | | CCP2TMRH | 176h | | | | | | | MCC | P2 Time Ba | ise Register | High Word | | | | | | | 0000 | | CCP2PRL | 178h | | | | | | | MCCP2 | Time Base | Period Reg | ister Low Wo | rd | | | | | | FFFF | | CCP2PRH | 17Ah | | | | | | | MCCP2 | Time Base I | Period Regi | ster High Wo | rd | | | | | | FFFF | | CCP2RAL | 17Ch | | | | | | | 0 | utput Comp | oare 2 Data | Word A | | | | | | | 0000 | | CCP2RBL | 180h | | | | | | | 0 | utput Comp | oare 2 Data | Word B | | | | | | | 0000 | | CCP2BUFL | 184h | | | | | | | Input | t Capture 2 | Data Buffer | Low Word | | | | | | | 0000 | | CCP2BUFH | 186h | | | | | | | Input | Capture 2 | Data Buffer | High Word | | | | | | | 0000 | PIC24FV16KM204 FAMILY **Legend:** x = unknown, TABLE 4-10: MCCP3 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |--------------------------|-------|---------|---------|---------|--------|---------|---------|---------|-------------|---------------|--------------|---------|-------|-------|-------|-------|-------|---------------| | CCP3CON1L <sup>(1)</sup> | 188h | CCPON | _ | CCPSIDL | r | TMRSYNC | CLKSEL2 | CLKSEL1 | CLKSEL0 | TMRPS1 | TMRPS0 | T32 | CCSEL | MOD3 | MOD2 | MOD1 | MOD0 | 0000 | | CCP3CON1H <sup>(1)</sup> | 18Ah | OPSSRC | RTRGEN | 1 | _ | IOPS3 | IOPS2 | IOPS1 | IOPS0 | TRIGEN | ONESHOT | ALTSYNC | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | 0000 | | CCP3CON2L <sup>(1)</sup> | 18Ch | PWMRSEN | ASDGM | 1 | SSDG | - | 1 | 1 | _ | ASDG7 | ASDG6 | ASDG5 | ASDG4 | ASDG3 | ASDG2 | ASDG1 | ASDG0 | 0000 | | CCP3CON2H <sup>(1)</sup> | 18Eh | OENSYNC | DT[5:0] | | | | | | | | | | | | | | | 0100 | | CCP3CON3L <sup>(1)</sup> | 190h | - | DT[5:0] | | | | | | | | | | | | | | | 0000 | | CCP3CON3H <sup>(1)</sup> | 192h | OETRIG | | | | | | | | | | | | | | | | 0000 | | CCP3STAT <sup>(1)</sup> | 194h | - | | | | | | | | | | | | | | | | 0000 | | CCP3TMRL <sup>(1)</sup> | 198h | | | | | | | MCCF | P3 Time Ba | se Register | Low Word | • | | | | • | | 0000 | | CCP3TMRH <sup>(1)</sup> | 19Ah | | | | | | | MCCF | 3 Time Bas | se Register | High Word | | | | | | | 0000 | | CCP3PRL <sup>(1)</sup> | 19Ch | | | | | | | MCCP3 T | īme Base F | Period Regis | ster Low Wor | d | | | | | | FFFF | | CCP3PRH <sup>(1)</sup> | 19Eh | | | | | | | МССР3 Т | ïme Base P | eriod Regis | ter High Wor | d d | | | | | | FFFF | | CCP3RAL <sup>(1)</sup> | 1A0h | | | | | | | Οι | utput Compa | are 3 Data V | Vord A | | | | | | | 0000 | | CCP3RBL <sup>(1)</sup> | 1A4h | | | • | | • | | Oı | utput Compa | are 3 Data V | Word B | • | | | | | | 0000 | | CCP3BUFL <sup>(1)</sup> | 1A8h | | | • | | • | | Input | Capture 3 [ | Data Buffer | Low Word | • | | | | | | 0000 | | CCP3BUFH <sup>(1)</sup> | 1AAh | | | | | | | Input | Capture 3 E | Oata Buffer I | High Word | | | | | | | 0000 | $\textbf{Legend:} \quad x = \text{unknown, } u = \text{unchanged, } \\ \textbf{\_} = \text{unimplemented, } q = \text{value depends on condition, } r = \text{reserved.}$ TABLE 4-11: SCCP4 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |--------------------------|-------|---------|----------------------------------------------------------------------|---------|--------|---------|---------|-----------|--------------|----------------|-------------|---------|-------|-------|-------|-------|-------|---------------| | CCP4CON1L <sup>(1)</sup> | 1ACh | CCPON | _ | CCPSIDL | r | TMRSYNC | CLKSEL2 | CLKSEL1 | CLKSEL0 | TMRPS1 | TMRPS0 | T32 | CCSEL | MOD3 | MOD2 | MOD1 | MOD0 | 0000 | | CCP4CON1H(1) | 1AEh | OPSSRC | RTRGEN | - | - | IOPS3 | IOPS2 | IOPS1 | IOPS0 | TRIGEN | ONESHOT | ALTSYNC | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | 0000 | | CCP4CON2L <sup>(1)</sup> | 1B0h | PWMRSEN | ASDGM | - | SSDG | - | _ | _ | _ | ASDG7 | ASDG6 | ASDG5 | ASDG4 | ASDG3 | ASDG2 | ASDG1 | ASDG0 | 0000 | | CCP4CON2H(1) | 1B2h | OENSYNC | | | | | | | | | | | | | | | | 0100 | | CCP4CON3H(1) | 1B6h | OETRIG | RIG OSCNT2 OSCNT1 OSCNT0 — — — — — POLACE — PSSACE1 PSSACE0 — — | | | | | | | | | | | | | | | 0000 | | CCP4STATL <sup>(1)</sup> | 1B8h | - | TRIG OSCNT2 OSCNT1 OSCNT0 — — — — — — — POLACE — PSSACE1 PSSACE0 — — | | | | | | | | | | | | | | | 0000 | | CCP4TMRL <sup>(1)</sup> | 1BCh | | | | | | | SCCP4 | 1 Time Base | Register Lo | w Word | | | | | | | 0000 | | CCP4TMRH(1) | 1BEh | | | | | | | SCCP4 | Time Base | Register Hi | gh Word | | | | | | | 0000 | | CCP4PRL(1) | 1C0h | | | | | | | SCCP4 Tir | ne Base Pe | riod Registe | r Low Word | | | | | | | FFFF | | CCP4PRH(1) | 1C2h | | | | | | | SCCP4 Tir | ne Base Pe | riod Registe | r High Word | | | | | | | FFFF | | CCP4RAL <sup>(1)</sup> | 1C4h | | | | | | | Out | put Compar | e 4 Data Wo | ord A | | | | | | | 0000 | | CCP4RBL <sup>(1)</sup> | 1C8h | | | | | | | Out | put Compar | e 4 Data Wo | ord B | | | | | | - | 0000 | | CCP4BUFL <sup>(1)</sup> | 1CCh | | | • | • | | • | Input C | Capture 4 Da | ata Buffer Lo | w Word | | | • | | | | 0000 | | CCP4BUFH <sup>(1)</sup> | 1CEh | | | | | | | Input C | apture 4 Da | ıta Buffer Hiç | gh Word | | | | | | | 0000 | **Legend:** x = unknown, u = unchanged, --- = unimplemented, q = value depends on condition, r = reserved. **Note 1:** These registers are available only on PIC24F(V)16KM2XX devices. TABLE 4-12: SCCP5 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |--------------------------|-------|---------|------------------------------------------------------------------|---------|--------|---------|---------|-----------|-------------|---------------|-------------|---------|-------|-------|-------|-------|-------|---------------| | CCP5CON1L <sup>(1)</sup> | 1D0h | CCPON | _ | CCPSIDL | r | TMRSYNC | CLKSEL2 | CLKSEL1 | CLKSEL0 | TMRPS1 | TMRPS0 | T32 | CCSEL | MOD3 | MOD2 | MOD1 | MOD0 | 0000 | | CCP5CON1H <sup>(1)</sup> | 1D2h | OPSSRC | RTRGEN | 1 | 1 | IOPS3 | IOPS2 | IOPS1 | IOPS0 | TRIGEN | ONESHOT | ALTSYNC | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | 0000 | | CCP5CON2L <sup>(1)</sup> | 1D4h | PWMRSEN | ASDGM | ı | SSDG | _ | _ | _ | _ | ASDG7 | ASDG6 | ASDG5 | ASDG4 | ASDG3 | ASDG2 | ASDG1 | ASDG0 | 0000 | | CCP5CON2H <sup>(1)</sup> | 1D6h | OENSYNC | | | | | | | | | | | | | | | | 0100 | | CCP5CON3H <sup>(1)</sup> | 1DAh | OETRIG | TRIG OSCNT2 OSCNT1 OSCNT0 — — — — — POLACE — PSSACE1 PSSACE0 — — | | | | | | | | | | | | | | | 0000 | | CCP5STATL <sup>(1)</sup> | 1DCh | - | CCPTRIG TRSET TRCLR ASEVT SCEVT ICDIS ICOV ICBN | | | | | | | | | | | | | | | 0000 | | CCP5TMRL <sup>(1)</sup> | 1E0h | | | | | | | SCCP5 | Time Base | Register Lo | w Word | | | | | | | 0000 | | CCP5TMRH <sup>(1)</sup> | 1E2h | | | | | | | SCCP5 | Time Base | Register Hig | gh Word | | | | | | | 0000 | | CCP5PRL <sup>(1)</sup> | 1E4h | | | | | | | SCCP5 Tir | ne Base Pe | riod Registe | r Low Word | | | | | | | FFFF | | CCP5PRH <sup>(1)</sup> | 1E6h | | | | | | | SCCP5 Tin | ne Base Per | iod Register | r High Word | | | | | | | FFFF | | CCP5RAL <sup>(1)</sup> | 1E8h | | | | | | | Out | put Compar | e 5 Data Wo | ord A | | | | | | | 0000 | | CCP5RBL <sup>(1)</sup> | 1ECh | | | | | | | Out | put Compar | e 5 Data Wo | ord B | | | | | | | 0000 | | CCP5BUFL <sup>(1)</sup> | 1F0h | | | | | | | Input C | apture 5 Da | ita Buffer Lo | w Word | | | | | | | 0000 | | CCP5BUFH <sup>(1)</sup> | 1F2h | | | | | | | Input C | apture 5 Da | ta Buffer Hig | gh Word | | | | | | | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. TABLE 4-13: MSSP1 (I<sup>2</sup>C/SPI) REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|--------|--------|--------|--------|--------|-------|-------|--------|---------|-------------------------|-----------------------------|----------------------------------------------------------|----------------------|-------|-------|---------------| | SSP1BUF | 200h | _ | _ | _ | _ | _ | _ | - | _ | | | MSSP1 Re | ceive Buffer | /Transmit R | legister | | | 00xx | | SSP1CON1 | 202h | _ | - | _ | _ | _ | _ | 1 | _ | WCOL | SSPOV | SSPEN | CKP | SSPM3 | SSPM2 | SSPM1 | SSPM0 | 0000 | | SSP1CON2 | 204h | _ | - | _ | _ | _ | _ | 1 | _ | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | 0000 | | SSP1CON3 | 206h | _ | - | _ | _ | _ | _ | 1 | _ | ACKTIM | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | 0000 | | SSP1STAT | 208h | _ | - | _ | _ | _ | _ | | _ | SMP | CKE | D/Ā | Р | S | R/W | UA | BF | 0000 | | SSP1ADD | 20Ah | _ | | _ | _ | - | _ | | | | MSSF | MSSP1 Add<br>1 Baud Rat | ress Registe<br>e Reload Re | er in I <sup>2</sup> C Sla<br>gister in I <sup>2</sup> C | ve Mode<br>Master Mo | de | | 0000 | | SSP1MSK | 20Ch | _ | _ | _ | _ | _ | _ | _ | | | | | MSK[7 | :0] | | | | 00FF | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. TABLE 4-14: MSSP2 (I<sup>2</sup>C/SPI) REGISTER MAP | ., | | <del> ,</del> | . 0,0 | , | | | | | | | | | | | | | | | |-------------------------|-------|---------------|--------|--------|--------|--------|--------|-------|-------|-----------------------------------------------------------------------------------------------------------------------|---------|----------|--------------|--------------|----------|-------|-------|---------------| | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | | SSP2BUF <sup>(1)</sup> | 210h | _ | | _ | _ | _ | _ | _ | _ | | | MSSP2 Re | ceive Buffer | r/Transmit F | Register | | | 00xx | | SSP2CON1 <sup>(1)</sup> | 212h | _ | _ | _ | _ | _ | _ | _ | _ | WCOL | SSPOV | SSPEN | CKP | SSPM3 | SSPM2 | SSPM1 | SSPM0 | 0000 | | SSP2CON2 <sup>(1)</sup> | 214h | _ | _ | _ | _ | _ | _ | _ | _ | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | 0000 | | SSP2CON3 <sup>(1)</sup> | 216h | _ | _ | _ | _ | _ | _ | _ | _ | ACKTIM | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | 0000 | | SSP2STAT <sup>(1)</sup> | 218h | _ | _ | _ | _ | _ | _ | _ | _ | SMP | CKE | D/Ā | Р | S | R/W | UA | BF | 0000 | | SSP2ADD <sup>(1)</sup> | 21Ah | _ | _ | _ | _ | _ | _ | _ | _ | MSSP2 Address Register in I <sup>2</sup> C Slave Mode MSSP2 Baud Rate Reload Register in I <sup>2</sup> C Master Mode | | | | | | | | | | SSP2MSK <sup>(1)</sup> | 21Ch | _ | | _ | _ | | _ | _ | _ | | • | • | MSK[7 | ː0] | • | • | • | OOFF | $\textbf{Legend:} \quad x = unknown, \ u = unchanged, \\ \textbf{\_} = unimplemented, \ q = value \ depends \ on \ condition, \ r = reserved.$ #### **TABLE 4-15: UART1 REGISTER MAP** | | _ | _ | | | | | | | | | | | | | | | | | |-----------|-------|----------|--------|----------|--------|--------|--------|-------|-------------|---------------|----------|-----------|-------------|-------|--------|--------|-------|---------------| | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | | U1MODE | 220h | UARTEN | _ | USIDL | IREN | RTSMD | _ | UEN1 | UEN0 | WAKE | LPBACK | ABAUD | URXINV | BRGH | PDSEL1 | PDSEL0 | STSEL | 0000 | | U1STA | 222h | UTXISEL1 | UTXINV | UTXISEL0 | _ | UTXBRK | UTXEN | UTXBF | TRMT | URXISEL1 | URXISEL0 | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | U1TXREG | 224h | _ | _ | - | _ | _ | _ | _ | | | | UART1 Tra | nsmit Regi | ster | | | | xxxx | | U1RXREG | 226h | _ | _ | - | _ | _ | _ | _ | | | | UART1 Re | ceive Regis | ster | | | | 0000 | | U1BRG | 228h | | | | | | | E | Baud Rate G | enerator Pres | caler | | | | | | | 0000 | $\textbf{Legend:} \ \ x = \text{unknown}, \ u = \text{unchanged}, \ \textbf{--} = \text{unimplemented}, \ q = \text{value depends on condition}, \ r = \text{reserved}.$ #### **TABLE 4-16: UART2 REGISTER MAP** | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | | |------------------------|-------|----------|-------------------------------|----------|--------|--------|--------|-------|------------------------|----------|----------|-----------|-------------|-------|--------|--------|-------|---------------|--| | U2MODE(1) | 230h | UARTEN | _ | USIDL | IREN | RTSMD | _ | UEN1 | UEN0 | WAKE | LPBACK | ABAUD | URXINV | BRGH | PDSEL1 | PDSEL0 | STSEL | 0000 | | | U2STA <sup>(1)</sup> | 232h | UTXISEL1 | UTXINV | UTXISEL0 | _ | UTXBRK | UTXEN | UTXBF | TRMT | URXISEL1 | URXISEL0 | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | 0110 | | | U2TXREG <sup>(1)</sup> | 234h | _ | _ | _ | _ | _ | _ | _ | | | | UART2 Tra | nsmit Regis | ter | | | | xxxx | | | U2RXREG <sup>(1)</sup> | 236h | _ | _ | _ | _ | _ | _ | _ | UART2 Receive Register | | | | | | | | | | | | U2BRG <sup>(1)</sup> | 238h | | Baud Rate Generator Prescaler | | | | | | | | | | | | | | 0000 | | | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### TABLE 4-17: OP AMP 1 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |------------------------|-------|--------|--------|---------|--------|--------|--------|-------|-------|--------|-------|---------|---------|---------|---------|---------|---------|---------------| | AMP1CON <sup>(1)</sup> | 24Ah | AMPEN | I | AMPSIDL | AMPSLP | 1 | | | | SPDSEL | _ | NINSEL2 | NINSEL1 | NINSEL0 | PINSEL2 | PINSEL1 | PINSEL0 | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: This registers are available only on PIC24F(V)16KM2XX devices. #### TABLE 4-18: OP AMP 2 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |------------------------|-------|--------|--------|---------|--------|--------|--------|-------|-------|--------|-------|---------|---------|---------|---------|---------|---------|---------------| | AMP2CON <sup>(1)</sup> | 24Ch | AMPEN | 1 | AMPSIDL | AMPSLP | _ | _ | 1 | 1 | SPDSEL | 1 | NINSEL2 | NINSEL1 | NINSEL0 | PINSEL2 | PINSEL1 | PINSEL0 | 0000 | IC24FV16KM204 FAMIL **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: This registers are available only on PIC24F(V)16KM2XX devices. #### TABLE 4-19: DAC1 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |------------|-------|--------|--------|---------|--------|--------|--------|-------|-----------|---------------------|----------|----------|----------|----------|----------|---------|---------|---------------| | DAC1CON(1) | 274h | DACEN | _ | DACSIDL | DACSLP | DACFM | _ | SRDIS | DACTRIG | DACOE | DACTSEL4 | DACTSEL3 | DACTSEL2 | DACTSEL1 | DACTSEL0 | DACREF1 | DACREF0 | 0000 | | DAC1DAT(1) | 276h | | | | | | | | DACDAT[15 | i:0] <sup>(2)</sup> | | | | | | | | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: These registers are available only on PIC24F(V)16KM1XX devices. 2: The 8-bit result format depends on the value of the DACFM control bit. #### TABLE 4-20: DAC2 REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |------------------------|-------|--------|--------|---------|--------|--------|--------|-------|-----------|---------------------|----------|----------|----------|----------|----------|---------|---------|---------------| | DAC2CON <sup>(1)</sup> | 278h | DACEN | - | DACSIDL | DACSLP | DACFM | _ | SRDIS | DACTRIG | DACOE | DACTSEL4 | DACTSEL3 | DACTSEL2 | DACTSEL1 | DACTSEL0 | DACREF1 | DACREF0 | 0000 | | DAC2DAT <sup>(1)</sup> | 27Ah | | | | | | | | DACDAT[15 | i:0] <sup>(2)</sup> | • | • | | | | | | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: These registers are available only on PIC24F(V)16KM2XX devices. 2: The 8-bit result format depends on the value of the DACFM control bit. #### **TABLE 4-21: PORTA REGISTER MAP** | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 <sup>(4,5)</sup> | Bit 10 <sup>(4,5)</sup> | Bit 9 <sup>(4,5)</sup> | Bit 8 <sup>(4,5)</sup> | Bit 7 <sup>(4)</sup> | Bit 6 <sup>(3)</sup> | Bit 5 <sup>(2)</sup> | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|--------|--------|--------|----------------------------|-------------------------|------------------------|------------------------|----------------------|----------------------|----------------------|-------|-------|---------------------|-------|-------|---------------| | TRISA | 2C0h | _ | _ | _ | _ | | | | | | | | | | 0FDF <sup>(1)</sup> | | | | | PORTA | 2C2h | _ | - | _ | _ | RA[11:0] xxx | | | | | | | | | xxxx | | | | | LATA | 2C4h | _ | - | _ | _ | LATA[11:6] — LATA[4:0] xxx | | | | | | | | | xxxx | | | | | ODCA | 2C6h | _ | - | _ | _ | | | | | | | | | | | 0000 | | | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. - **Note 1:** Reset value depends on the device type; the PIC24F16KM204 value is shown. - 2: These bits are only available when MCLRE (FPOR[7]) = 0. - 3: These bits are not implemented in FV devices. - 4: These bits are not implemented in 20-pin devices. - 5: These bits are not implemented in 28-pin devices. #### **TABLE 4-22: PORTB REGISTER MAP** | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 <sup>(2)</sup> | Bit 10 <sup>(2)</sup> | Bit 9 | Bit 8 | Bit 7 | Bit 6 <sup>(2)</sup> | Bit 5 <sup>(2)</sup> | Bit 4 | Bit 3 <sup>(2)</sup> | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|-------------|--------|--------|-----------------------|-----------------------|-------|-------|-------|----------------------|----------------------|-------|----------------------|-------|-------|-------|---------------| | TRISB | 2C8h | | TRISB[15:0] | | | | | | | | | | | | | | | FFFF(1) | | PORTB | 2CAh | | RB[15:0] | | | | | | | | | | | | | | xxxx | | | LATB | 2CCh | | LATB[15:0] | | | | | | | | | | | | | | xxxx | | | ODCB | 2CEh | | | | | | | | ODB[1 | 5:0] | | | | | | | | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: Reset value depends on the device type; the PIC24F16KM204 value is shown. 2: These bits are not implemented in 20-pin devices. #### **TABLE 4-23: PORTC REGISTER MAP** | File<br>Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 <sup>(2,3)</sup> | Bit 8 <sup>(2,3)</sup> | Bit 7 <sup>(2,3)</sup> | Bit 6 <sup>(2,3)</sup> | Bit 5 <sup>(2,3)</sup> | Bit 4 <sup>(2,3)</sup> | Bit 3 <sup>(2,3)</sup> | Bit 2 <sup>(2,3)</sup> | Bit 1 <sup>(2,3)</sup> | Bit 0 <sup>(2,3)</sup> | All<br>Resets | |--------------|-------|--------|--------|--------|--------|--------|--------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|---------------| | TRISC | 2D0h | _ | _ | _ | _ | _ | _ | | | | | | | | | | | 03FF(1) | | PORTC | 2D2h | _ | _ | _ | _ | _ | _ | | | | | | | | | | | xxxx | | LATTC | 2D4h | _ | _ | _ | _ | _ | _ | - LATC[9:0] xx | | | | | | | | | | xxxx | | ODCC | 2D6h | _ | _ | _ | _ | _ | _ | ODCIONI | | | | | | | | | | | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: Reset value depends on the device type; the PIC24F16KM204 value is shown. 2: These bits are not implemented in 20-pin devices. 3: These bits are not implemented in 28-pin devices. #### TABLE 4-24: PAD CONFIGURATION REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|--------|--------|--------|------------------------|------------------------|---------|---------|-------|-------|-------|-------|-------|-------|-------|-------|---------------| | PADCFG1 | 2FCh | _ | _ | _ | _ | SDO2DIS <sup>(1)</sup> | SCK2DIS <sup>(1)</sup> | SDO1DIS | SCK1DIS | _ | _ | _ | _ | - | _ | _ | _ | 0000 | PIC24FV16KM204 FAMILY $\textbf{Legend:} \ \ x = \text{unknown}, \ u = \text{unchanged}, \ \textbf{--} = \text{unimplemented}, \ q = \text{value depends on condition}, \ r = \text{reserved}.$ Note 1: These bits are not available on the PIC24F(V)08KM101 device, read as '0'. | | C | |---|-------------| | | ũ | | | ۲ | | | ۶ | | | ૅ | | | 03000303030 | | | ۶ | | | ì | | | page | | ( | ç | | | Ü | | | - | | | | | | | | TABLE 4-2 | 25. | A /D | REGIS | TED | MAD | |-----------|-----|------|-------|-----|-------| | IADLE 4- | 20 | A/U | KEGIO | IEK | IVIAE | | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|---------|---------|---------|---------|----------|--------------|------------|-------------------------|-------------------------|-------------------------|-----------------------|-----------|---------|------------------------|------------------------|---------|---------------| | ADC1BUF0 | 300h | | | | | A/D D | ata Buffer 0 | /Threshold | for Channel 0/ | Threshold for | Channel 0 & 1 | 2 in Window | Compare | | | | | xxxx | | ADC1BUF1 | 302h | | | | | A/D D | ata Buffer 1 | /Threshold | for Channel 1/ | Threshold for | Channel 1 & 1 | 3 in Window | Compare | | | | | XXXX | | ADC1BUF2 | 304h | | | | | A/D D | ata Buffer 2 | /Threshold | for Channel 2/ | Threshold for | Channel 2 & 1 | 4 in Window | Compare | | | | | xxxx | | ADC1BUF3 | 306h | | | | | A/D D | ata Buffer 3 | /Threshold | for Channel 3/ | Threshold for | Channel 3 & 1 | 5 in Window | Compare | | | | | xxxx | | ADC1BUF4 | 308h | | | | | A/D D | ata Buffer 4 | /Threshold | for Channel 4/ | Threshold for | Channel 4 & 1 | 6 in Window | Compare | | | | | xxxx | | ADC1BUF5 | 30Ah | | | | | A/D D | ata Buffer 5 | /Threshold | for Channel 5/ | Threshold for | Channel 5 & 1 | 7 in Window | Compare | | | | | XXXX | | ADC1BUF6 | 30Ch | | | | | A/D D | ata Buffer 6 | /Threshold | for Channel 6/ | Threshold for | Channel 6 & 1 | 8 in Window | Compare | | | | | XXXX | | ADC1BUF7 | 30Eh | | | | | A/D D | ata Buffer 7 | /Threshold | for Channel 7/ | Threshold for | Channel 7 & 1 | 9 in Window | Compare | | | | | xxxx | | ADC1BUF8 | 310h | | | | | A/D D | ata Buffer 8 | /Threshold | for Channel 8/ | Threshold for | Channel 8 & 2 | 0 in Window | Compare | | | | | XXXX | | ADC1BUF9 | 312h | | | | | A/D D | ata Buffer 9 | /Threshold | for Channel 9/ | Threshold for | Channel 9 & 2 | 1 in Window | Compare | | | | | xxxx | | ADC1BUF10 | 314h | | | | | A/D Dat | a Buffer 10/ | Threshold | for Channel 10 | /Threshold for | r Channel 10 8 | 22 in Windo | w Compare | | | | | xxxx | | ADC1BUF11 | 316h | | | | | A/D Dat | a Buffer 11/ | Threshold | for Channel 11 | /Threshold for | Channel 11 & | 23 in Windo | w Compare | | | | | XXXX | | ADC1BUF12 | 318h | | | | | A/D Da | ta Buffer 12 | /Threshold | for Channel 12 | 2/Threshold fo | r Channel 0 & | 12 in Windov | w Compare | | | | | xxxx | | ADC1BUF13 | 31Ah | | | | | A/D Da | ta Buffer 13 | /Threshold | for Channel 13 | 3/Threshold fo | r Channel 1 & | 13 in Windov | w Compare | | | | | xxxx | | ADC1BUF14 | 31Ch | | | | | | | | | | | | | | | XXXX | | | | ADC1BUF15 | 31Eh | | | | | | | | | | | | | | | xxxx | | | | ADC1BUF16 | 320h | | | | | A/D Da | ta Buffer 16 | /Threshold | for Channel 16 | 6/Threshold fo | r Channel 4 & | 16 in Windov | w Compare | | | | | xxxx | | ADC1BUF17 | 322h | | | | | A/D Da | ta Buffer 17 | /Threshold | for Channel 17 | 7/Threshold fo | or Channel 5 & | 17 in Window | w Compare | | | | | XXXX | | ADC1BUF18 | 324h | | | | | A/D Da | ta Buffer 18 | /Threshold | for Channel 18 | 8/Threshold fo | r Channel 6 & | 18 in Windov | w Compare | | | | | XXXX | | ADC1BUF19 | 326h | | | | | A/D Da | ta Buffer 19 | /Threshold | for Channel 19 | 9/Threshold fo | or Channel 7 & | 19 in Windov | w Compare | | | | | XXXX | | ADC1BUF20 | 328h | | | | | A/D Da | ta Buffer 20 | /Threshold | for Channel 20 | 0/Threshold fo | or Channel 8 & | 20 in Window | w Compare | | | | | XXXX | | ADC1BUF21 | 32Ah | | | | | A/D Da | ta Buffer 21 | /Threshold | for Channel 2 | 1/Threshold fo | r Channel 9 & | 21 in Windov | w Compare | | | | | xxxx | | ADC1BUF22 | 32Ch | | | | | A/D Dat | a Buffer 22/ | Threshold | for Channel 22 | Threshold for | r Channel 10 8 | 22 in Windo | w Compare | | | | | xxxx | | ADC1BUF23 | 32Eh | | | | | A/D Dat | a Buffer 23/ | Threshold | for Channel 23 | 3/Threshold for | r Channel 11 & | 23 in Windo | w Compare | | | | | XXXX | | AD1CON1 | 340h | ADON | - | ADSIDL | ı | _ | MODE12 | FORM1 | FORM0 | SSRC3 | SSRC2 | SSRC1 | SSRC0 | _ | ASAM | SAMP | DONE | 0000 | | AD1CON2 | 342h | PVCFG1 | PVCFG0 | NVCFG0 | I | BUFREGEN | CSCNA | _ | - | BUFS | SMPI4 | SMPI3 | SMPI2 | SMPI1 | SMPI0 | BUFM | ALTS | 0000 | | AD1CON3 | 344h | ADRC | EXTSAM | _ | SAMC4 | SAMC3 | SAMC2 | SAMC1 | SAMC0 | ADCS7 | ADCS6 | ADCS5 | ADCS4 | ADCS3 | ADCS2 | ADCS1 | ADCS0 | 0000 | | AD1CHS | 348h | CH0NB2 | CH0NB1 | CH0NB0 | CH0SB4 | CH0SB3 | CH0SB2 | CH0SB1 | CH0SB0 | CH0NA2 | CH0NA1 | CH0NA0 | CH0SA4 | CH0SA3 | CH0SA2 | CH0SA1 | CH0SA0 | 0000 | | AD1CSSH | 34Eh | _ | CSS30 | CSS29 | CSS28 | CSS27 | CSS26 | _ | _ | CSS23 | CSS22 | CSS21 | CSS20 | CSS19 | CSS18 <sup>(1)</sup> | CSS17 <sup>(1)</sup> | CSS16 | 0000 | | AD1CSSL | 350h | CSS15 | CSS14 | CSS13 | CSS12 | CSS11 | CSS10 | CSS9 | CSS8 <sup>(1,2)</sup> | CSS7 <sup>(1,2)</sup> | CSS6 <sup>(1,2)</sup> | CSS5 <sup>(1)</sup> | CSS4 | CSS3 | CSS2 | CSS1 | CSS0 | 0000 | | AD1CON5 | 354h | ASEN | LPEN | CTMREQ | BGREQ | r | _ | ASINT1 | ASINT0 | _ | _ | _ | _ | WM1 | WM0 | CM1 | CM0 | 0000 | | AD1CHITH | 356h | _ | _ | _ | _ | _ | _ | _ | _ | CHH23 | CHH22 | CHH21 | CHH20 | CHH19 | CHH18 <sup>(1)</sup> | CHH17 <sup>(1)</sup> | CHH16 | 0000 | | AD1CHITL | 358h | CHH15 | CHH14 | CHH13 | CHH12 | CHH11 | CHH10 | CHH9 | CHH8 <sup>(1,2)</sup> | CHH7 <sup>(1,2)</sup> | CHH6 <sup>(1,2)</sup> | CHH5 <sup>(1)</sup> | CHH4 | CHH3 | CHH2 | CHH1 | CHH0 | 0000 | | AD1CTMENH | 360h | _ | | _ | | _ | _ | | _ | CTMEN23 | CTMEN22 | CTMEN21 | CTMEN20 | CTMEN19 | CTMEN18 <sup>(1)</sup> | CTMEN17 <sup>(1)</sup> | CTMEN16 | 0000 | | AD1CTMENL | 362h | CTMEN15 | CTMEN14 | CTMEN13 | CTMEN12 | CTMEN11 | CTMEN10 | CTMEN9 | CTMEN8 <sup>(1,2)</sup> | CTMEN7 <sup>(1,2)</sup> | CTMEN6 <sup>(1,2)</sup> | CTMEN5 <sup>(1)</sup> | CTMEN4 | CTMEN3 | CTMEN2 | CTMEN1 | CTMEN0 | 0000 | **Legend:** x = unknown, u = unchanged, --- = unimplemented, q = value depends on condition, r = reserved. Note 1: These bits are not implemented in 20-pin devices. 2: These bits are not implemented in 28-pin devices. #### TABLE 4-26: CTMU REGISTER MAP | | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |---|-----------|-------|---------|---------|----------|----------|----------|----------|----------|----------|---------|---------|----------|----------|----------|----------|---------|---------|---------------| | C | TMUCON1L | 35Ah | CTMUEN | _ | CTMUSIDL | TGEN | EDGEN | EDGSEQEN | IDISSEN | CTTRIG | ITRIM5 | ITRIM4 | ITRIM3 | ITRIM2 | ITRIM1 | ITRIM0 | IRNG1 | IRNG0 | 0000 | | C | TMUCON1H | 35Ch | EDG1MOD | EDG1POL | EDG1SEL3 | EDG1SEL2 | EDG1SEL1 | EDG1SEL0 | EDG2STAT | EDG1STAT | EDG2MOD | EDG2POL | EDG2SEL3 | EDG2SEL2 | EDG2SEL1 | EDG2SEL0 | _ | _ | 0000 | | C | TMUCON2L | 35Eh | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | IRSTEN | _ | DISCHS2 | DISCHS1 | DISCHS0 | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### **TABLE 4-27: ANSEL REGISTER MAP** | File<br>Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |--------------|-------|--------|--------|--------|--------|--------|--------|-------|-------|-------|----------------------|----------------------|----------------------|----------------------|------------------------|------------------------|------------------------|---------------------| | ANSA | 4E0h | _ | | _ | | _ | - | | _ | _ | - | | ANSA4 <sup>(2)</sup> | ANSA3 | ANSA2 | ANSA1 | ANSA0 | 001F <sup>(1)</sup> | | ANSB | 4E2h | ANSB15 | ANSB14 | ANSB13 | ANSB12 | | _ | ANSB9 | ANSB8 | ANSB7 | ANSB6 <sup>(2)</sup> | ANSB5 <sup>(2)</sup> | ANSB4 | ANSB3 <sup>(2)</sup> | ANSB2 | ANSB1 | ANSB0 | F3FF(1) | | ANSC | 4E4h | _ | | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | 1 | ANSC2 <sup>(2,3)</sup> | ANSC1 <sup>(2,3)</sup> | ANSC0 <sup>(2,3)</sup> | 0007 <sup>(1)</sup> | PIC24FV16KM204 FAMILY **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. **Note 1:** Reset value depends on the device type; the PIC24F16KM204 value is shown. 2: These bits are not implemented in 20-pin devices. 3: These bits are not implemented in 28-pin devices. #### TABLE 4-28: REAL-TIME CLOCK AND CALENDAR REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|--------|---------|---------|---------|--------------|---------------|----------------|-----------|---------|-------|-------|-------|-------|-------|-------|---------------| | ALRMVAL | 620h | | | | | | Alarm Value | High Register | r Window Based | d on APTF | R[1:0] | | | | | | | xxxx | | ALCFGRPT | 622h | ALRMEN | CHIME | AMASK3 | AMASK2 | AMASK1 | AMASK0 | ALRMPTR1 | ALRMPTR0 | ARPT7 | ARPT6 | ARPT5 | ARPT4 | ARPT3 | ARPT2 | ARPT1 | ARPT0 | 0000(1) | | RTCVAL | 624h | | | | | | RTCC Value I | High Register | Window Based | on RTCP | TR[1:0] | | | | | | | xxxx | | RCFGCAL | 626h | RTCEN | _ | RTCWREN | RTCSYNC | HALFSEC | RTCOE | RTCPTR1 | RTCPTR0 | CAL7 | CAL6 | CAL5 | CAL4 | CAL3 | CAL2 | CAL1 | CAL0 | 0000(1) | | RTCPWC | 628h | PWCEN | PWCPOL | PWCCPRE | PWCSPRE | RTCCLK1 | RTCCLK0 | RTCOUT1 | RTCOUT0 | _ | _ | _ | _ | _ | _ | _ | _ | 0000(1) | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: Values are reset only on a VDD POR event. #### TABLE 4-29: COMPARATOR REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------------------|-------|--------|--------|--------|--------|--------|----------------------|----------------------|-------|--------|--------|-------|----------------------|-------|----------------------|----------------------|-------|---------------| | CMSTAT | 630h | CMIDL | _ | _ | _ | | C3EVT <sup>(1)</sup> | C2EVT <sup>(1)</sup> | C1EVT | _ | _ | | _ | _ | C3OUT <sup>(1)</sup> | C2OUT <sup>(1)</sup> | C10UT | 0000 | | CVRCON | 632h | _ | _ | _ | ı | 1 | _ | _ | _ | CVREN | CVROE | CVRSS | CVR4 | CVR3 | CVR2 | CVR1 | CVR0 | 0000 | | CM1CON | 634h | CON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPOL1 | EVPOL0 | 1 | CREF1 | CREF0 | _ | CCH1 | CCH0 | 0000 | | CM2CON <sup>(1)</sup> | 636h | CON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPOL1 | EVPOL0 | 1 | CREF1 <sup>(1)</sup> | CREF0 | _ | CCH1 | CCH0 | 0000 | | CM3CON <sup>(1)</sup> | 638h | CON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPOL1 | EVPOL0 | _ | CREF1 <sup>(1)</sup> | CREF0 | _ | CCH1 | CCH0 | 0000 | $\textbf{Legend:} \quad \textbf{x} = \text{unknown}, \ \textbf{u} = \text{unchanged}, \\ \textbf{—} = \text{unimplemented}, \ \textbf{q} = \text{value depends on condition}, \ \textbf{r} = \text{reserved}.$ Note 1: These registers and bits are available only on PIC24F(V)16KM2XX devices. #### TABLE 4-30: BAND GAP BUFFER CONTROL REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | AII<br>Resets | |-----------|-------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|---------------| | BUFCON0 | 670h | _ | | _ | _ | _ | _ | _ | _ | | _ | _ | _ | | | BUFRE | F[1:0] | 0001 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### TABLE 4-31: CLOCK CONTROL REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|---------|-------|--------|-------|--------|---------|--------|--------|---------------| | RCON | 740h | TRAPR | IOPUWR | SBOREN | RETEN | _ | _ | СМ | PMSLP | EXTR | SWR | SWDTEN | WDTO | SLEEP | IDLE | BOR | POR | (Note 1) | | OSCCON | 742h | _ | COSC2 | COSC1 | COSC0 | _ | NOSC2 | NOSC1 | NOSC0 | CLKLOCK | _ | LOCK | 1 | CF | SOSCDRV | SOSCEN | OSWEN | (Note 2) | | CLKDIV | 744h | ROI | DOZE2 | DOZE1 | DOZE0 | DOZEN | RCDIV2 | RCDIV1 | RCDIV0 | _ | _ | _ | 1 | _ | _ | _ | _ | 0100 | | OSCTUN | 748h | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | | | TL | IN[5:0] | | | 0000 | | REFOCON | 74Eh | ROEN | _ | ROSSLP | ROSEL | RODIV3 | RODIV2 | RODIV1 | RODIV0 | _ | _ | _ | 1 | _ | _ | _ | _ | 0000 | | HLVDCON | 756h | HLVDEN | _ | HLSIDL | - | _ | ĺ | _ | _ | VDIR | BGVST | IRVST | | HLVDL3 | HLVDL2 | HLVDL1 | HLVDL0 | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. Note 1: RCON register Reset values are dependent on the type of Reset. 2: OSCCON register Reset values are dependent on Configuration fuses and by type of Reset. #### **TABLE 4-32: NVM REGISTER MAP** | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|--------|--------|---------|--------|--------|-------|-------|-------|-------|--------|--------|--------|--------|--------|--------|---------------| | NVMCON | 760h | WR | WREN | WRERR | PGMONLY | _ | _ | _ | _ | _ | ERASE | NVMOP5 | NVMOP4 | NVMOP3 | NVMOP2 | NVMOP1 | NVMOP0 | 0000 | | NVMKEY | 766h | _ | _ | _ | _ | _ | _ | _ | _ | | | | NVMKE | Y[7:0] | | | | 0000 | PIC24FV16KM204 FAMILY **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### TABLE 4-33: ULTRA LOW-POWER WAKE-UP REGISTER MAP | File Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |-----------|-------|--------|--------|---------|--------|--------|--------|-------|---------|-------|-------|-------|-------|-------|-------|-------|-------|---------------| | ULPWCON | 768h | ULPEN | _ | ULPSIDL | _ | _ | _ | _ | ULPSINK | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### TABLE 4-34: PMD REGISTER MAP | File<br>Name | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets | |--------------|-------|--------|--------|--------|--------|--------|--------|--------|-------|--------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|--------|---------------| | PMD1 | 770h | - | _ | - | 1 | T1MD | _ | _ | - | SSP1MD | U2MD <sup>(1)</sup> | U1MD | _ | _ | _ | _ | ADCMD | 0000 | | PMD2 | 772h | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | _ | CCP5MD <sup>(1)</sup> | CCP4MD <sup>(1)</sup> | CCP3MD <sup>(1)</sup> | CCP2MD | CCP1MD | 0000 | | PMD3 | 774h | _ | _ | _ | 1 | _ | CMPMD | RTCCMD | _ | _ | DAC1MD <sup>(1)</sup> | _ | _ | _ | _ | SSP2MD <sup>(1)</sup> | _ | 0000 | | PMD4 | 776h | _ | _ | _ | 1 | _ | _ | _ | _ | _ | ULPWUMD | _ | _ | REFOMD | CTMUMD | HLVDMD | _ | 0000 | | PMD6 | 77Ah | _ | _ | _ | 1 | _ | _ | _ | _ | _ | _ | AMP1MD <sup>(1)</sup> | DAC2MD <sup>(1)</sup> | AMP2MD <sup>(1)</sup> | _ | _ | _ | 0000 | | PMD8 | 77Eh | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | CLC2MD <sup>(1)</sup> | CLC1MD | _ | _ | 0000 | **Legend:** x = unknown, u = unchanged, — = unimplemented, q = value depends on condition, r = reserved. #### 4.2.5 SOFTWARE STACK In addition to its use as a Working register, the W15 register in PIC24F devices is also used as a Software Stack Pointer. The pointer always points to the first available free word and grows from lower to higher addresses. It pre-decrements for stack pops and post-increments for stack pushes, as depicted in Figure 4-4. For a PC push during any CALL instruction, the MSB of the PC is zero-extended before the push, ensuring that the MSB is always clear. **Note:** A PC push during exception processing will concatenate the SRL register to the MSB of the PC prior to the push. The Stack Pointer Limit Value (SPLIM) register, associated with the Stack Pointer, sets an upper address boundary for the stack. SPLIM is uninitialized at Reset. As is the case for the Stack Pointer, SPLIM[0] is forced to '0' as all stack operations must be word-aligned. Whenever an EA is generated using W15 as a source or destination pointer, the resulting address is compared with the value in SPLIM. If the contents of the Stack Pointer (W15) and the SPLIM register are equal, and a push operation is performed, a stack error trap will not occur. The stack error trap will occur on a subsequent push operation. Thus, for example, if it is desirable to cause a stack error trap when the stack grows beyond address, 0DF6 in RAM, initialize the SPLIM with the value, 0DF4. Similarly, a Stack Pointer underflow (stack error) trap is generated when the Stack Pointer address is found to be less than 0800h. This prevents the stack from interfering with the Special Function Register (SFR) space. **Note:** A write to the SPLIM register should not be immediately followed by an indirect read operation using W15. #### FIGURE 4-4: CALL STACK FRAME # 4.3 Interfacing Program and Data Memory Spaces The PIC24F architecture uses a 24-bit wide program space and 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 these data successfully, they must be accessed in a way that preserves the alignment of information in both spaces. Apart from the normal execution, the PIC24F architecture provides two methods by which the 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, PSV Table instructions allow an application to read or write small areas of the program memory. This makes the method ideal for accessing data tables that need to be updated from time to time. 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. It can only access the least significant word (lsw) of the program word. #### 4.3.1 ADDRESSING PROGRAM SPACE Since the address ranges for the data and program spaces are 16 and 24 bits, respectively, a method is needed to create a 23-bit or 24-bit program address from 16-bit data registers. The solution depends on the interface method to be used. For table operations, the 8-bit Table Memory Page Address register (TBLPAG) is used to define a 32K word region within the program space. This is concatenated with a 16-bit EA to arrive at a full 24-bit program space address. In this format, the Most Significant bit (MSb) of TBLPAG is used to determine if the operation occurs in the user memory (TBLPAG[7] = 0) or the configuration memory (TBLPAG[7] = 1). For remapping operations, the 8-bit Program Space Visibility Page Address register (PSVPAG) is used to define a 16K word page in the program space. When the MSb of the EA is '1', PSVPAG is concatenated with the lower 15 bits of the EA to form a 23-bit program space address. Unlike the table operations, this limits remapping operations strictly to the user memory area. See Table 4-35 and Figure 4-5 to know how the program EA is created for table operations and remapping accesses from the data EA. Here, P[23:0] refers to a program space word, whereas D[15:0] refers to a Data Space word. TABLE 4-35: PROGRAM SPACE ADDRESS CONSTRUCTION | Access Tyres | Access | Program Space Address | | | | | | | | | |--------------------------|---------------|-----------------------|------------|--------------------------------------------------|---------------|-----|--|--|--|--| | Access Type | Space | [23] | [22:16] | [15] | [14:1] | [0] | | | | | | Instruction Access | User | 0 | | PC[22:1] | | 0 | | | | | | (Code Execution) | | | 0xx xxxx x | xxx xxxx | xxxx xxx0 | | | | | | | TBLRD/TBLWT | User | TE | BLPAG[7:0] | | Data EA[15:0] | | | | | | | (Byte/Word Read/Write) | | 0: | xxx xxxx | XXX | x xxxx xxxx x | XXX | | | | | | | Configuration | TE | BLPAG[7:0] | Data EA[15:0] | | | | | | | | | | 1: | xxx xxxx | xxxx xxxx xxxx xxxx | | | | | | | | Program Space Visibility | User | 0 | PSVPAG[7: | 7:0] <sup>(2)</sup> Data EA[14:0] <sup>(1)</sup> | | | | | | | | (Block Remap/Read) | | 0 | XXXX XXX | XXX XXXX XXXX XX | | | | | | | - **Note 1:** Data EA[15] is always '1' in this case, but is not used in calculating the program space address. Bit 15 of the address is PSVPAG[0]. - 2: PSVPAG can have only two values ('00' to access program memory and FF to access data EEPROM) on the PIC24F16KM family. FIGURE 4-5: DATA ACCESS FROM PROGRAM SPACE ADDRESS GENERATION memory space. # 4.3.2 DATA ACCESS FROM PROGRAM MEMORY AND DATA EEPROM 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 memory without going through Data Space. It also offers a direct method of reading or writing a word of any address within data EEPROM memory. The TBLRDH and TBLWTH instructions are the only method to read or write the upper 8 bits of a program space word as data. Note: The TBLRDH and TBLWTH instructions are not used while accessing data EEPROM memory. 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, word-wide address spaces, residing side by side, each with the same address range. TBLRDL and TBLWTL access the space which contains the least significant data word, and TBLRDH and TBLWTH access the space which 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, it 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, it maps the entire upper word of a program address (P[23:16]) to a data address. Note that D[15:8], the 'phantom' byte, will always be '0'. In Byte mode, it maps the upper or lower byte of the program word to D[7:0] of the data address, as above. Note that the data will always be '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 Section 5.0 "Flash Program Memory". For all table operations, the area of program memory space to be accessed is determined by the Table Memory Page Address register (TBLPAG). TBLPAG covers the entire program memory space of the device, including user 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. **Note:** Only Table Read operations will execute in the configuration memory space, and only then, in implemented areas, such as the Device ID. Table Write operations are not allowed. FIGURE 4-6: ACCESSING PROGRAM MEMORY WITH TABLE INSTRUCTIONS # 4.3.3 READING DATA FROM PROGRAM MEMORY USING PROGRAM SPACE VISIBILITY The upper 32 Kbytes of Data Space may optionally be mapped into a 16K word page of the program space. This provides transparent access of stored constant data from the Data Space without the need to use special instructions (i.e., TBLRDL/H). Program space access through the Data Space occurs if the MSb of the Data Space, EA, is '1' and PSV is enabled by setting the PSV bit in the CPU Control (CORCON[2]) register. The location of the program memory space to be mapped into the Data Space is determined by the Program Space Visibility Page Address register (PSVPAG). This 8-bit register defines any one of 256 possible pages of 16K words in program space. In effect, PSVPAG functions as the upper 8 bits of the program memory address, with the 15 bits of the EA functioning as the lower bits. By incrementing the PC by two for each program memory word, the lower 15 bits of Data Space addresses directly map to the lower 15 bits in the corresponding program space addresses. Data reads from this area add an additional cycle to the instruction being executed, since two program memory fetches are required. Although each Data Space address, 8000h and higher, maps directly into a corresponding program memory address (see Figure 4-7), only the lower 16 bits of the 24-bit program word are used to contain the data. The upper 8 bits of any program space locations used as data should be programmed with '1111 1111' or '0000 0000' to force a NOP. This prevents possible issues should the area of code ever be accidentally executed. **Note:** PSV access is temporarily disabled during Table Reads/Writes. For operations that use PSV and are executed outside a REPEAT loop, the MOV and MOV. D instructions will require one instruction cycle in addition to the specified execution time. All other instructions will require two instruction cycles in addition to the specified execution time. For operations that use PSV, which are executed inside a REPEAT loop, there will be some instances that require two instruction cycles in addition to the specified execution time of the instruction: - · Execution in the first iteration - · Execution in the last iteration - Execution prior to exiting the loop due to an interrupt - Execution upon re-entering the loop after an interrupt is serviced Any other iteration of the REPEAT loop will allow the instruction accessing data, using PSV, to execute in a single cycle. #### 5.0 FLASH PROGRAM MEMORY Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on Flash programming, refer to "PIC24F Flash Program Memory" (www.microchip.com/DS30009715) in the "dsPIC33/PIC24F Family Reference Manual". The PIC24FV16KM204 family of devices contains internal Flash program memory for storing and executing application code. The memory is readable, writable and erasable when operating with VDD over 1.8V. Flash memory can be programmed in three ways: - In-Circuit Serial Programming™ (ICSP™) - Run-Time Self-Programming (RTSP) - · Enhanced In-Circuit Serial Programming (Enhanced ICSP) ICSP allows a PIC24FXXXXX device to be serially programmed while in the end application circuit. This is simply done with two lines for the programming clock and programming data (which are named PGECx and PGEDx, respectively), and three other lines for power (VDD), ground (Vss) and Master Clear/Program Mode Entry Voltage (MCLR/VPP). This allows customers to manufacture boards with unprogrammed devices and then program the microcontroller just before shipping the product. This also allows the most recent firmware or custom firmware to be programmed. Run-Time Self-Programming (RTSP) is accomplished using TBLRD (Table Read) and TBLWT (Table Write) instructions. With RTSP, the user may write program memory data in blocks of 32 instructions (96 bytes) at a time, and erase program memory in blocks of 32, 64 and 128 instructions (96,192 and 384 bytes) at a time. The NVMOP[1:0] (NVMCON[1:0]) bits decide the erase block size. #### 5.1 Table Instructions and Flash **Programming** Regardless of the method used, Flash memory programming is done with the Table Read and 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 the TBLPAG[7:0] bits and the Effective Address (EA) from a W register, specified in the table instruction, as depicted in Figure 5-1. The TBLRDL and the 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 The PIC24F Flash program memory array is organized into rows of 32 instructions or 96 bytes. RTSP allows the user to erase blocks of one row, two rows and four rows (32, 64 and 128 instructions) at a time, and to program one row at a time. It is also possible to program single words. The 1-row (96 bytes), 2-row (192 bytes) and 4-row (384 bytes) erase blocks, and single row write block (96 bytes) are edge-aligned, from the beginning of program memory. When data are written to program memory using TBLWT instructions, the data are not written directly to memory. Instead, data written using Table Writes are stored in holding latches until the programming sequence is executed. Any number of TBLWT instructions can be executed and a write will be successfully performed. However, 32 TBLWT instructions are required to write the full row of memory. The basic sequence for RTSP programming is to set up a Table Pointer, then do a series of TBLWT instructions to load the buffers. Programming is performed by setting the control bits in the NVMCON register. Data can be loaded in any order and the holding registers can be written to multiple times before performing a write operation. Subsequent writes, however, will wipe out any previous writes. **Note:** Writing to a location multiple times, without erasing it, is not recommended. All of the Table Write operations are single-word writes (two instruction cycles), because only the buffers are written. A programming cycle is required for programming each row. # 5.3 Enhanced In-Circuit Serial Programming Enhanced ICSP uses an on-board bootloader, known as the Program Executive (PE), 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. #### 5.4 Control Registers There are two SFRs used to read and write the program Flash memory: NVMCON and NVMKEY. The NVMCON register (Register 5-1) controls the blocks that need to be erased, which memory type is to be programmed and when the programming cycle starts. NVMKEY is a write-only register that is used for write protection. To start a programming or erase sequence, the user must consecutively write 55h and AAh to the NVMKEY register. Refer to **Section 5.5 "Programming Operations"** for further details. #### 5.5 Programming Operations A complete programming sequence is necessary for programming or erasing the internal Flash in RTSP mode. During a programming or erase operation, the processor stalls (waits) until the operation is finished. Setting the WR bit (NVMCON[15]) starts the operation and the WR bit is automatically cleared when the operation is finished. #### REGISTER 5-1: NVMCON: FLASH MEMORY CONTROL REGISTER | HC/R/SO-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-----------|-------|-------|------------------------|-----|-----|-----|-------| | WR | WREN | WRERR | PGMONLY <sup>(4)</sup> | _ | _ | _ | _ | | bit 15 | | | • | | | | bit 8 | | U-0 | R/W-0 |-------|-------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------| | _ | ERASE | NVMOP5 <sup>(1)</sup> | NVMOP4 <sup>(1)</sup> | NVMOP3 <sup>(1)</sup> | NVMOP2 <sup>(1)</sup> | NVMOP1 <sup>(1)</sup> | NVMOP0 <sup>(1)</sup> | | bit 7 | | | | | | | bit 0 | | Legend: | SO = Settable Only bit | HC = Hardware Clearable b | pit | |----------------------|------------------------|----------------------------|------------------| | -n = Value at POR | '1' = Bit is set | R = Readable bit | W = Writable bit | | '0' = Bit is cleared | x = Bit is unknown | U = Unimplemented bit, rea | d as '0' | - bit 15 WR: Write Control bit - 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 = Enables Flash program/erase operations - 0 = Inhibits Flash program/erase operations - bit 13 WRERR: Write Sequence Error Flag bit - 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 **PGMONLY:** Program Only Enable bit<sup>(4)</sup> - bit 11-7 **Unimplemented:** Read as '0' - bit 6 **ERASE**: Erase/Program Enable bit - 1 = Performs the erase operation specified by the NVMOP[5:0] bits on the next WR command - 0 = Performs the program operation specified by the NVMOP[5:0] bits on the next WR command - bit 5-0 **NVMOP[5:0]:** Programming Operation Command Byte bits<sup>(1)</sup> #### Erase Operations (when ERASE bit is '1'): - 1010xx = Erases entire boot block (including code-protected boot block)(2) - 1001xx = Erases entire memory (including boot block, configuration block, general block)<sup>(2)</sup> - 011010 = Erases four rows of Flash memory<sup>(3)</sup> - 011001 = Erases two rows of Flash memory(3) - 011000 = Erases one row of Flash memory<sup>(3)</sup> - 0101xx = Erases entire configuration block (except code protection bits) - 0100xx = Erases entire data EEPROM(4) - 0011xx = Erases entire general memory block programming operations - 0001xx = Writes one row of Flash memory (when ERASE bit is '0')(3) - **Note 1:** All other combinations of NVMOP[5:0] are no operation. - 2: Available in ICSP™ mode only. Refer to the device programming specification. - 3: The address in the Table Pointer decides which rows will be erased. - **4:** This bit is used only while accessing data EEPROM. # 5.5.1 PROGRAMMING ALGORITHM FOR FLASH PROGRAM MEMORY The user can program one row of Flash program memory at a time by erasing the programmable row. The general process is: - Read a row of program memory (32 instructions) and store in data RAM. - Update the program data in RAM with the desired new data. - 3. Erase a row (see Example 5-1): - a) Set the NVMOPx bits (NVMCON[5:0]) to '011000' to configure for row erase. Set the ERASE (NVMCON[6]) and WREN (NVMCON[14]) bits. - Write the starting address of the block to be erased into the TBLPAG and W registers. - c) Write 55h to NVMKEY. - d) Write AAh to NVMKEY. - Set the WR bit (NVMCON[15]). The erase cycle begins and the CPU stalls for the duration of the erase cycle. When the erase is done, the WR bit is cleared automatically. - 4. Write the first 32 instructions from data RAM into the program memory buffers (see Example 5-1). - 5. Write the program block to Flash memory: - Set the NVMOPx bits to '000100' to configure for row programming. Clear the ERASE bit and set the WREN bit. - b) Write 55h to NVMKEY. - c) Write AAh to NVMKEY. - d) Set the WR bit. The programming cycle begins and the CPU stalls for the duration of the write cycle. When the write to Flash memory is done, the WR bit is cleared automatically. For protection against accidental operations, the write initiate sequence for NVMKEY must be used to allow any erase or program operation to proceed. After the programming command has been executed, the user must wait for the programming time until programming is complete. The two instructions following the start of the programming sequence should be NOPs, as displayed in Example 5-5. #### EXAMPLE 5-1: ERASING A PROGRAM MEMORY ROW – ASSEMBLY LANGUAGE CODE ``` ; Set up NVMCON for row erase operation MOV #0x4058, W0 VOM WO, NVMCON ; Initialize NVMCON ; Init pointer to row to be ERASED MOV #tblpage(PROG ADDR), W0 ; Initialize PM Page Boundary SFR MOV WO, TBLPAG ; Initialize in-page EA[15:0] pointer VOM #tbloffset(PROG ADDR), W0 TBLWTL WO, [WO] ; Set base address of erase block DISI #5 ; Block all interrupts for next 5 instructions MOV #0×55, W0 ; Write the 55 key MOV WO, NVMKEY #0xAA, W1 MOV MOV W1, NVMKEY ; Write the AA key NVMCON, #WR BSET ; Start the erase sequence NOP ; Insert two NOPs after the erase NOP ; command is asserted ``` #### EXAMPLE 5-2: ERASING A PROGRAM MEMORY ROW – 'C' LANGUAGE CODE ``` // C example using MPLAB C30 int __attribute__ ((space(auto_psv))) progAddr = 0x1234; // Variable located in Pgm Memory, declared as a // global variable unsigned int offset; //Set up pointer to the first memory location to be written TBLPAG = __builtin_tblpage(&progAddr); // Initialize PM Page Boundary SFR offset = builtin tbloffset(&progAddr); // Initialize lower word of address builtin tblwtl(offset, 0x0000); // Set base address of erase block // with dummy latch write NVMCON = 0x4058; // Initialize NVMCON asm("DISI #5"); // Block all interrupts for next 5 instructions builtin write NVM(); // C30 function to perform unlock // sequence and set WR ``` #### EXAMPLE 5-3: LOADING THE WRITE BUFFERS – ASSEMBLY LANGUAGE CODE ``` ; Set up NVMCON for row programming operations MOV #0x4004, W0 MOV W0, NVMCON ; Initialize NVMCON ; Set up a pointer to the first program memory location to be written ; program memory selected, and writes enabled MOV #0x0000, W0 MOV WO, TBLPAG ; Initialize PM Page Boundary SFR MOV #0x1500, W0 ; An example program memory address ; Perform the TBLWT instructions to write the latches ; 0th program word MOV #LOW WORD 0, W2 MOV #HIGH BYTE 0, W3 TBLWTL W2, [W0] TRIWTH W3. [W0++] ; Write PM low word into program latch TBLWTH W3, [W0++] ; Write PM high byte into program latch ; 1st program word MOV #LOW_WORD_1, W2 MOV #HIGH_BYTE_1, W3 .... w2, [W0] TBLWTH W3, [W0++] ; Write PM low word into program latch ; Write PM high byte into program latch ; 2nd_program_word MOV #LOW_WORD_2, W2 ; MOV #HIGH_BYTE_2, W3 -- "2, [WU] TBLWTH W3, [W0++] ; Write PM low word into program latch ; Write PM high byte into program latch ; 32nd program word MOV #LOW WORD 31, W2 MOV #HIGH BYTE 31, W3 TBLWTL W2, [W0] ; Write PM low word into program latch TBLWTH W3, [W0] ; Write PM high byte into program latch ``` #### **EXAMPLE 5-4:** LOADING THE WRITE BUFFERS – 'C' LANGUAGE CODE ``` // C example using MPLAB C30 #define NUM INSTRUCTION PER ROW 64 int attribute ((space(auto psv))) progAddr = 0x1234 // Variable located in Pgm Memory unsigned int offset; unsigned int i; unsigned int progData[2*NUM INSTRUCTION PER ROW]; // Buffer of data to write //Set up NVMCON for row programming NVMCON = 0x4004; // Initialize NVMCON //Set up pointer to the first memory location to be written offset = builtin tbloffset(&progAddr); // Initialize lower word of address //Perform TBLWT instructions to write necessary number of latches for(i=0; i < 2*NUM INSTRUCTION PER ROW; i++)</pre> // Write to address low word _builtin_tblwtl(offset, progData[i++]); builtin_tblwth(offset, progData[i]); // Write to upper byte offset = offset + 2; // Increment address ``` #### EXAMPLE 5-5: INITIATING A PROGRAMMING SEQUENCE – ASSEMBLY LANGUAGE CODE ``` DISI ; Block all interrupts for next 5 instructions MOV #0x55, W0 W0, NVMKEY ; Write the 55 key MOV MOV #0xAA, W1 W1, NVMKEY ; Write the AA key MOV BSET NVMCON, #WR ; Start the erase sequence NOP ; 2 NOPs required after setting WR NOP BTSC NVMCON, #15 ; Wait for the sequence to be completed $-2 BRA ``` #### EXAMPLE 5-6: INITIATING A PROGRAMMING SEQUENCE - 'C' LANGUAGE CODE #### 6.0 DATA EEPROM MEMORY #### Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on data EEPROM, refer to "Data EEPROM" (www.microchip.com/DS39720) in the "dsPIC33/PIC24F Family Reference Manual". The data EEPROM memory is a Nonvolatile Memory (NVM), separate from the program and volatile data RAM. Data EEPROM memory is based on the same Flash technology as program memory, and is optimized for both long retention and a higher number of erase/write cycles. The data EEPROM is mapped to the top of the user program memory space, with the top address at program memory address, 7FFE00h to 7FFFFFh. The size of the data EEPROM is 256 words in PIC24FXXXXX devices. The data EEPROM is organized as 16-bit wide memory. Each word is directly addressable, and is readable and writable during normal operation over the entire VDD range. Unlike the Flash program memory, normal program execution is not stopped during a data EEPROM program or erase operation. The data EEPROM programming operations are controlled using the three NVM Control registers: - NVMCON: Nonvolatile Memory Control Register - · NVMKEY: Nonvolatile Memory Key Register - · NVMADR: Nonvolatile Memory Address Register #### 6.1 NVMCON Register The NVMCON register (Register 6-1) is also the primary control register for data EEPROM program/erase operations. The upper byte contains the control bits used to start the program or erase cycle and the flag bit to indicate if the operation was successfully performed. The lower byte of NVMCOM configures the type of NVM operation that will be performed. #### 6.2 NVMKEY Register The NVMKEY is a write-only register that is used to prevent accidental writes or erasures of data EEPROM locations. To start any programming or erase sequence, the following instructions must be executed first, in the exact order provided: - 1. Write 55h to NVMKEY. - 2. Write AAh to NVMKEY. After this sequence, a write will be allowed to the NVMCON register for one instruction cycle. In most cases, the user will simply need to set the WR bit in the NVMCON register to start the program or erase cycle. Interrupts should be disabled during the unlock sequence. The MPLAB® C30 C compiler provides a defined library procedure (builtin\_write\_NVM) to perform the unlock sequence. Example 6-1 illustrates how the unlock sequence can be performed with in-line assembly. #### **EXAMPLE 6-1: DATA EEPROM UNLOCK SEQUENCE** ``` //Disable Interrupts For 5 instructions asm volatile ("disi #5"); //Issue Unlock Sequence asm volatile ("mov #0x55, W0 "mov W0, NVMKEY \n" "mov #0xAA, W1 \n" "mov W1, NVMKEY \n"); // Perform Write/Erase operations ("bset NVMCON, #WR \n" asm volatile "nop \n" "nop \n"); ``` #### REGISTER 6-1: NVMCON: NONVOLATILE MEMORY CONTROL REGISTER | HC/R/SO-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-----------|-------|-------|---------|-----|-----|-----|-------| | WR | WREN | WRERR | PGMONLY | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-0 |-------|-------|--------|--------|--------|--------|--------|--------| | _ | ERASE | NVMOP5 | NVMOP4 | NVMOP3 | NVMOP2 | NVMOP1 | NVMOP0 | | bit 7 | | | | | | | bit 0 | | Legend: | HC = Hardware Clearable bit | U = Unimplemented bit, read as '0' | | |-------------------|-----------------------------|------------------------------------|-------| | R = Readable bit | W = Writable bit | S = Settable Only bit | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared x = Bit is un | known | bit 15 WR: Write Control bit (program or erase) 1 = Initiates a data EEPROM erase or write cycle (can be set, but not cleared in software) 0 = Write cycle is complete (cleared automatically by hardware) bit 14 WREN: Write Enable bit (erase or program) 1 = Enables an erase or program operation 0 = No operation allowed (device clears this bit on completion of the write/erase operation) bit 13 WRERR: Flash Error Flag bit 1 = A write operation is prematurely terminated (any MCLR or WDT Reset during programming operation) 0 = The write operation completed successfully bit 12 **PGMONLY:** Program Only Enable bit 1 = Write operation is executed without erasing target address(es) first 0 = Automatic erase-before-write Write operations are preceded automatically by an erase of the target address(es). bit 11-7 **Unimplemented:** Read as '0' bit 6 **ERASE**: Erase Operation Select bit 1 = Performs an erase operation when WR is set 0 = Performs a write operation when WR is set bit 5-0 **NVMOP[5:0]:** Programming Operation Command Byte bits Erase Operations (when ERASE bit is '1'): 011010 = Erases eight words 011001 = Erases four words 011000 = Erases one word 0100xx = Erases entire data EEPROM Programming Operations (when ERASE bit is '0'): 0001xx = Writes one word ## 6.3 NVM Address Register As with Flash program memory, the NVM Address registers, NVMADRU and NVMADR, form the 24-bit Effective Address (EA) of the selected row or word for data EEPROM operations. The NVMADRU register is used to hold the upper 8 bits of the EA, while the NVMADR register is used to hold the lower 16 bits of the EA. These registers are not mapped into the Special Function Register (SFR) space; instead, they directly capture the EA[23:0] of the last Table Write instruction that has been executed and select the data EEPROM row to erase. Figure 6-1 depicts the program memory EA that is formed for programming and erase operations. Like program memory operations, the Least Significant bit (LSb) of NVMADR is restricted to even addresses. This is because any given address in the data EEPROM space consists of only the lower word of the program memory width; the upper word, including the uppermost "phantom byte", are unavailable. This means that the LSb of a data EEPROM address will always be '0'. Similarly, the Most Significant bit (MSb) of NVMADRU is always '0', since all addresses lie in the user program space. FIGURE 6-1: DATA EEPROM ADDRESSING WITH TBLPAG AND NVM ADDRESS REGISTERS ## 6.4 Data EEPROM Operations The EEPROM block is accessed using Table Read and Write operations, similar to those used for program memory. The TBLWTH and TBLRDH instructions are not required for data EEPROM operations since the memory is only 16 bits wide (data on the lower address are valid only). The following programming operations can be performed on the data EEPROM: - · Erase one, four or eight words - · Bulk erase the entire data EEPROM - · Write one word - · Read one word - **Note 1:** Unexpected results will be obtained if the user attempts to read the EEPROM while a programming or erase operation is underway. - 2: The XC16 C compiler includes library procedures to automatically perform the Table Read and Table Write operations, manage the Table Pointer and write buffers, and unlock and initiate memory write sequences. This eliminates the need to create assembler macros or time critical routines in C for each application. The library procedures are used in the code examples detailed in the following sections. General descriptions of each process are provided for users who are not using the XC16 compiler libraries. ### 6.4.1 ERASE DATA EEPROM The data EEPROM can be fully erased, or can be partially erased, at three different sizes: one word, four words or eight words. The bits, NVMOP[1:0] (NVMCON[1:0]), decide the number of words to be erased. To erase partially from the data EEPROM, the following sequence must be followed: - Configure NVMCON to erase the required number of words: one, four or eight. - Load TBLPAG and WREG with the EEPROM address to be erased. - Clear the NVMIF status bit and enable the NVM interrupt (optional). - 4. Write the key sequence to NVMKEY. - 5. Set the WR bit to begin the erase cycle. - Either poll the WR bit or wait for the NVM interrupt (NVMIF is set). A typical erase sequence is provided in Example 6-2. This example shows how to do a one-word erase. Similarly, a four-word erase and an eight-word erase can be done. This example uses C library procedures to manage the Table Pointer (builtin\_tblpage and builtin\_tbloffset) and the Erase Page Pointer (builtin\_tblwtl). The memory unlock sequence (builtin\_write\_NVM) also sets the WR bit to initiate the operation and returns control when complete. ### **EXAMPLE 6-2:** SINGLE-WORD ERASE ``` _attribute__ ((space(eedata))) eeData = 0x1234; /*----- The variable eeData must be a Global variable declared outside of any method the code following this comment can be written inside the method that will execute the erase */ unsigned int offset; // Set up NVMCON to erase one word of data EEPROM NVMCON = 0 \times 4058: // Set up a pointer to the EEPROM location to be erased // Initizlize lower word of address offset = builtin tbloffset(&eeData); __builtin_tblwtl(offset, 0); // Write EEPROM data to write latch asm volatile ("disi #5"); // Disable Interrupts For 5 Instructions builtin write NVM(); // Issue Unlock Sequence & Start Write Cycle // Optional: Poll WR bit to wait for while (NVMCONbits.WR==1); // write sequence to complete ``` #### 6.4.1.1 Data EEPROM Bulk Erase To erase the entire data EEPROM (bulk erase), the address registers do not need to be configured because this operation affects the entire data EEPROM. The following sequence helps in performing a bulk erase: - 1. Configure NVMCON to Bulk Erase mode. - Clear the NVMIF status bit and enable the NVM interrupt (optional). - 3. Write the key sequence to NVMKEY. - 4. Set the WR bit to begin the erase cycle. - 5. Either poll the WR bit or wait for the NVM interrupt (NVMIF is set). A typical bulk erase sequence is provided in Example 6-3. #### 6.4.2 SINGLE-WORD WRITE To write a single word in the data EEPROM, the following sequence must be followed: - Erase one data EEPROM word (as mentioned in the previous section) if the PGMONLY bit (NVMCON[12]) is set to '1'. - 2. Write the data word into the data EEPROM latch. - 3. Program the data word into the EEPROM: - Configure the NVMCON register to program one EEPROM word (NVMCON[5:0] = 0001xx). - Clear the NVMIF status bit and enable the NVM interrupt (optional). - Write the key sequence to NVMKEY. - Set the WR bit to begin the erase cycle. - Either poll the WR bit or wait for the NVM interrupt (NVMIF is set). - To get cleared, wait until NVMIF is set. A typical single-word write sequence is provided in Example 6-4. ### **EXAMPLE 6-3: DATA EEPROM BULK ERASE** ``` // Set up NVMCON to bulk erase the data EEPROM NVMCON = 0x4050; // Disable Interrupts For 5 Instructions asm volatile ("disi #5"); // Issue Unlock Sequence and Start Erase Cycle __builtin_write_NVM(); ``` ### EXAMPLE 6-4: SINGLE-WORD WRITE TO DATA EEPROM ``` int attribute ((space(eedata))) eeData = 0x1234; int newData; // New data to write to EEPROM The variable eeData must be a Global variable declared outside of any method the code following this comment can be written inside the method that will execute the write unsigned int offset; // Set up NVMCON to erase one word of data EEPROM NVMCON = 0x4004; // Set up a pointer to the EEPROM location to be erased // Initizlize lower word of address offset = __builtin_tbloffset(&eeData); builtin tblwtl(offset, newData); // Write EEPROM data to write latch asm volatile ("disi #5"); // Disable Interrupts For 5 Instructions builtin write NVM(); // Issue Unlock Sequence & Start Write Cycle while (NVMCONbits.WR==1); // Optional: Poll WR bit to wait for // write sequence to complete ``` ### 6.4.3 READING THE DATA EEPROM To read a word from data EEPROM, the Table Read instruction is used. Since the EEPROM array is only 16 bits wide, only the <code>TBLRDL</code> instruction is needed. The read operation is performed by loading TBLPAG and WREG with the address of the EEPROM location, followed by a <code>TBLRDL</code> instruction. A typical read sequence, using the Table Pointer management (builtin\_tblpage and builtin\_tbloffset) and Table Read (builtin\_tblrdl) procedures from the C30 compiler library, is provided in Example 6-5. Program Space Visibility (PSV) can also be used to read locations in the data EEPROM. ### EXAMPLE 6-5: READING THE DATA EEPROM USING THE TBLRD COMMAND ## 7.0 RESETS Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on Resets, refer to "Reset with Programmable Brown-out Reset" (www.microchip.com/DS39728) in the "dsPIC33/PIC24F Family Reference Manual". The Reset module combines all Reset sources and controls the device Master Reset Signal, SYSRST. The following is a list of device Reset sources: POR: Power-on Reset MCLR: Pin Reset SWR: RESET Instruction WDTR: Watchdog Timer Reset BOR: Brown-out Reset LPBOR: Low-Power BOR TRAPR: Trap Conflict Reset IOPUWR: Illegal Opcode Reset UWR: Uninitialized W Register Reset A simplified block diagram of the Reset module is shown in Figure 7-1. Any active source of Reset will make the SYSRST signal active. Many registers associated with the CPU and peripherals are forced to a known Reset state. Most registers are unaffected by a Reset; their status is unknown on Power-on Reset (POR) and unchanged by all other Resets. **Note:** Refer to the specific peripheral or **Section 3.0 "CPU"** of this data sheet for register Reset states. All types of device Reset will set a corresponding status bit in the RCON register to indicate the type of Reset (see Register 7-1). A Power-on Reset will clear all bits except for the BOR and POR bits (RCON[1:0]) which are set. The user may 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 will not cause a device Reset to occur. The RCON register also has other bits associated with the Watchdog Timer (WDT) and device power-saving states. The function of these bits is discussed in other sections of this manual. **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 will be meaningful. FIGURE 7-1: RESET SYSTEM BLOCK DIAGRAM ## REGISTER 7-1: RCON: RESET CONTROL REGISTER (1) | HS/R/W-0 | HS/R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | |----------|----------|--------|----------------------|-----|-----|-------|-------| | TRAPR | IOPUWR | SBOREN | RETEN <sup>(3)</sup> | _ | _ | СМ | PMSLP | | bit 15 | | | | | | | bit 8 | | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-1 | HS/R/W-1 | |----------|----------|-----------------------|----------|----------|----------|----------|----------| | EXTR | SWR | SWDTEN <sup>(2)</sup> | WDTO | SLEEP | IDLE | BOR | POR | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 TRAPR: Trap Reset Flag bit 1 = A Trap Conflict Reset has occurred 0 = A Trap Conflict Reset has not occurred bit 14 IOPUWR: Illegal Opcode or Uninitialized W Access Reset Flag bit 1 = An illegal opcode detection, an illegal address mode or Uninitialized W register used as an Address Pointer caused a Reset 0 = An illegal opcode or Uninitialized W Reset has not occurred bit 13 SBOREN: Software Enable/Disable of BOR bit 1 = BOR is turned on in software 0 = BOR is turned off in software bit 12 **RETEN:** Retention Sleep Mode bit<sup>(3)</sup> 1 = Regulated voltage supply provided by the Retention Regulator (RETREG) during Sleep 0 = Regulated voltage supply provided by the main Voltage Regulator (VREG) during Sleep bit 11-10 Unimplemented: Read as '0' bit 9 CM: Configuration Word Mismatch Reset Flag bit 1 = A Configuration Word Mismatch Reset has occurred 0 = A Configuration Word Mismatch Reset has not occurred bit 8 PMSLP: Program Memory Power During Sleep bit 1 = Program memory bias voltage remains powered during Sleep 0 = Program memory bias voltage is powered down during Sleep and the voltage regulator enters Standby mode bit 7 **EXTR:** External Reset (MCLR) Pin bit 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 1 = A RESET instruction has been executed 0 = A RESET instruction has not been executed bit 5 **SWDTEN:** Software Enable/Disable of WDT bit<sup>(2)</sup> 1 = WDT is enabled 0 = WDT is disabled **Note 1:** All of the Reset status bits may be set or cleared in software. Setting one of these bits in software does not cause a device Reset. - 2: If the FWDTEN[1:0] Configuration bits are '11' (unprogrammed), the WDT is always enabled regardless of the SWDTEN bit setting. - 3: This is implemented on PIC24FV16KMXXX parts only; not used on PIC24F16KMXXX devices. ## REGISTER 7-1: RCON: RESET CONTROL REGISTER<sup>(1)</sup> (CONTINUED) bit 4 WDTO: Watchdog Timer Time-out Flag bit 1 = WDT time-out has occurred 0 = WDT time-out has not occurred bit 3 SLEEP: Wake-up from Sleep Flag bit 1 = Device has been in Sleep mode 0 = Device has not been in Sleep mode bit 2 IDLE: Wake-up from Idle Flag bit 1 = Device has been in Idle mode 0 = Device has not been in Idle mode bit 1 BOR: Brown-out Reset Flag bit 1 = A Brown-out Reset has occurred (the BOR is also set after a POR) 0 = A Brown-out Reset has not occurred bit 0 **POR:** Power-on Reset Flag bit 1 = A Power-on Reset has occurred 0 = A Power-on Reset has not occurred - **Note 1:** All of the Reset status bits may be set or cleared in software. Setting one of these bits in software does not cause a device Reset. - 2: If the FWDTEN[1:0] Configuration bits are '11' (unprogrammed), the WDT is always enabled regardless of the SWDTEN bit setting. - 3: This is implemented on PIC24FV16KMXXX parts only; not used on PIC24F16KMXXX devices. TABLE 7-1: RESET FLAG BIT OPERATION | Flag Bit | Setting Event | Clearing Event | |-------------------|---------------------------------------------------|-------------------------| | TRAPR (RCON[15]) | Trap Conflict Event | POR | | IOPUWR (RCON[14]) | Illegal Opcode or Uninitialized W Register Access | POR | | CM (RCON[9]) | Configuration Mismatch Reset | POR | | EXTR (RCON[7]) | MCLR Reset | POR | | SWR (RCON[6]) | RESET Instruction | POR | | WDTO (RCON[4]) | WDT Time-out | PWRSAV Instruction, POR | | SLEEP (RCON[3]) | PWRSAV #SLEEP Instruction | POR | | IDLE (RCON[2]) | PWRSAV #IDLE Instruction | POR | | BOR (RCON[1]) | POR, BOR | _ | | POR (RCON[0]) | POR | _ | **Note:** All Reset flag bits may be set or cleared by the user software. ### 7.1 Clock Source Selection at Reset If clock switching is enabled, the system clock source at device Reset is chosen, as shown in Table 7-2. If clock switching is disabled, the system clock source is always selected according to the Oscillator Configuration bits. For more information, see **Section 9.0 "Oscillator Configuration"**. TABLE 7-2: OSCILLATOR SELECTION vs. TYPE OF RESET (CLOCK SWITCHING ENABLED) | Reset Type | Clock Source Determinant | |------------|-------------------------------| | POR | FNOSC[2:0] Configuration bits | | BOR | (FOSCSEL[2:0]) | | MCLR | COSC[2:0] Control bits | | WDTO | (OSCCON[14:12]) | | SWR | | ### 7.2 Device Reset Times The Reset times for various types of device Reset are summarized in Table 7-3. Note that the System Reset signal, SYSRST, is released after the POR and PWRT delay times expire. The time at which the device actually begins to execute code will also depend on the system oscillator delays, which include the Oscillator Start-up Timer (OST) and the PLL lock time. The OST and PLL lock times occur in parallel with the applicable SYSRST delay times. The FSCM delay determines the time at which the FSCM begins to monitor the system clock source after the SYSRST signal is released. TABLE 7-3: RESET DELAY TIMES FOR VARIOUS DEVICE RESETS | Reset Type | Clock Source | SYSRST Delay | System Clock<br>Delay | Notes | |--------------------|--------------|--------------|-----------------------|------------| | POR <sup>(6)</sup> | EC | TPOR + TPWRT | _ | 1, 2 | | | FRC, FRCDIV | TPOR + TPWRT | TFRC | 1, 2, 3 | | | LPRC | TPOR + TPWRT | TLPRC | 1, 2, 3 | | | ECPLL | TPOR + TPWRT | TLOCK | 1, 2, 4 | | | FRCPLL | TPOR + TPWRT | TFRC + TLOCK | 1, 2, 3, 4 | | | XT, HS, SOSC | TPOR+ TPWRT | Tost | 1, 2, 5 | | | XTPLL, HSPLL | TPOR + TPWRT | Tost + Tlock | 1, 2, 4, 5 | | BOR | EC | TPWRT | _ | 2 | | | FRC, FRCDIV | TPWRT | TFRC | 2, 3 | | | LPRC | TPWRT | TLPRC | 2, 3 | | | ECPLL | TPWRT | TLOCK | 2, 4 | | | FRCPLL | TPWRT | TFRC + TLOCK | 2, 3, 4 | | | XT, HS, SOSC | TPWRT | Tost | 2, 5 | | | XTPLL, HSPLL | TPWRT | TFRC + TLOCK | 2, 3, 4 | | All Others | Any Clock | _ | _ | None | - **Note 1:** TPOR = Power-on Reset delay. - 2: TPWRT = 64 ms nominal if the Power-up Timer is enabled; otherwise, it is zero. - 3: TFRC and TLPRC = RC Oscillator start-up times. - 4: TLOCK = PLL Lock time. - **5:** Tost = Oscillator Start-up Timer (OST). A 10-bit counter waits 1024 oscillator periods before releasing the oscillator clock to the system. - **6:** If Two-Speed Start-up is enabled, regardless of the Primary Oscillator selected, the device starts with FRC, and in such cases, FRC start-up time is valid. Note: For detailed operating frequency and timing specifications, see Section 27.0 "Electrical Characteristics". # 7.2.1 POR AND LONG OSCILLATOR START-UP TIMES The oscillator start-up circuitry and its associated delay timers are not linked to the device Reset delays that occur at power-up. Some crystal circuits (especially low-frequency crystals) will have a relatively long start-up time. Therefore, one or more of the following conditions is possible after SYSRST is released: - · The oscillator circuit has not begun to oscillate. - The Oscillator Start-up Timer (OST) has not expired (if a crystal oscillator is used). - The PLL has not achieved a lock (if PLL is used). The device will not begin to execute code until a valid clock source has been released to the system. Therefore, the oscillator and PLL start-up delays must be considered when the Reset delay time must be known. # 7.2.2 FAIL-SAFE CLOCK MONITOR (FSCM) AND DEVICE RESETS If the FSCM is enabled, it will begin to monitor the system clock source when SYSRST is released. If a valid clock source is not available at this time, the device will automatically switch to the FRC Oscillator and the user can switch to the desired crystal oscillator in the Trap Service Routine (TSR). # 7.3 Special Function Register Reset States Most of the Special Function Registers (SFRs) associated with the PIC24F CPU and peripherals are reset to a particular value at a device Reset. The SFRs are grouped by their peripheral or CPU function and their Reset values are specified in each section of this manual. The Reset value for each SFR does not depend on the type of Reset, with the exception of four registers. The Reset value for the Reset Control register, RCON, will depend on the type of device Reset. The Reset value for the Oscillator Control register, OSCCON, will depend on the type of Reset and the programmed values of the FNOSCx bits in the Flash Configuration Word (FOSCSEL[2:0]); see Table 7-2. The RCFGCAL and NVMCON registers are only affected by a POR. ### 7.4 Brown-out Reset (BOR) The PIC24FXXXXX family devices implement a BOR circuit, which provides the user several configuration and power-saving options. The BOR is controlled by the BORV[1:0] and BOREN[1:0] Configuration bits (FPOR[6:5,1:0]). There are a total of four BOR configurations, which are provided in Table 7-3. The BOR threshold is set by the BORV[1:0] bits. If BOR is enabled (any values of BOREN[1:0], except '00'), any drop of VDD below the set threshold point will reset the device. The chip will remain in BOR until VDD rises above the threshold. If the Power-up Timer is enabled, it will be invoked after VDD rises above the threshold. Then, it will keep the chip in Reset for an additional time delay, TPWRT, if VDD drops below the threshold while the Power-up Timer is running. The chip goes back into a BOR and the Power-up Timer will be initialized. Once VDD rises above the threshold, the Power-up Timer will execute the additional time delay. BOR and the Power-up Timer (PWRT) are independently configured. Enabling the Brown-out Reset does not automatically enable the PWRT. ## 7.4.1 LOW-POWER BOR (LPBOR) The Low-Power BOR is an alternate setting for the BOR, designed to consume minimal power. In LPBOR mode, BORV[1:0] (FPOR[6:5]) = 00. The BOR trip point is approximately 2.0V. Due to the low current consumption, the accuracy of the LPBOR mode can vary. Unlike the other BOR modes, LPBOR mode will not cause a device Reset when VDD drops below the trip point. Instead, it re-arms the POR circuit to ensure that the device will reset properly in the event that VDD continues to drop below the minimum operating voltage. The device will continue to execute code when VDD is below the level of the LPBOR trip point. A device that requires falling edge BOR protection to prevent code from improperly executing should use one of the other BOR voltage settings. ### 7.4.2 SOFTWARE ENABLED BOR When BOREN[1:0] = 01, the BOR can be enabled or disabled by the user in software. This is done with the control bit, SBOREN (RCON[13]). Setting SBOREN enables the BOR to function as previously described. Clearing the SBOREN disables the BOR entirely. The SBOREN bit operates only in this mode; otherwise, it is read as '0'. Placing BOR under software control gives the user the additional flexibility of tailoring the application to its environment without having to reprogram the device to change the BOR configuration. It also allows the user to tailor the incremental current that the BOR consumes. While the BOR current is typically very small, it may have some impact in low-power applications. Note: Even when the BOR is under software control, the Brown-out Reset voltage level is still set by the BORV[1:0] Configuration bits; it can not be changed in software. ### 7.4.3 DETECTING BOR When BOR is enabled, the BOR bit (RCON[1]) is always reset to '1' on any BOR or POR event. This makes it difficult to determine if a BOR event has occurred just by reading the state of BOR alone. A more reliable method is to simultaneously check the state of both POR and BOR. This assumes that the POR and BOR bits are reset to '0' in the software immediately after any POR event. If the BOR bit is '1' while POR is '0', it can be reliably assumed that a BOR event has occurred. ### 7.4.4 DISABLING BOR IN SLEEP MODE When BOREN[1:0] = 10, BOR remains under hardware control and operates as previously described. However, whenever the device enters Sleep mode, BOR is automatically disabled. When the device returns to any other operating mode, BOR is automatically re-enabled. This mode allows for applications to recover from brown-out situations, while actively executing code, when the device requires BOR protection the most. At the same time, it saves additional power in Sleep mode by eliminating the small incremental BOR current. Note: BOR levels differ depending on device type; PIC24FV16KM204 devices are at different levels than those of PIC24F16KM204 devices. See Section 27.0 "Electrical Characteristics" for BOR voltage levels. ## 8.0 INTERRUPT CONTROLLER Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Interrupt Controller, refer to "Interrupts" (www.microchip.com/DS70000600) in the "dsPIC33/PIC24F Family Reference Manual". The PIC24F interrupt controller reduces the numerous peripheral interrupt request signals to a single interrupt request signal to the CPU. It has the following features: - Up to Eight Processor Exceptions and Software Traps - Seven User-Selectable Priority Levels - · Interrupt Vector Table (IVT) with up to 118 Vectors - Unique Vector for Each Interrupt or Exception Source - Fixed Priority within a Specified User Priority Level - Alternate Interrupt Vector Table (AIVT) for Debug Support - · Fixed Interrupt Entry and Return Latencies ## 8.1 Interrupt Vector Table (IVT) The IVT is shown in Figure 8-1. The IVT resides in the program memory, starting at location, 000004h. The IVT contains 126 vectors, consisting of eight non-maskable trap vectors, plus up to 118 sources of interrupt. 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). Interrupt vectors are prioritized in terms of their natural priority; this is linked to their position in the vector table. All other things being equal, lower addresses have a higher natural priority. For example, the interrupt associated with Vector 0 will take priority over interrupts at any other vector address. PIC24FV16KM204 family devices implement non-maskable traps and unique interrupts; these are summarized in Table 8-1. # 8.1.1 ALTERNATE INTERRUPT VECTOR TABLE (AIVT) The Alternate Interrupt Vector Table (AIVT) is located after the IVT, as shown in Figure 8-1. Access to the AIVT is provided by the ALTIVT control bit (INTCON2[15]). If the ALTIVT bit is set, all interrupt and exception processes will use the alternate vectors instead of the default vectors. The alternate vectors are organized in the same manner as the default vectors. The AIVT supports emulation and debugging efforts 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. If the AIVT is not needed, the AIVT should be programmed with the same addresses used in the IVT. ## 8.2 Reset Sequence A device Reset is not a true exception, because the interrupt controller is not involved in the Reset process. The PIC24F devices clear their registers in response to a Reset, which forces the Program Counter (PC) to zero. The microcontroller then begins program execution at location, 000000h. The user programs a GOTO instruction at the Reset address, which redirects the program execution to the appropriate start-up routine. Note: Any unimplemented or unused vector locations in the IVT and AIVT should be programmed with the address of a default interrupt handler routine that contains a RESET instruction. TABLE 8-1: TRAP VECTOR DETAILS | Vector Number | IVT Address | AIVT Address | Trap Source | |---------------|-------------|--------------|--------------------| | 0 | 000004h | 000104h | Reserved | | 1 | 000006h | 000106h | Oscillator Failure | | 2 | 000008h | 000108h | Address Error | | 3 | 00000Ah | 00010Ah | Stack Error | | 4 | 00000Ch | 00010Ch | Math Error | | 5 | 00000Eh | 00010Eh | Reserved | | 6 | 000010h | 000110h | Reserved | | 7 | 000012h | 000112h | Reserved | TABLE 8-2: IMPLEMENTED INTERRUPT VECTORS | Into word Course | MPLAB® XC16 ISR | Vector | IRQ | IVT | AIVT | Inte | rrupt Bit Lo | cations | |------------------------------------------|------------------|--------|-----|---------|---------|----------|--------------|--------------| | Interrupt Source | Name | # | # | Address | Address | Flag | Enable | Priority | | INT0 – External Interrupt 0 | INT0Interrupt | 8 | 0 | 000014h | 000114h | IFS0[0] | IEC0[0] | IPC0[2:0] | | MCCP1 – Capture/Compare 1 | CCP1Interrupt | 9 | 1 | 000016h | 000116h | IFS0[1] | IEC0[1] | IPC0[6:4] | | MCCP2 – Capture/Compare 2 | CCP2Interrupt | 10 | 2 | 000018h | 000118h | IFS0[2] | IEC0[2] | IPC0[10:8] | | TMR1 – Timer1 | T1Interrupt | 11 | 3 | 00001Ah | 00011Ah | IFS0[3] | IEC0[3] | IPC0[14:12] | | MCCP3 – Capture/Compare 3 | CCP3Interrupt | 13 | 5 | 00001Eh | 00011Eh | IFS0[5] | IEC0[5] | IPC1[6:4] | | SCCP4 - Capture/Compare 4 | CCP4Interrupt | 14 | 6 | 000020h | 000120h | IFS0[6] | IEC0[6] | IPC1[10:8] | | MCCP1 – Time Base 1 | CCT1Interrupt | 15 | 7 | 000022h | 000122h | IFS0[7] | IEC0[7] | IPC1[14:12] | | MCCP2 – Time Base 2 | CCT2Interrupt | 16 | 8 | 000024h | 000124h | IFS0[8] | IEC0[8] | IPC2[2:0] | | UART1RX – UART1 Receiver | U1RXInterrupt | 19 | 11 | 00002Ah | 00012Ah | IFS0[11] | IEC0[11] | IPC2[14:12] | | UART1TX – UART1 Transmitter | U1TXInterrupt | 20 | 12 | 00002Ch | 00012Ch | IFS0[12] | IEC0[12] | IPC3[2:0] | | ADC1 – ADC1 Convert Done | ADC1Interrupt | 21 | 13 | 00002Eh | 00012Eh | IFS0[13] | IEC0[13] | IPC3[6:4] | | NVM – NVM Write Complete | NVMInterrupt | 23 | 15 | 000032h | 000132h | IFS0[15] | IEC0[15] | IPC3[14:12] | | MSSP1 – I <sup>2</sup> C/SPI Interrupt 1 | MSSP1Interrupt | 24 | 16 | 000034h | 000134h | IFS1[0] | IEC1[0] | IPC4[2:0] | | MSSP1 – Bus Collision Interrupt 1 | MSSP1BCInterrupt | 25 | 17 | 000036h | 000136h | IFS1[1] | IEC1[1] | IPC4[6:4] | | Comparator Interrupt | CompInterrupt | 26 | 18 | 000038h | 000138h | IFS1[2] | IEC1[2] | IPC4[10:8] | | ICN – Input Change Notification | CNInterrupt | 27 | 19 | 00003Ah | 00013Ah | IFS1[3] | IEC1[3] | IPC4[14:12] | | INT1 – External Interrupt 1 | INT1Interrupt | 28 | 20 | 00003Ch | 00013Ch | IFS1[4] | IEC1[4] | IPC5[2:0] | | SCCP5 - Capture/Compare 5 | CCP5Interrupt | 30 | 22 | 000040h | 000140h | IFS1[6] | IEC1[6] | IPC5[10:8] | | MCCP3 – Time Base 3 | CCT3Interrupt | 35 | 27 | 00004Ah | 00014Ah | IFS1[11] | IEC1[11] | IPC6[14:12] | | SCCP4 – Time Base 4 | CCT4Interrupt | 36 | 28 | 00004Ch | 00014Ch | IFS1[12] | IEC1[12] | IPC7[2:0] | | INT2 – External Interrupt 2 | INT2Interrupt | 37 | 29 | 00004Eh | 00014Eh | IFS1[13] | IEC1[13] | IPC7[6:4] | | UART2RX – UART2 Receiver | U2RXInterrupt | 38 | 30 | 000050h | 000150h | IFS1[14] | IEC1[14] | IPC7[10:8] | | UART2TX – UART2 Transmitter | U2TXInterrupt | 39 | 31 | 000052h | 000152h | IFS1[15] | IEC1[15] | IPC7[14:12] | | SCCP5 – Time Base 5 | CCT5Interrupt | 49 | 41 | 000066h | 000166h | IFS2[9] | IEC2[9] | IPC10[6:4] | | MSSP2 – I <sup>2</sup> C/SPI Interrupt 2 | MSSP2Interrupt | 57 | 49 | 000076h | 000176h | IFS3[1] | IEC3[1] | IPC12[6:4] | | MSSP2 – Bus Collision Interrupt 2 | MSSP2BCInterrupt | 58 | 50 | 000078h | 000178h | IFS3[2] | IEC3[2] | IPC12[10:8] | | RTCC – Real-Time Clock/Calendar | RTCCInterrupt | 70 | 62 | 000090h | 000190h | IFS3[14] | IEC3[14] | IPC15[10:8] | | U1Err – UART1 Error | U1ErrInterrupt | 73 | 65 | 000096h | 000196h | IFS4[1] | IEC4[1] | IPC16[6:4] | | U2Err – UART2 Error | U2ErrInterrupt | 74 | 66 | 000098h | 000198h | IFS4[2] | IEC4[2] | IPC16[10:8] | | HLVD – High/Low-Voltage Detect | HLVDInterrupt | 80 | 72 | 0000A4h | 0001A4h | IFS4[8] | IEC4[8] | IPC18[2:0] | | СТМИ | CTMUInterrupt | 85 | 77 | 0000AEh | 0001AEh | IFS4[13] | IEC4[13] | IPC19[6:4] | | DAC1 – Buffer Update 1 | DAC1Interrupt | 86 | 78 | 0000B0h | 0001B0h | IFS4[14] | IEC4[14] | IPC19[10:8] | | DAC2 – Buffer Update 2 | DAC2Interrupt | 87 | 79 | 0000B2h | 0001B2h | IFS4[15] | IEC4[15] | IPC19[14:12] | | ULPWU – Ultra Low-Power Wake-up | ULPWUInterrupt | 88 | 80 | 0000B4h | 0001B4h | IFS5[0] | IEC5[0] | IPC20[2:0] | | CLC1 | CLC1Interrupt | 104 | 96 | 0000D4h | 0001D4h | IFS6[0] | IEC6[0] | IPC24[2:0] | | CLC2 | CLC2Interrupt | 105 | 97 | 0000D6h | 0001D6h | IFS6[1] | IEC6[1] | IPC24[6:4] | # 8.3 Interrupt Control and Status Registers The PIC24FV16KM204 family of devices implements a total of 33 registers for the interrupt controller: - INTCON1 - INTCON2 - · IFS0 through IFS6 - · IEC0 through IEC6 - IPC0 through IPC7, IPC10, IPC12, IPC15, IPC16, IPC18 through IPC20 and IPC24 - INTTREG Global Interrupt Enable (GIE) control functions are controlled from INTCON1 and INTCON2. INTCON1 contains the Interrupt Nesting Disable (NSTDIS) bit, as well as the control and status flags for the processor trap sources. The INTCON2 register controls the external interrupt request signal behavior and the use of the AIVT. 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. 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. 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 eight priority levels The INTTREG register contains the associated interrupt vector number and the new CPU Interrupt Priority Level, which are latched into the Vector Number (VECNUM[6:0]) and the Interrupt Level (ILR[3:0]) bit 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. For example, the INT0 (External Interrupt 0) is depicted as having a vector number and a natural order priority of 0. The INT0IF status bit is found in IFS0[0], the INT0IE enable bit in IEC0[0] and the INT0IP[2:0] priority bits are in the first position of IPC0 (IPC0[2:0]). Although they are not specifically part of the interrupt control hardware, two of the CPU Control registers contain bits that control interrupt functionality. The ALU STATUS Register (SR) contains the IPL[2:0] bits (SR[7:5]). These indicate the current CPU Interrupt Priority Level. The user may 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 Interrupt Priority Level. IPL3 is a read-only bit so that the trap events cannot be masked by the user's software. All Interrupt registers are described in Register 8-3 through Register 8-35, in the following sections. ### **REGISTER 8-1: SR: ALU STATUS REGISTER** | U-0 HSC/R-0 | |--------|-----|-----|-----|-----|-----|-----|-------------------| | _ | _ | _ | _ | _ | _ | _ | DC <sup>(1)</sup> | | bit 15 | | | | | | | bit 8 | | HSC/R/W-0 | HSC/R/W-0 | HSC/R/W-0 | HSC/R-0 | HSC/R/W-0 | HSC/R/W-0 | HSC/R/W-0 | HSC/R/W-0 | |-----------------------|-----------------------|-----------------------|-------------------|------------------|-------------------|------------------|------------------| | IPL2 <sup>(2,3)</sup> | IPL1 <sup>(2,3)</sup> | IPL0 <sup>(2,3)</sup> | RA <sup>(1)</sup> | N <sup>(1)</sup> | OV <sup>(1)</sup> | Z <sup>(1)</sup> | C <sup>(1)</sup> | | bit 7 | | | | | | | bit 0 | | Legend: | HSC = Hardware Settable | HSC = Hardware Settable/Clearable bit | | | | | |-------------------|-------------------------|-----------------------------------------|------------------------------------|--|--|--| | R = Readable bit | W = Writable bit | U = Unimplemented bit | U = Unimplemented bit, read as '0' | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared x = Bit is unknown | | | | | bit 15-9 Unimplemented: Read as '0' bit 7-5 IPL[2:0]: CPU Interrupt Priority Level Status bits<sup>(2,3)</sup> 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) Note 1: See Register 3-1 for the description of these bits, which are not dedicated to interrupt control functions. 2: The IPL[2:0] bits are concatenated with the IPL3 bit (CORCON[3]) to form the CPU Interrupt Priority Level. The value in parentheses indicates the Interrupt Priority Level if IPL3 = 1. 3: The IPLx Status bits are read-only when NSTDIS (INTCON1[15]) = 1. Note: Bit 8 and bits 4 through 0 are described in Section 3.0 "CPU". ### REGISTER 8-2: CORCON: CPU CONTROL REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | HSC/R/C-0 | R/W-0 | U-0 | U-0 | |-------|-----|-----|-----|---------------------|--------------------|-----|-------| | _ | _ | _ | _ | IPL3 <sup>(2)</sup> | PSV <sup>(1)</sup> | _ | _ | | bit 7 | | | | | | | bit 0 | | Legend: C = Clearable bit | | HSC = Hardware Settable/Clearable bit | |---------------------------|------------------|-------------------------------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared $x = Bit$ is unknown | bit 15-4 **Unimplemented:** Read as '0' bit 3 IPL3: CPU Interrupt Priority Level Status bit<sup>(2)</sup> 1 = CPU Interrupt Priority Level is greater than 70 = CPU Interrupt Priority Level is 7 or less bit 1-0 **Unimplemented:** Read as '0' **Note 1:** See Register 3-2 for the description of this bit, which is not dedicated to interrupt control functions. 2: The IPL3 bit is concatenated with the IPL[2:0] bits (SR[7:5]) to form the CPU Interrupt Priority Level. Note: Bit 2 is described in Section 3.0 "CPU". ### REGISTER 8-3: INTCON1: INTERRUPT CONTROL REGISTER 1 | R/W-0 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | NSTDIS | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | U-0 | |-------|-----|-----|----------|----------|----------|----------|-------| | _ | _ | _ | MATHERR | ADDRERR | STKERR | OSCFAIL | _ | | bit 7 | | | | | | | bit 0 | | Legend: | HS = Hardware Settable bit | | | |-------------------|----------------------------|-----------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read | d as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15 NSTDIS: Interrupt Nesting Disable bit 1 = Interrupt nesting is disabled0 = Interrupt nesting is enabled bit 14-5 **Unimplemented:** Read as '0' bit 4 MATHERR: Arithmetic Error Trap Status bit 1 = Overflow trap has occurred0 = Overflow trap has not occurred bit 3 ADDRERR: Address Error Trap Status bit 1 = Address error trap has occurred 0 = Address error trap has not occurred bit 2 STKERR: Stack Error Trap Status bit bit 0 1 = Stack error trap has occurred0 = Stack error trap has not occurred bit 1 OSCFAIL: Oscillator Failure Trap Status bit 1 = Oscillator failure trap has occurred0 = Oscillator failure trap has not occurred Unimplemented: Read as '0' ### REGISTER 8-4: INTCON2: INTERRUPT CONTROL REGISTER 2 | R/W-0 | HSC/R-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|---------|-----|-----|-----|-----|-----|-------| | ALTIVT | DISI | _ | _ | _ | _ | _ | _ | | bit 15 | | • | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|--------|--------|--------| | _ | _ | _ | _ | _ | INT2EP | INT1EP | INT0EP | | bit 7 | | | | | | | bit 0 | **Legend:** HSC = Hardware Settable/Clearable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 ALTIVT: Enable Alternate Interrupt Vector Table bit 1 = Uses Alternate Interrupt Vector Table (AIVT) 0 = Uses standard (default) Interrupt Vector Table (IVT) bit 14 DISI: DISI Instruction Status bit 1 = DISI instruction is active 0 = DISI instruction is not active bit 13-3 **Unimplemented:** Read as '0' bit 2 INT2EP: External Interrupt 2 Edge Detect Polarity Select bit 1 = Interrupt is on the negative edge 0 = Interrupt is on the positive edge bit 1 INT1EP: External Interrupt 1 Edge Detect Polarity Select bit 1 = Interrupt is on the negative edge0 = Interrupt is on the positive edge bit 0 INT0EP: External Interrupt 0 Edge Detect Polarity Select bit 1 = Interrupt is on the negative edge0 = Interrupt is on the positive edge ## REGISTER 8-5: IFS0: INTERRUPT FLAG STATUS REGISTER 0 | HS/R/W-0 | U-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | U-0 | U-0 | HS/R/W-0 | |----------|-----|----------|----------|----------|-----|-----|----------| | NVMIF | _ | AD1IF | U1TXIF | U1RXIF | _ | _ | CCT2IF | | bit 15 | | | | | | | bit 8 | | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | U-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | |----------|----------|----------|-----|----------|----------|----------|----------| | CCT1IF | CCP4IF | CCP3IF | _ | T1IF | CCP2IF | CCP1IF | INT0IF | | bit 7 | | | | | | | bit 0 | | Legend: | HS = Hardware Settable bit | | | |-------------------|----------------------------|----------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, rea | d as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | bit 15 | <b>NVMIF:</b> NVM Interrupt Flag Status bit 1 = Interrupt request has occurred | |----------|-----------------------------------------------------------------------------------------------------| | | 0 = Interrupt request has not occurred | | bit 14 | Unimplemented: Read as '0' | | bit 13 | AD1IF: A/D Conversion Complete Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | | 0 = Interrupt request has not occurred | | bit 12 | U1TXIF: UART1 Transmitter Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | | 0 = Interrupt request has not occurred | | bit 11 | U1RXIF: UART1 Receiver Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | | 0 = Interrupt request has not occurred | | bit 10-9 | Unimplemented: Read as '0' | | bit 8 | CCT2IF: Capture/Compare 2 Timer Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | = | 0 = Interrupt request has not occurred | | bit 7 | CCT1IF: Capture/Compare 1 Timer Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | h:+ C | 0 = Interrupt request has not occurred | | bit 6 | CCP4IF: Capture/Compare 4 Event Interrupt Flag Status bit | | | <ul><li>1 = Interrupt request has occurred</li><li>0 = Interrupt request has not occurred</li></ul> | | bit 5 | CCP3IF: Capture/Compare 3 Event Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | | 0 = Interrupt request has not occurred | | bit 4 | Unimplemented: Read as '0' | | bit 3 | T1IF: Timer1 Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | | 0 = Interrupt request has not occurred | | bit 2 | <b>CCP2IF:</b> Capture/Compare 2 Event Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | 1 4 | 0 = Interrupt request has not occurred | | bit 1 | CCP1IF: Capture/Compare 1 Event Interrupt Flag Status bit | | | 1 = Interrupt request has occurred | | bit 0 | 0 = Interrupt request has not occurred | | DIL U | INTOIF: External Interrupt 0 Flag Status bit | | | 1 = Interrupt request has occurred 0 = Interrupt request has not occurred | | | interrupt request has not obtained | ### REGISTER 8-6: IFS1: INTERRUPT FLAG STATUS REGISTER 1 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | U-0 | U-0 | U-0 | |----------|----------|----------|----------|----------|-----|-----|-------| | U2TXIF | U2RXIF | INT2IF | CCT4IF | CCT3IF | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | HS/R/W-0 | U-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | |-------|----------|-----|----------|----------|----------|----------|----------| | _ | CCP5IF | _ | INT1IF | CNIF | CMIF | BCL1IF | SSP1IF | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **U2TXIF:** UART2 Transmitter Interrupt Flag Status bit 1 = Interrupt request has occurred 0 = Interrupt request has not occurred bit 14 U2RXIF: UART2 Receiver Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 13 INT2IF: External Interrupt 2 Flag Status bit 1 = Interrupt request has occurred 0 = Interrupt request has not occurred bit 12 CCT4IF: Capture/Compare 4 Timer Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 11 CCT3IF: Capture/Compare 3 Timer Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 10-7 **Unimplemented:** Read as '0' bit 6 **CCP5IF:** Capture/Compare 5 Event Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 5 **Unimplemented:** Read as '0' bit 4 INT1IF: External Interrupt 1 Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 3 CNIF: Input Change Notification Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 2 **CMIF:** Comparator Interrupt Flag Status Bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 1 **BCL1IF:** MSSP1 I<sup>2</sup>C Bus Collision Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 0 SI2C1IF: MSSP1 SPI/I<sup>2</sup>C Event Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred ## REGISTER 8-7: IFS2: INTERRUPT FLAG STATUS REGISTER 2 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | HS/R/W-0 | U-0 | |--------|-----|-----|-----|-----|-----|----------|-------| | _ | _ | _ | _ | _ | _ | CCT5IF | _ | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-10 **Unimplemented:** Read as '0' bit 9 CCT5IF: Capture/Compare 5 Timer Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 8-0 **Unimplemented:** Read as '0' ### REGISTER 8-8: IFS3: INTERRUPT FLAG STATUS REGISTER 3 | U-0 | HS/R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|----------|-----|-----|-----|-----|-----|-------| | _ | RTCIF | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | HS/R/W-0 | HS/R/W-0 | U-0 | |-------|-----|-----|-----|-----|----------|----------|-------| | _ | _ | _ | _ | _ | BCL2IF | SSP2IF | _ | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14 RTCIF: Real-Time Clock and Calendar Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 13-3 Unimplemented: Read as '0' bit 2 BCL2IF: MSSP2 I<sup>2</sup>C Bus Collision Interrupt Flag Status bit 1 = Interrupt request has occurred 0 = Interrupt request has not occurred bit 1 SSP2IF: MSSP2 SPI/I<sup>2</sup>C Event Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 0 Unimplemented: Read as '0' ### REGISTER 8-9: IFS4: INTERRUPT FLAG STATUS REGISTER 4 | HS/R/W-0 | HS/R/W-0 | HS/R/W-0 | U-0 | U-0 | U-0 | U-0 | R/W-0, HS | |----------|----------|----------|-----|-----|-----|-----|-----------| | DAC2IF | DAC1IF | CTMUIF | _ | _ | _ | _ | HLVDIF | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | HS/R/W-0 | HS/R/W-0 | U-0 | |-------|-----|-----|-----|-----|----------|----------|-------| | _ | _ | _ | _ | _ | U2ERIF | U1ERIF | _ | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 DAC2IF: Digital-to-Analog Converter 2 Interrupt Flag Status bit 1 = Interrupt request has occurred 0 = Interrupt request has not occurred bit 14 DAC1IF: Digital-to-Analog Converter 1 Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 13 **CTMUIF:** CTMU Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 12-9 Unimplemented: Read as '0' bit 8 **HLVDIF:** High/Low-Voltage Detect Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 7-3 Unimplemented: Read as '0' bit 2 U2ERIF: UART2 Error Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 1 U1ERIF: UART1 Error Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 0 **Unimplemented:** Read as '0' ### REGISTER 8-10: IFS5: INTERRUPT FLAG STATUS REGISTER 5 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 HS/R/W-0 | |-------|-----|-----|-----|-----|-----|-----|----------| | _ | _ | _ | _ | _ | _ | _ | ULPWUIF | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-1 Unimplemented: Read as '0' bit 0 **ULPWUIF:** Ultra Low-Power Wake-up Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred ### REGISTER 8-11: IFS6: INTERRUPT FLAG STATUS REGISTER 6 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | HS/R/W-0 | HS/R/W-0 | |-------|-----|-----|-----|-----|-----|----------|----------| | _ | _ | _ | _ | _ | _ | CLC2IF | CLC1IF | | bit 7 | | | | | | | bit 0 | **Legend:** HS = Hardware Settable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-2 Unimplemented: Read as '0' bit 1 CLC2IF: Configurable Logic Cell 2 Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 0 CLC1IF: Configurable Logic Cell 1 Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred ### REGISTER 8-12: IEC0: INTERRUPT ENABLE CONTROL REGISTER 0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | |--------|-----|-------|--------|--------|-----|-----|--------| | NVMIE | _ | AD1IE | U1TXIE | U1RXIE | _ | _ | CCT2IE | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|--------|--------|-----|-------|--------|--------|--------| | CCT1IE | CCP4IE | CCP3IE | _ | T1IE | CCP2IE | CCP1IE | INT0IE | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **NVMIE:** NVM Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 14 Unimplemented: Read as '0' bit 13 AD1IE: A/D Conversion Complete Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 12 **U1TXIE:** UART1 Transmitter Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 11 **U1RXIE:** UART1 Receiver Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 10-9 **Unimplemented:** Read as '0' bit 8 CCT2IE: Capture/Compare 2 Timer Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 7 CCT1IE: Capture/Compare 1 Timer Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 6 CCP4IE: Capture/Compare 4 Event Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 5 CCP3IE: Capture/Compare 3 Event Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 4 Unimplemented: Read as '0' bit 3 T1IE: Timer1 Interrupt Enable by **T1IE:** Timer1 Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 2 CCP2IE: Capture/Compare 2 Event Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 1 **CCP1IE:** Capture/Compare 1 Event Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 0 INTOIE: External Interrupt 0 Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled ## REGISTER 8-13: IEC1: INTERRUPT ENABLE CONTROL REGISTER 1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | |--------|--------|--------|--------|--------|-----|-----|-------| | U2TXIE | U2RXIE | INT2IE | CCT4IE | CCT3IE | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|--------|-----|--------|-------|-------|--------|--------| | _ | CCP5IE | _ | INT1IE | CNIE | CMIE | BCL1IE | SSP1IE | | bit 7 | | | | | | | bit 0 | R = Readable bit W = Writable bit -n = Value at POR '1' = Bit is set Legend: U = Unimplemented bit, read as '0' n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **U2TXIE:** UART2 Transmitter Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 14 **U2RXIE:** UART2 Receiver Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 13 INT2IE: External Interrupt 2 Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 12 CCT4IE: Capture/Compare 4 Timer Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 11 CCT3IE: Capture/Compare 3 Timer Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 10-7 Unimplemented: Read as '0' bit 6 **CCP5IE:** Capture/Compare 5 Event Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 5 **Unimplemented:** Read as '0' bit 4 INT1IE: External Interrupt 1 Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 3 CNIE: Input Change Notification Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 2 CMIE: Comparator Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 1 BCL1IE: MSSP1 I<sup>2</sup>C Bus Collision Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 0 SSP1IE: MSSP1 SPI/I<sup>2</sup>C Event Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled ### REGISTER 8-14: IEC2: INTERRUPT ENABLE CONTROL REGISTER 2 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | U-0 | |--------|-----|-----|-----|-----|-----|--------|-------| | _ | _ | _ | _ | _ | _ | CCT5IE | _ | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: bit 8-0 R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-10 **Unimplemented:** Read as '0' bit 9 CCT5IE: Capture/Compare 5 Timer Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled Unimplemented: Read as '0' ## REGISTER 8-15: IEC3: INTERRUPT ENABLE CONTROL REGISTER 3 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|-------|-----|-----|-----|-----|-----|-------| | _ | RTCIE | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | |-------|-----|-----|-----|-----|--------|--------|-------| | _ | _ | _ | _ | _ | BCL2IE | SSP2IE | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14 RTCIE: Real-Time Clock and Calendar Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 13-3 Unimplemented: Read as '0' bit 2 BCL2IE: MSSP2 I<sup>2</sup>C Bus Collision Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 1 SSP2IE: MSSP2 SPI/I<sup>2</sup>C Event Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 0 **Unimplemented:** Read as '0' ### REGISTER 8-16: IEC4: INTERRUPT ENABLE CONTROL REGISTER 4 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | |--------|--------|--------|-----|-----|-----|-----|--------| | DAC2IE | DAC1IE | CTMUIE | _ | _ | _ | _ | HLVDIE | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | |-------|-----|-----|-----|-----|--------|--------|-------| | _ | _ | _ | _ | _ | U2ERIE | U1ERIE | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 DAC2IE: Digital-to-Analog Converter 2 Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 14 DAC1IE: Digital-to-Analog Converter 1 Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 13 **CTMUIE:** CTMU Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 12-9 Unimplemented: Read as '0' bit 8 **HLVDIE**: High/Low-Voltage Detect Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 7-3 **Unimplemented:** Read as '0' bit 2 **U2ERIE:** UART2 Error Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 1 **U1ERIE:** UART1 Error Interrupt Enable bit 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 0 **Unimplemented:** Read as '0' ### REGISTER 8-17: IEC5: INTERRUPT ENABLE CONTROL REGISTER 5 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 R/W-0 | |-------|-----|-----|-----|-----|-----|-----|---------| | _ | _ | _ | _ | _ | _ | _ | ULPWUIE | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-1 **Unimplemented:** Read as '0' bit 0 **ULPWUIE:** Ultra Low-Power Wake-up Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled ### REGISTER 8-18: IEC6: INTERRUPT ENABLE CONTROL REGISTER 5 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|-----|--------|--------| | _ | _ | _ | _ | _ | _ | CLC2IE | CLC1IE | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-2 Unimplemented: Read as '0' bit 1 CLC2IE: Configurable Logic Cell 2 Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled bit 0 CLC1IE: Configurable Logic Cell 1 Interrupt Enable bit 1 = Interrupt request is enabled0 = Interrupt request is not enabled ### REGISTER 8-19: IPC0: INTERRUPT PRIORITY CONTROL REGISTER 0 | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|-------|-------|-------|-----|---------|---------|---------| | _ | T1IP2 | T1IP1 | T1IP0 | _ | CCP2IP2 | CCP2IP1 | CCP2IP0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|---------|---------|---------|-----|---------|---------|---------| | _ | CCP1IP2 | CCP1IP1 | CCP1IP0 | _ | INT0IP2 | INT0IP1 | INT0IP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15 **Unimplemented:** Read as '0' bit 14-12 T1IP[2:0]: Timer1 Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11 **Unimplemented:** Read as '0' bit 10-8 CCP2IP[2:0]: Capture/Compare 2 Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7 Unimplemented: Read as '0' bit 6-4 CCP1IP[2:0]: Capture/Compare 1 Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3 **Unimplemented:** Read as '0' bit 2-0 INT0IP[2:0]: External Interrupt 0 Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . 001 = Interrupt is Priority 1 ## REGISTER 8-20: IPC1: INTERRUPT PRIORITY CONTROL REGISTER 1 | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|---------|---------|---------|-----|---------|---------|---------| | _ | CCT1IP2 | CCT1IP1 | CCT1IP0 | _ | CCP4IP2 | CCP4IP1 | CCP4IP0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-------|---------|---------|---------|-----|-----|-----|-------| | _ | CCP3IP2 | CCP3IP1 | CCP3IP0 | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 CCT1IP[2:0]: Capture/Compare 1 Timer Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11 **Unimplemented:** Read as '0' bit 10-8 **CCP4IP[2:0]:** Capture/Compare 4 Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7 **Unimplemented:** Read as '0' bit 6-4 CCP3IP[2:0]: Capture/Compare 3 Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3-0 **Unimplemented:** Read as '0' ## REGISTER 8-21: IPC2: INTERRUPT PRIORITY CONTROL REGISTER 2 | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |--------|---------|---------|---------|-----|-----|-----|-------| | _ | U1RXIP2 | U1RXIP1 | U1RXIP0 | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|---------|---------|---------| | _ | _ | _ | _ | _ | CCT2IP2 | CCT2IP1 | CCT2IP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 **U1RXIP[2:0]:** UART1 Receiver Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11-3 **Unimplemented:** Read as '0' bit 2-0 CCT2IP[2:0]: Capture/Compare 2 Timer Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • \_ 001 = Interrupt is Priority 1 ### REGISTER 8-22: IPC3: INTERRUPT PRIORITY CONTROL REGISTER 3 | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |--------|--------|--------|--------|-----|-----|-----|-------| | _ | NVMIP2 | NVMIP1 | NVMIP0 | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|--------|--------|--------|-----|---------|---------|---------| | _ | AD1IP2 | AD1IP1 | AD1IP0 | _ | U1TXIP2 | U1TXIP1 | U1TXIP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 **NVMIP[2:0]:** NVM Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . . . . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11-7 **Unimplemented:** Read as '0' bit 6-4 AD1IP[2:0]: A/D Conversion Complete Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3 **Unimplemented:** Read as '0' bit 2-0 U1TXIP[2:0]: UART1 Transmitter Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 ### REGISTER 8-23: IPC4: INTERRUPT PRIORITY CONTROL REGISTER 4 | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|-------|-------|-------|-----|-------|-------|-------| | _ | CNIP2 | CNIP1 | CNIP0 | _ | CMIP2 | CMIP1 | CMIP0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|---------|---------|---------|-----|---------|---------|---------| | _ | BCL1IP2 | BCL1IP1 | BCL1IP0 | _ | SSP1IP2 | SSP1IP1 | SSP1IP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 CNIP[2:0]: Input Change Notification Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11 **Unimplemented:** Read as '0' bit 10-8 **CMIP[2:0]:** Comparator Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) . • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7 **Unimplemented:** Read as '0' bit 6-4 **BCL1IP[2:0]:** MSSP1 I<sup>2</sup>C Bus Collision Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3 **Unimplemented:** Read as '0' bit 2-0 SSP1IP[2:0]: MSSP1 SPI/I<sup>2</sup>C Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) . . 001 = Interrupt is Priority 1 ### REGISTER 8-24: IPC5: INTERRUPT PRIORITY CONTROL REGISTER 5 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|-----|-----|-----|-----|---------|---------|---------| | _ | _ | _ | _ | _ | CCP5IP2 | CCP5IP1 | CCP5IP0 | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|---------|---------|---------| | _ | _ | _ | _ | _ | INT1IP2 | INT1IP1 | INT1IP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-11 **Unimplemented:** Read as '0' bit 10-8 **CCP5IP[2:0]:** Capture/Compare 5 Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7-3 **Unimplemented:** Read as '0' bit 2-0 **INT1IP[2:0]:** External Interrupt 1 Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) . 001 = Interrupt is Priority 1 ## REGISTER 8-25: IPC6: INTERRUPT PRIORITY CONTROL REGISTER 6 | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |--------|---------|---------|---------|-----|-----|-----|-------| | _ | CCT3IP2 | CCT3IP1 | CCT3IP0 | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 |-------------|-----|-----|-----|-----|-----|-----|-----| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 bit 0 | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 CCT3IP[2:0]: Capture/Compare 3 Timer Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11-0 **Unimplemented:** Read as '0' ### REGISTER 8-26: IPC7: INTERRUPT PRIORITY CONTROL REGISTER 7 | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|---------|---------|---------|-----|---------|---------|---------| | _ | U2TXIP2 | U2TXIP1 | U2TXIP0 | _ | U2RXIP2 | U2RXIP1 | U2RXIP0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|---------|---------|---------|-----|---------|---------|---------| | _ | INT2IP2 | INT2IP1 | INT2IP0 | _ | CCT4IP2 | CCT4IP1 | CCT4IP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 Unimplemented: Read as '0' bit 14-12 U2TXIP[2:0]: UART2 Transmitter Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11 **Unimplemented:** Read as '0' bit 10-8 **U2RXIP[2:0]:** UART2 Receiver Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) . \_ 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7 **Unimplemented:** Read as '0' bit 6-4 **INT2IP[2:0]:** External Interrupt 2 Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) . • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3 **Unimplemented:** Read as '0' bit 2-0 CCT4IP[2:0]: Capture/Compare 4 Timer Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . 001 = Interrupt is Priority 1 #### REGISTER 8-27: IPC10: INTERRUPT PRIORITY CONTROL REGISTER 10 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | | _ | | _ | | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-------|---------|---------|---------|-----|-----|-----|-------| | _ | CCT5IP2 | CCT5IP1 | CCT5IP0 | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-7 **Unimplemented:** Read as '0' bit 6-4 CCT5IP[2:0]: Capture/Compare 5 Timer Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3-0 **Unimplemented:** Read as '0' #### REGISTER 8-28: IPC12: INTERRUPT PRIORITY CONTROL REGISTER 12 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|-----|-----|-----|-----|---------|---------|---------| | _ | _ | _ | _ | _ | BCL2IP2 | BCL2IP1 | BCL2IP0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-------|---------|---------|---------|-----|-----|-----|-------| | _ | SSP2IP2 | SSP2IP1 | SSP2IP0 | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-11 **Unimplemented:** Read as '0' bit 10-8 **BCL2IP[2:0]:** MSSP2 I<sup>2</sup>C Bus Collision Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7 **Unimplemented:** Read as '0' bit 6-4 SSP2IP[2:0]: MSSP2 SPI/I<sup>2</sup>C Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3-0 **Unimplemented:** Read as '0' #### REGISTER 8-29: IPC15: INTERRUPT PRIORITY CONTROL REGISTER 15 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|-----|-----|-----|-----|--------|--------|--------| | _ | _ | _ | _ | _ | RTCIP2 | RTCIP1 | RTCIP0 | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-11 **Unimplemented:** Read as '0' bit 10-8 RTCIP[2:0]: Real-Time Clock and Calendar Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7-0 **Unimplemented:** Read as '0' #### REGISTER 8-30: IPC16: INTERRUPT PRIORITY CONTROL REGISTER 16 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|-----|-----|-----|-----|---------|---------|---------| | _ | _ | _ | _ | _ | U2ERIP2 | U2ERIP1 | U2ERIP0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-------|---------|---------|---------|-----|-----|-----|-------| | _ | U1ERIP2 | U1ERIP1 | U1ERIP0 | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-11 **Unimplemented:** Read as '0' bit 10-8 **U2ERIP[2:0]:** UART2 Error Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7 **Unimplemented:** Read as '0' bit 6-4 **U1ERIP[2:0]:** UART1 Error Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) . . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3-0 **Unimplemented:** Read as '0' #### REGISTER 8-31: IPC18: INTERRUPT PRIORITY CONTROL REGISTER 18 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|---------|---------|---------| | _ | _ | _ | _ | _ | HLVDIP2 | HLVDIP1 | HLVDIP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-3 **Unimplemented:** Read as '0' bit 2-0 **HLVDIP[2:0]:** High/Low-Voltage Detect Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled #### **REGISTER 8-32: IPC19: INTERRUPT PRIORITY CONTROL REGISTER 19** | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|---------|---------|---------|-----|---------|---------|---------| | _ | DAC2IP2 | DAC2IP1 | DAC2IP0 | _ | DAC1IP2 | DAC1IP1 | DAC1IP0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-------|---------|---------|---------|-----|-----|-----|-------| | _ | CTMUIP2 | CTMUIP1 | CTMUIP0 | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 DAC2IP[2:0]: Digital-to-Analog Converter 2 Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 11 **Unimplemented:** Read as '0' bit 10-8 DAC1IP[2:0]: Digital-to-Analog Converter 1 Event Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 7 **Unimplemented:** Read as '0' bit 6-4 CTMUIP[2:0]: CTMU Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3-0 **Unimplemented:** Read as '0' #### REGISTER 8-33: IPC20: INTERRUPT PRIORITY CONTROL REGISTER 20 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | | _ | _ | _ | | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|----------|----------|----------| | _ | _ | _ | _ | _ | ULPWUIP2 | ULPWUIP1 | ULPWUIP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-3 Unimplemented: Read as '0' bit 2-0 **ULPWUIP[2:0]:** Ultra Low-Power Wake-up Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • . 001 = Interrupt is Priority 1 000 = Interrupt source is disabled #### REGISTER 8-34: IPC24: INTERRUPT PRIORITY CONTROL REGISTER 24 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|---------|---------|---------|-----|---------|---------|---------| | _ | CLC2IP2 | CLC2IP1 | CLC2IP0 | _ | CLC1IP2 | CLC1IP1 | CLC1IP0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-7 Unimplemented: Read as '0' bit 6-4 CLC2IP[2:0]: CLC2 Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled bit 3 **Unimplemented:** Read as '0' bit 2-0 **CLC1IP[2:0]:** CLC1 Interrupt Priority bits 111 = Interrupt is Priority 7 (highest priority interrupt) • • 001 = Interrupt is Priority 1 000 = Interrupt source is disabled #### REGISTER 8-35: INTTREG: INTERRUPT CONTROL AND STATUS REGISTER | R-0 | U-0 | R/W-0 | U-0 | R-0 | R-0 | R-0 | R-0 | |--------|-----|-------|-----|------|------|------|-------| | CPUIRQ | _ | VHOLD | _ | ILR3 | ILR2 | ILR1 | ILR0 | | bit 15 | | | | | | | bit 8 | | U-0 | R-0 |-------|-----|-----|-----|-------------|-----|-----|-------| | _ | | | | VECNUM[6:0] | ] | | | | bit 7 | | | | | | | bit 0 | | Legend: | | | | |-------------------|------------------|-----------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read | d as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15 CPUIRQ: Interrupt Request from Interrupt Controller CPU bit 1 = An interrupt request has occurred but has not yet been Acknowledged by the CPU (this will happen when the CPU priority is higher than the interrupt priority) 0 = No interrupt request is left unacknowledged bit 14 **Unimplemented:** Read as '0' bit 13 VHOLD: Vector Hold bit Allows Vector Number Capture and Changes which Interrupt is Stored in the VECNUM[6:0] bits: 1 = VECNUM[6:0] will contain the value of the highest priority pending interrupt, instead of the current interrupt 0 = VECNUM[6:0] will contain the value of the last Acknowledged interrupt (last interrupt that has occurred with higher priority than the CPU, even if other interrupts are pending) bit 12 **Unimplemented:** Read as '0' bit 11-8 ILR[3:0]: New CPU Interrupt Priority Level bits 1111 = CPU Interrupt Priority Level is 15 • 0001 = CPU Interrupt Priority Level is 1 0000 = CPU Interrupt Priority Level is 0 bit 7 Unimplemented: Read as '0' bit 6-0 **VECNUM[6:0]:** Vector Number of Pending Interrupt bits 0111111 = Interrupt vector pending is Number 135 • • 0000001 = Interrupt vector pending is Number 9 0000000 = Interrupt vector pending is Number 8 #### 8.4 Interrupt Setup Procedures #### 8.4.1 INITIALIZATION To configure an interrupt source: - Set the NSTDIS control bit (INTCON1[15]) if nested interrupts are not desired. - Select the user-assigned priority level for the interrupt source by writing the control bits in the appropriate IPCx register. The priority level will depend on the specific application and type of interrupt source. If multiple priority levels are not desired, the IPCx register control bits for all enabled interrupt sources may be programmed to the same non-zero value. **Note:** At a device Reset, the IPCx registers are initialized, such that all user interrupt sources are assigned to Priority Level 4. - Clear the interrupt flag status bit associated with the peripheral in the associated IFSx register. - 4. Enable the interrupt source by setting the interrupt enable control bit associated with the source in the appropriate IECx register. #### 8.4.2 INTERRUPT SERVICE ROUTINE The method that is used to declare an ISR (Interrupt Service Routine) and initialize the IVT with the correct vector address depends on the programming language (i.e., C or assembly), and the language development toolsuite that is used to develop the application. In general, the user must clear the interrupt flag in the appropriate IFSx register for the source of the interrupt that the ISR handles. Otherwise, the ISR will be re-entered immediately after exiting the routine. If the ISR is coded in assembly language, it must be terminated using a RETFIE instruction to unstack the saved PC value, SRL value and old CPU priority level. #### 8.4.3 TRAP SERVICE ROUTINE (TSR) A Trap Service Routine (TSR) is coded like an ISR, except that the appropriate trap status flag in the INTCON1 register must be cleared to avoid re-entry into the TSR. #### 8.4.4 INTERRUPT DISABLE All user interrupts can be disabled using the following procedure: - Push the current SR value onto the software stack using the PUSH instruction. - Force the CPU to Priority Level 7 by inclusive ORing the value, 0Eh, with SRL. To enable user interrupts, the POP instruction may be used to restore the previous SR value. Only user interrupts with a priority level of 7 or less can be disabled. Trap sources (Levels 8-15) cannot be disabled. The DISI instruction provides a convenient way to disable interrupts of Priority Levels 1-6 for a fixed period. Level 7 interrupt sources are not disabled by the DISI instruction. NOTES: # 9.0 OSCILLATOR CONFIGURATION Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on oscillator configuration, refer to "Oscillator with 500 kHz Low-Power FRC" (www.microchip.com/DS39726) in FRC" (www.microchip.com/DS39726) in the "dsPIC33/PIC24F Family Reference Manual". The oscillator system for the PIC24FV16KM204 family of devices has the following features: A total of five external and internal oscillator options as clock sources, providing 11 different clock modes. - On-chip 4x Phase-Locked Loop (PLL) to boost internal operating frequency on select internal and external oscillator sources. - Software-controllable switching between various clock sources. - Software-controllable postscaler for selective clocking of CPU for system power savings. - System frequency range declaration bits for External Clock (EC) mode. When using an EC source, the current consumption is reduced by setting the declaration bits to the expected frequency range. - A Fail-Safe Clock Monitor (FSCM) that detects clock failure and permits safe application recovery or shutdown. A simplified diagram of the oscillator system is shown in Figure 9-1. FIGURE 9-1: PIC24FXXXXX FAMILY CLOCK DIAGRAM #### 9.1 CPU Clocking Scheme The system clock source can be provided by one of four sources: - Primary Oscillator (POSC) on the OSCI and OSCO pins - Secondary Oscillator (SOSC) on the SOSCI and SOSCO pins The PIC24FXXXXX family devices consist of two types of secondary oscillator: - High-Power Secondary Oscillator - Low-Power Secondary Oscillator These can be selected by using the SOSCSEL (FOSC[5]) bit. - Fast Internal RC (FRC) Oscillator: - 8 MHz FRC Oscillator - 500 kHz Lower Power FRC Oscillator - Low-Power Internal RC (LPRC) Oscillator with two modes: - High-Power/High-Accuracy mode - Low-Power/Low-Accuracy mode The Primary Oscillator and 8 MHz FRC sources have the option of using the internal 4x PLL. The frequency of the FRC clock source can optionally be reduced by the programmable clock divider. The selected clock source generates the processor and peripheral clock sources. The processor clock source is divided by two to produce the internal instruction cycle clock, Fcy. In this document, the instruction cycle clock is also denoted by Fosc/2. The internal instruction cycle clock, Fosc/2, can be provided on the OSCO I/O pin for some operating modes of the Primary Oscillator. #### 9.2 Initial Configuration on POR The oscillator source (and operating mode) that is used at a device Power-on Reset (POR) event is selected using Configuration bit settings. The Oscillator Configuration bit settings are located in the Configuration registers in the program memory (for more information, see Section 25.1 "Configuration Bits"). The Primary Configuration bits, POSCMOD[1:0] Oscillator (FOSC[1:0]), and the Initial Oscillator Select Configuration bits, FNOSC[2:0] (FOSCSEL[2:0]), select the oscillator source that is used at a POR. The FRC Primary Oscillator with Postscaler (FRCDIV) is the default (unprogrammed) selection. The Secondary Oscillator, or one of the internal oscillators, may be chosen by programming these bit locations. The EC mode Frequency Range Configuration bits, POSCFREQ[1:0] (FOSC[4:3]), optimize power consumption when running in EC mode. The default configuration is "frequency range is greater than 8 MHz". The Configuration bits allow users to choose between the various clock modes, as shown in Table 9-1. # 9.2.1 CLOCK SWITCHING MODE CONFIGURATION BITS The FCKSM[1:0] Configuration bits (FOSC[7:6]) are used jointly to configure device clock switching and the FSCM. Clock switching is enabled only when FCKSM1 is programmed ('0'). The FSCM is enabled only when FCKSM[1:0] are both programmed ('0'). | TABLE 9-1: | CONFIGURATION BIT VALUES FOR CLOCK SELECTION | |------------|----------------------------------------------| | IADLE 9-1: | CONFIGURATION BIT VALUES FOR CLOCK SELECTION | | Oscillator Mode | Oscillator Source | POSCMOD[1:0] | FNOSC[2:0] | Notes | |---------------------------------------------------|-------------------|--------------|------------|-------| | 8 MHz FRC Oscillator with Postscaler (FRCDIV) | Internal | 11 | 111 | 1, 2 | | 500 kHz FRC Oscillator with Postscaler (LPFRCDIV) | Internal | 11 | 110 | 1 | | Low-Power RC Oscillator (LPRC) | Internal | 11 | 101 | 1 | | Secondary (Timer1) Oscillator (SOSC) | Secondary | 00 | 100 | 1 | | Primary Oscillator (HS) with PLL Module (HSPLL) | Primary | 10 | 011 | | | Primary Oscillator (EC) with PLL Module (ECPLL) | Primary | 0.0 | 011 | | | Primary Oscillator (HS) | Primary | 10 | 010 | | | Primary Oscillator (XT) | Primary | 01 | 010 | | | Primary Oscillator (EC) | Primary | 00 | 010 | | | 8 MHz FRC Oscillator with PLL Module (FRCPLL) | Internal | 11 | 001 | 1 | | 8 MHz FRC Oscillator (FRC) | Internal | 11 | 000 | 1 | Note 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.3 Control Registers The operation of the oscillator is controlled by three Special Function Registers (SFRs): - OSCCON - CLKDIV - OSCTUN The OSCCON register (Register 9-1) is the main control register for the oscillator. It controls clock source switching and allows the monitoring of clock sources The Clock Divider register (Register 9-2) controls the features associated with Doze mode, as well as the postscaler for the FRC Oscillator. The FRC Oscillator Tune register (Register 9-3) allows the user to fine-tune the FRC Oscillator over a range of approximately ±5.25%. Each bit increment or decrement changes the factory calibrated frequency of the FRC Oscillator by a fixed amount. #### REGISTER 9-1: OSCCON: OSCILLATOR CONTROL REGISTER | U-0 | HSC/R-0 | HSC/R-0 | HSC/R-0 | U-0 | R/W-x <sup>(1)</sup> | R/W-x <sup>(1)</sup> | R/W-x <sup>(1)</sup> | |--------|---------|---------|---------|-----|----------------------|----------------------|----------------------| | _ | COSC2 | COSC1 | COSC0 | _ | NOSC2 | NOSC1 | NOSC0 | | bit 15 | | | | | | | bit 8 | | HSC/R/SO-0 | U-0 | HSC/R-0 <sup>(2)</sup> | U-0 | HS/R/CO-0 | R/W-0 <sup>(3)</sup> | R/W-0 | R/W-0 | |------------|-----|------------------------|-----|-----------|----------------------|--------|-------| | CLKLOCK | _ | LOCK | _ | CF | SOSCDRV | SOSCEN | OSWEN | | bit 7 | • | | | | | | bit 0 | Legend:HSC = Hardware Settable/Clearable bitHS = Hardware Settable bitCO = Clearable Only bitSO = Settable Only bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 COSC[2:0]: Current Oscillator Selection bits 111 = 8 MHz Fast RC Oscillator with Postscaler (FRCDIV) 110 = 500 kHz Low-Power Fast RC Oscillator (FRC) with Postscaler (LPFRCDIV) 101 = Low-Power RC Oscillator (LPRC) 100 = Secondary Oscillator (SOSC) 011 = Primary Oscillator with PLL module (XTPLL, HSPLL, ECPLL) 010 = Primary Oscillator (XT, HS, EC) 001 = 8 MHz FRC Oscillator with Postscaler and PLL module (FRCPLL) 000 = 8 MHz FRC Oscillator (FRC) bit 11 **Unimplemented:** Read as '0' bit 10-8 **NOSC[2:0]:** New Oscillator Selection bits<sup>(1)</sup> 111 = 8 MHz Fast RC Oscillator with Postscaler (FRCDIV) 110 = 500 kHz Low-Power Fast RC Oscillator (FRC) with Postscaler (LPFRCDIV) 101 = Low-Power RC Oscillator (LPRC) 100 = Secondary Oscillator (SOSC) 011 = Primary Oscillator with PLL module (XTPLL, HSPLL, ECPLL) 010 = Primary Oscillator (XT, HS, EC) 001 = 8 MHz FRC Oscillator with Postscaler and PLL module (FRCPLL) 000 = 8 MHz FRC Oscillator (FRC) Note 1: Reset values for these bits are determined by the FNOSCx Configuration bits. 2: This bit also resets to '0' during any valid clock switch or whenever a non-PLL Clock mode is selected. 3: When SOSC is selected to run from a digital clock input rather than an external crystal (SOSCSRC = 0), this bit has no effect. #### REGISTER 9-1: OSCCON: OSCILLATOR CONTROL REGISTER (CONTINUED) bit 7 CLKLOCK: Clock Selection Lock Enable bit If FSCM is Enabled (FCKSM1 = 1): 1 = Clock and PLL selections are locked 0 = Clock and PLL selections are not locked and may be modified by setting the OSWEN bit If FSCM is Disabled (FCKSM1 = 0): Clock and PLL selections are never locked and may be modified by setting the OSWEN bit. bit 6 **Unimplemented:** Read as '0' bit 5 **LOCK:** PLL Lock Status bit<sup>(2)</sup> 1 = PLL module is in lock or PLL module start-up timer is satisfied 0 = PLL module is out of lock, PLL start-up timer is running or PLL is disabled bit 4 **Unimplemented:** Read as '0' 1 = FSCM has detected a clock failure0 = No clock failure has been detected bit 2 **SOSCDRV**: Secondary Oscillator Drive Strength bit<sup>(3)</sup> 1 = High-power SOSC circuit is selected 0 = Low/high-power select is done via the SOSCSRC Configuration bit bit 1 SOSCEN: 32 kHz Secondary Oscillator (SOSC) Enable bit 1 = Enables the Secondary Oscillator0 = Disables the Secondary Oscillator bit 0 OSWEN: Oscillator Switch Enable bit 1 = Initiates an oscillator switch to the clock source specified by the NOSC[2:0] bits 0 = Oscillator switch is complete Note 1: Reset values for these bits are determined by the FNOSCx Configuration bits. 2: This bit also resets to '0' during any valid clock switch or whenever a non-PLL Clock mode is selected. 3: When SOSC is selected to run from a digital clock input rather than an external crystal (SOSCSRC = 0), this bit has no effect. #### **REGISTER 9-2: CLKDIV: CLOCK DIVIDER REGISTER** | R/W-0 | R/W-0 | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-1 | |--------|-------|-------|-------|----------------------|--------|--------|--------| | ROI | DOZE2 | DOZE1 | DOZE0 | DOZEN <sup>(1)</sup> | RCDIV2 | RCDIV1 | RCDIV0 | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 ROI: Recover on Interrupt bit 1 = Interrupts clear the DOZEN bit, and reset the CPU and peripheral clock ratio to 1:1 0 = Interrupts have no effect on the DOZEN bit DOZE[2:0]: CPU and Peripheral Clock Ratio Select bits bit 14-12 111 = 1:128 110 = 1:64 101 = 1:32 100 = 1:16 011 = 1:8 010 = 1:4 001 = 1:2 000 = 1:1 DOZEN: Doze Enable bit(1) bit 11 1 = DOZE[2:0] bits specify the CPU and peripheral clock ratio 0 = CPU and peripheral clock ratio are set to 1:1 bit 10-8 RCDIV[2:0]: FRC Postscaler Select bits When COSC[2:0] (OSCCON[14:12]) = 111: 111 = 31.25 kHz (divide-by-256) 110 = 125 kHz (divide-by-64) 101 = 250 kHz (divide-by-32) 100 = 500 kHz (divide-by-16) 011 = 1 MHz (divide-by-8) 010 = 2 MHz (divide-by-4) 001 = 4 MHz (divide-by-2) - default 000 = 8 MHz (divide-by-1) When COSC[2:0] (OSCCON[14:12]) = 110: 111 = 1.95 kHz (divide-by-256) 110 = 7.81 kHz (divide-by-64) 101 = 15.62 kHz (divide-by-32) 100 = 31.25 kHz (divide-by-16) 011 = 62.5 kHz (divide-by-8) 010 = 125 kHz (divide-by-4) 001 = 250 kHz (divide-by-2) - default 000 = 500 kHz (divide-by-1) bit 7-0 Unimplemented: Read as '0' Note 1: This bit is automatically cleared when the ROI bit is set and an interrupt occurs. #### REGISTER 9-3: OSCTUN: FRC OSCILLATOR TUNE REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-------|-------|-------|---------------------|-------|-------| | _ | _ | | | TUN[ | 5:0] <sup>(1)</sup> | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-6 **Unimplemented:** Read as '0' bit 5-0 **TUN[5:0]:** FRC Oscillator Tuning bits<sup>(1)</sup> 011111 = Maximum frequency deviation 011110 • 000001 000000 = Center frequency, oscillator is running at factory calibrated frequency 111111 • \_ 100001 100000 = Minimum frequency deviation **Note 1:** Increments or decrements of TUN[5:0] may not change the FRC frequency in equal steps over the FRC tuning range and may not be monotonic. #### 9.4 Clock Switching Operation With few limitations, applications are free to switch between any of the four clock sources (POSC, SOSC, FRC and LPRC) under software control and at any time. To limit the possible side effects that could result from this flexibility, PIC24F devices have a safeguard lock built into the switching process. Note: The Primary Oscillator mode has three different submodes (XT, HS and EC), which are determined by the POSCMODx Configuration bits. While an application can switch to and from Primary Oscillator mode in software, it cannot switch between the different primary submodes without reprogramming the device. #### 9.4.1 ENABLING CLOCK SWITCHING To enable clock switching, the FCKSM1 Configuration bit in the FOSC Configuration register must be programmed to '0'. (Refer to **Section 25.0 "Special Features"** for further details.) If the FCKSM1 Configuration bit is unprogrammed ('1'), the clock switching function and FSCM function are disabled; this is the default setting. The NOSCx control bits (OSCCON[10:8]) do not control the clock selection when clock switching is disabled. However, the COSCx bits (OSCCON[14:12]) will reflect the clock source selected by the FNOSCx Configuration bits The OSWEN control bit (OSCCON[0]) has no effect when clock switching is disabled; it is held at '0' at all times. # 9.4.2 OSCILLATOR SWITCHING SEQUENCE At a minimum, performing a clock switch requires this basic sequence: - If desired, read the COSCx bits (OSCCON[14:12]) to determine the current oscillator source. - 2. Perform the unlock sequence to allow a write to the OSCCON register high byte. - 3. Write the appropriate value to the NOSCx bits (OSCCON[10:8]) for the new oscillator source. - Perform the unlock sequence to allow a write to the OSCCON register low byte. - Set the OSWEN bit to initiate the oscillator switch. Once the basic sequence is completed, the system clock hardware responds automatically, as follows: - The clock switching hardware compares the COSCx bits with the new value of the NOSCx bits. If they are the same, then the clock switch is a redundant operation. In this case, the OSWEN bit is cleared automatically and the clock switch is aborted. - If a valid clock switch has been initiated, the LOCK (OSCCON[5]) and CF (OSCCON[3]) bits are cleared. - The new oscillator is turned on by the hardware if it is not currently running. If a crystal oscillator must be turned on, the hardware will wait until the OST expires. If the new source is using the PLL, then the hardware waits until a PLL lock is detected (LOCK = 1). - The hardware waits for ten clock cycles from the new clock source and then performs the clock switch. - The hardware clears the OSWEN bit to indicate a successful clock transition. In addition, the NOSCx bits value is transferred to the COSCx bits. - The old clock source is turned off at this time, with the exception of LPRC (if WDT, FSCM or RTCC with LPRC as a clock source is enabled) or SOSC (if SOSCEN remains enabled). - **Note 1:** The processor will continue to execute code throughout the clock switching sequence. Timing-sensitive code should not be executed during this time. - 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:** An unlock sequence must be performed before a write to OSCCON is allowed. The following code sequence for a clock switch is recommended: - Disable interrupts during the OSCCON register unlock and write sequence. - Execute the unlock sequence for the OSCCON high byte by writing 78h and 9Ah to OSCCON[15:8], in two back-to-back instructions. - Write the new oscillator source to the NOSCx bits in the instruction immediately following the unlock sequence. - Execute the unlock sequence for the OSCCON low byte by writing 46h and 57h to OSCCON[7:0], in two back-to-back instructions. - Set the OSWEN bit in the instruction immediately following the unlock sequence. - Continue to execute code that is not clock-sensitive (optional). - Invoke an appropriate amount of software delay (cycle counting) to allow the selected oscillator and/or PLL to start and stabilize. - Check to see if OSWEN is '0'. If it is, the switch was successful. If OSWEN is still set, then check the LOCK bit to determine the cause of failure. The core sequence for unlocking the OSCCON register and initiating a clock switch is shown in Example 9-1 and Example 9-2. # EXAMPLE 9-1: ASSEMBLY CODE SEQUENCE FOR CLOCK SWITCHING ``` ;Place the new oscillator selection in WO ;OSCCONH (high byte) Unlock Sequence MOV #OSCCONH, w1 #0x78, w2 MOV #0x9A, w3 MOV MOV.b w2, [w1] MOV.b w3, [w1] ;Set new oscillator selection WREG, OSCCONH MOV.b ;OSCCONL (low byte) unlock sequence MOV #OSCCONL, w1 MOV #0x46, w2 #0x57, w3 MOV w2, [w1] MOV.b MOV.b w3, [w1] ;Start oscillator switch operation BSET OSCCON, #0 ``` # EXAMPLE 9-2: BASIC 'C' CODE SEQUENCE FOR CLOCK SWITCHING ``` //Use compiler built-in function to write new clock setting __builtin_write_OSCCONH(0x01); //0x01 switches to FRCPLL //Use compiler built-in function to set the OSWEN bit. __builtin_write_OSCCONL(OSCCONL | 0x01); //Optional: Wait for clock switch sequence to complete while(OSCCONbits.OSWEN == 1); ``` #### 9.5 Reference Clock Output In addition to the CLKO output (Fosc/2) available in certain oscillator modes, the device clock in the PIC24FXXXXX family devices can also 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. This reference clock output is controlled by the REFOCON register (Register 9-4). Setting the ROEN bit (REFOCON[15]) makes the clock signal available on the REFO pin. The RODIV[3:0] bits (REFOCON[11:8]) enable the selection of 16 different clock divider options. The ROSSLP and ROSEL bits (REFOCON[13:12]) control the availability of the reference output during Sleep mode. The ROSEL bit determines if the oscillator on OSC1 and OSC2, or the current system clock source, is used for the reference clock output. The ROSSLP bit determines if the reference source is available on REFO when the device is in Sleep mode. To use the reference clock output in Sleep mode, both the ROSSLP and ROSEL bits must be set. The device clock must also be configured for one of the primary modes (EC, HS or XT); otherwise, if the ROSEL bit is not also set, the oscillator on OSC1 and OSC2 will be powered down when the device enters Sleep mode. Clearing the ROSEL bit allows the reference output frequency to change as the system clock changes during any clock switches. #### **REGISTER 9-4:** REFOCON: REFERENCE OSCILLATOR CONTROL REGISTER | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|--------|-------|--------|--------|--------|--------| | ROEN | _ | ROSSLP | ROSEL | RODIV3 | RODIV2 | RODIV1 | RODIV0 | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | | Legend: | | | | |-------------------|------------------|----------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, rea | d as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15 **ROEN:** Reference Oscillator Output Enable bit 1 = Reference Oscillator is enabled on the REFO pin 0 = Reference Oscillator is disabled bit 14 Unimplemented: Read as '0' bit 13 ROSSLP: Reference Oscillator Output Stop in Sleep bit 1 = Reference Oscillator continues to run in Sleep 0 = Reference Oscillator is disabled in Sleep bit 12 **ROSEL:** Reference Oscillator Source Select bit 1 = Primary Oscillator is used as the base clock<sup>(1)</sup> 0 = System clock is used as the base clock; base clock reflects any clock switching of the device bit 11-8 RODIV[3:0]: Reference Oscillator Divisor Select bits 1111 = Base clock value divided by 32,768 1110 = Base clock value divided by 16,384 1101 = Base clock value divided by 8,192 1100 = Base clock value divided by 4,096 1011 = Base clock value divided by 2,048 1010 = Base clock value divided by 1,024 1001 = Base clock value divided by 512 1000 = Base clock value divided by 256 0111 = Base clock value divided by 128 0110 = Base clock value divided by 64 0101 = Base clock value divided by 32 0100 = Base clock value divided by 16 0011 = Base clock value divided by 8 0010 = Base clock value divided by 4 0001 = Base clock value divided by 2 0000 = Base clock value bit 7-0 Unimplemented: Read as '0' Note 1: The crystal oscillator must be enabled using the FOSC[2:0] bits; the crystal maintains the operation in Sleep mode. #### 10.0 POWER-SAVING FEATURES Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information, refer to "Power-Saving Features with VBAT" (www.microchip.com/30622) in the "dsPIC33/PIC24F Family Reference Manual". This FRM describes some features which are not implemented in this device. Sections related to the VBAT pin and Deep Sleep do not apply to the PIC24FV16KM204 family. The PIC24FV16KM204 family of devices provides 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 circuits being clocked constitutes lower consumed power. All PIC24F devices manage power consumption in four different 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. #### 10.1 Clock Frequency and Clock Switching PIC24F devices allow for 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. The process of changing a system clock during operation, as well as limitations to the process, are discussed in more detail in Section 9.0 "Oscillator Configuration". # 10.2 Instruction-Based Power-Saving Modes PIC24F 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 'C' syntax of the PWRSAV instruction is shown in Example 10-1. Note: SLEEP\_MODE and IDLE\_MODE 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". #### 10.2.1 SLEEP MODE Sleep mode includes these features: - The system clock source is shut down. If an on-chip oscillator is used, it is turned off. - The device current consumption will be reduced to a minimum provided that no I/O pin is sourcing current - The I/O pin directions and states are frozen. - The Fail-Safe Clock Monitor does not operate during Sleep mode since the system clock source is disabled. - The LPRC clock will continue to run in Sleep mode if the WDT or RTCC with LPRC as the clock source is enabled. - The WDT, if enabled, is automatically cleared prior to entering Sleep mode. - Some device features or peripherals may continue to operate in Sleep mode. 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 will be disabled in Sleep mode. The device will wake-up from Sleep mode on any of these events: - On any interrupt source that is individually enabled - · On any form of device Reset - · On a WDT time-out On wake-up from Sleep, the processor will restart with the same clock source that was active when Sleep mode was entered. #### **EXAMPLE 10-1:** 'C' POWER-SAVING ENTRY ``` Sleep(); //Put the device into Sleep mode Idle(); //Put the device into Idle mode ``` #### 10.2.2 IDLE MODE Idle mode includes these features: - · The CPU will stop 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 Section 10.6 "Selective Peripheral Module Control"). - If the WDT or FSCM is enabled, the LPRC will also remain active. The device will wake 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, the clock is reapplied to the CPU and instruction execution begins immediately, starting with the instruction following the PWRSAV instruction or the first instruction in the ISR. # 10.2.3 INTERRUPTS COINCIDENT WITH POWER SAVE INSTRUCTIONS Any interrupt that coincides with the execution of a PWRSAV instruction will be held off until entry into Sleep or Idle mode has completed. The device will then wake-up from Sleep or Idle mode. #### 10.2.3.1 Power-on Resets (PORs) VDD voltage is monitored to produce PORs. When a true POR occurs, the entire device is reset. #### 10.3 Ultra Low-Power Wake-up The Ultra Low-Power Wake-up (ULPWU) on pin, RB0, allows a slow falling voltage to generate an interrupt without excess current consumption. To use this feature: - Charge the capacitor on RB0 by configuring the RB0 pin to an output and setting it to '1'. - Stop charging the capacitor by configuring RB0 as an input. - Discharge the capacitor by setting the ULPEN and ULPSINK bits in the ULPWCON register. - 4. Configure Sleep mode. - 5. Enter Sleep mode. When the voltage on RB0 drops below VIL, the device wakes up and executes the next instruction. This feature provides a low-power technique for periodically waking up the device from Sleep mode. The time-out is dependent on the discharge time of the RC circuit on RB0. When the ULPWU module wakes the device from Sleep mode, the ULPWUIF bit (IFS5[0]) is set. Software can check this bit upon wake-up to determine the wake-up source. See Example 10-2 for initializing the ULPWU module. # EXAMPLE 10-2: ULTRA LOW-POWER WAKE-UP INITIALIZATION ``` //******** // 1. Charge the capacitor on RBO //********* TRISBbits.TRISB0 = 0; LATBbits.LATB0 = 1; for(i = 0; i < 10000; i++) Nop(); //******** //2. Stop Charging the capacitor on RBO //******** TRISBbits.TRISB0 = 1; //******** //3. Enable ULPWU Interrupt //******** IFS5bits.ULPWUIF = 0; IEC5bits.ULPWUIE = 1; IPC21bits.ULPWUIP = 0x7; //******** //4. Enable the Ultra Low Power Wakeup module and allow capacitor discharge // //******** ULPWCONbits.ULPEN = 1; ULPWCONbit.ULPSINK = 1; //******** //5. Enter Sleep Mode Sleep(); //for sleep, execution will //resume here ``` A series resistor, between RB0 and the external capacitor provides overcurrent protection for the AN2/ULPWU/RB0 pin and enables software calibration of the time-out (see Figure 10-1). #### FIGURE 10-1: SERIES RESISTOR A timer can be used to measure the charge time and discharge time of the capacitor. The charge time can then be adjusted to provide the desired delay in Sleep. This technique compensates for the affects of temperature, voltage and component accuracy. The peripheral can also be configured as a simple, programmable Low-Voltage Detect (LVD) or temperature sensor. #### REGISTER 10-1: ULPWCON: ULPWU CONTROL REGISTER | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | |--------|-----|---------|-----|-----|-----|-----|---------| | ULPEN | _ | ULPSIDL | _ | _ | _ | _ | ULPSINK | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **ULPEN:** ULPWU Module Enable bit 1 = Module is enabled0 = Module is disabled bit 14 Unimplemented: Read as '0' bit 13 ULPSIDL: ULPWU Stop in Idle Select bit 1 = Discontinues module operation when the device enters Idle mode 0 = Continues module operation in Idle mode bit 12-9 Unimplemented: Read as '0' bit 8 **ULPSINK:** ULPWU Current Sink Enable bit 1 = Current sink is enabled0 = Current sink is disabled bit 7-0 **Unimplemented:** Read as '0' #### 10.4 Voltage Regulator-Based Power-Saving Features The PIC24FV16KM204 family series devices have a voltage regulator that has the ability to alter functionality to provide power savings. The on-chip regulator is made up of two basic modules: the Voltage Regulator (VREG) and the Retention Regulator (RETREG). With the combination of VREG and RETREG, the following power modes are available: #### 10.4.1 RUN MODE In Run mode, the main VREG is providing a regulated voltage with enough current to supply a device running at full speed and the device is not in Sleep mode. The RETREG may or may not be running, but is unused. #### 10.4.2 SLEEP MODE In Sleep mode, the device is in Sleep and the main VREG is providing a regulated voltage to the core. By default, in Sleep mode, the regulator enters a Low-Power Standby state which consumes reduced quiescent current. The PMSLP bit (RCON[8]) controls the regulator state in Sleep mode. If the PMSLP bit is set, the program Flash memory will stay powered on during Sleep mode and the regulator will stay in its full-power mode. #### 10.4.3 RETENTION REGULATOR The Retention Regulator, sometimes referred to as the low-voltage regulator, is designed to provide power to the core at a lower voltage than the standard voltage regulator, while consuming significantly lower quiescent current. Refer to **Section 27.0** "Electrical Characteristics" for the voltage output range of the RETREG. This regulator is only used in Sleep mode, and has limited output current to maintain the RAM and provide power for limited peripherals, such as the WDT, while the device is in Sleep. It is controlled by the RETCFG Configuration bit (FPOR[2]) and in firmware by the RETEN bit (RCON[12]). RETCFG must be programmed (= 0) and the RETEN bit must be set (= 1) for the Retention Regulator to be enabled. #### 10.4.4 RETENTION SLEEP MODE In Retention Sleep mode, the device is in Sleep and all regulated voltage is provided solely by the RETREG, while the main VREG is disabled. Consequently, this mode provides the lowest Sleep power consumption, but has a trade-off of a longer wake-up time. The low-voltage Sleep wake-up time is longer than Sleep mode due to the extra time required to re-enable the VREG and raise the VDDCORE supply rail back to normal regulated levels. Note: The PIC24F16KM204 family devices do not have any internal voltage regulation, and therefore, do not support Retention Sleep mode. TABLE 10-1: VOLTAGE REGULATION CONFIGURATION SETTINGS FOR PIC24FXXXXX FAMILY DEVICES | RETCFG Bit<br>(FPOR[2]) | RETEN Bit<br>(RCON[12] | PMSLP Bit<br>(RCON[8]) | Power Mode<br>During Sleep | Description | |-------------------------|------------------------|------------------------|----------------------------|----------------------------------------------------------| | 0 | 0 | 1 | Sleep | VREG mode (normal) is unchanged during Sleep. | | | | | | RETREG is unused. | | 0 | 0 | 0 | Sleep | VREG goes to Low-Power Standby mode during Sleep. | | | | | (Standby) | RETREG is unused. | | 0 | 1 | 0 | Retention | VREG is off during Sleep. | | | | | Sleep | RETREG is enabled and provides Sleep voltage regulation. | | 1 | х | 1 | Sleep | VREG mode (normal) is unchanged during Sleep. | | | | | | RETREG is disabled at all times. | | 1 | Х | 0 | Sleep | VREG goes to Low-Power Standby mode during Sleep. | | | | | (Standby) | RETREG is disabled at all times. | #### 10.5 Doze Mode Generally, changing clock speed and invoking one of the power-saving modes are the preferred strategies for reducing power consumption. There may be circumstances, however, where this is not 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 may introduce communication errors, while using a power-saving mode may 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. It is also possible to 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. Meanwhile, the CPU Idles, waiting for something to invoke an interrupt routine. Enabling the automatic return to full-speed CPU operation on interrupts is enabled by setting the ROI bit (CLKDIV[15]). By default, interrupt events have no effect on Doze mode operation. # 10.6 Selective Peripheral Module Control Idle and Doze modes allow users to substantially reduce power consumption by slowing or stopping the CPU clock. Even so, peripheral modules still remain clocked, and thus, consume power. There may be cases where the application needs what these modes do not provide: the allocation of power resources to CPU processing with minimal power consumption from the peripherals. PIC24F devices address this requirement by allowing peripheral modules to be selectively disabled, reducing or eliminating their power consumption. This can be done with two control bits: - The Peripheral Enable bit, generically named, "XXXEN", located in the module's main control SER - The Peripheral Module Disable (PMD) bit, generically named, "XXXMD", located in one of the PMDx Control registers. Both bits have similar functions in enabling or disabling its associated module. Setting the PMDx bits for a module, disables all clock sources to that module, reducing its power consumption to an absolute minimum. In this state, the control and status registers associated with the peripheral will also be disabled, so writes to those registers will have no effect, and read values will be invalid. Many peripheral modules have a corresponding PMDx bit. In contrast, disabling a module by clearing its XXXEN bit, disables its functionality, but leaves its registers available to be read and written to. Power consumption is reduced, but not by as much as when the PMDx bits are used. Most peripheral modules have an enable bit; exceptions include capture, compare and RTCC. To achieve more selective power savings, peripheral modules can also be selectively disabled when the device enters Idle mode. This is done through the control bit of the generic name format, "XXXIDL". By default, all modules that can operate during Idle mode will do so. Using the disable on Idle feature disables the module while in Idle mode, allowing further reduction of power consumption during Idle mode, enhancing power savings for extremely critical power applications. NOTES: #### 11.0 I/O PORTS Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the I/O ports, refer to "I/O Ports with Peripheral Pin Select (PPS)" (www.microchip.com/DS30009711) in the "dsPIC33/PIC24F Family Reference Manual". Note that the PIC24FV16KM204 family devices do not support Peripheral Pin Select features. All of the device pins (except VDD and Vss) are shared between the peripherals and the parallel I/O ports. All I/O input ports feature Schmitt Trigger inputs for improved noise immunity. #### 11.1 Parallel I/O (PIO) Ports A Parallel I/O port that shares a pin with a peripheral is, in general, subservient to the peripheral. The peripheral's output buffer data and control signals are provided to a pair of multiplexers. The multiplexers select whether the peripheral or the associated port has ownership of the output data and control signals of the I/O pin. The logic also prevents "loop through", in which a port's digital output can drive the input of a peripheral that shares the same pin. Figure 11-1 illustrates how ports are shared with other peripherals and the associated I/O pin to which they are connected. When a peripheral is enabled and the peripheral is actively driving an associated pin, the use of the pin as a general purpose output pin is disabled. The I/O pin may be read, but the output driver for the parallel port bit will be disabled. If a peripheral is enabled, but the peripheral is not actively driving a pin, that pin may be driven by a port. All port pins have three registers directly associated with their operation as digital I/O. The Data Direction register (TRISx) determines whether the pin is an input or an output. If the Data Direction register bit is a '1', then the pin is an input. All port pins are defined as inputs after a Reset. Reads from the Data Latch register (LATx), read the latch. Writes to the latch, write the latch. Reads from the port (PORTx), read the port pins; 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 will be disabled. That means the corresponding LATx and TRISx registers, and the port pin will 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. **Peripheral Module Output Multiplexers** Peripheral Input Data Peripheral Module Enable Peripheral Output Enable Output Enable Peripheral Output Data **PIO Module** Output Data Read TRIS Data Bus D Q I/O Pin WR TRIS CK **₹** TRIS Latch D Q WR LAT + CK 🖳 WR PORT Data Latch Read LAT Input Data Read PORT FIGURE 11-1: BLOCK DIAGRAM OF A TYPICAL SHARED PORT STRUCTURE #### 11.1.1 OPEN-DRAIN CONFIGURATION In addition to the PORT, LAT and TRIS registers for data control, each port pin can also be individually configured for either digital or open-drain output. This is controlled by the Open-Drain Control register, ODCx, associated with each port. Setting any of the bits configures the corresponding pin to act as an open-drain output. The maximum open-drain voltage allowed is the same as the maximum VIH specification. #### 11.2 Configuring Analog Port Pins The use of the ANSx and TRISx registers controls the operation of the A/D port pins. The port pins that are desired as analog inputs must have their corresponding TRISx bit set (input). If the TRISx bit is cleared (output), the digital output level (VOH or VOL) will be converted. When reading the PORTx register, all pins configured as analog input channels will read as cleared (a low level). Analog levels on any pin that is defined as a digital input (including the ANx pins) may cause the input buffer to consume current that exceeds the device specifications. #### 11.2.1 ANALOG SELECTION REGISTER I/O pins with shared analog functionality, such as A/D inputs and comparator inputs, must have their digital inputs shut off when analog functionality is used. Note that analog functionality includes an analog voltage being applied to the pin externally. To allow for analog control, the ANSx registers are provided. There is one ANSx register for each port (ANSA, ANSB and ANSC). Within each ANSx register, there is a bit for each pin that shares analog functionality with the digital I/O functionality. If a particular pin does not have an analog function, that bit is unimplemented. See Register 11-1 to Register 11-3 for implementation. #### REGISTER 11-1: ANSA: PORTA ANALOG SELECTION REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | |-------|-----|-----|-------|-------|--------------------------|-------|-------| | _ | _ | _ | | | ANSA[4:0] <sup>(1)</sup> | | | | bit 7 | | | | | | | bit 0 | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-5 **Unimplemented:** Read as '0' bit 4-0 ANSA[4:0]: Analog Select Control bits<sup>(1)</sup> 1 = Digital input buffer is not active (use for analog input) 0 = Digital input buffer is active Note 1: The ANSA4 bit is not available on 20-pin devices. #### REGISTER 11-2: ANSB: PORTB ANALOG SELECTION REGISTER | R/W-1 | R/W-1 | R/W-1 | R/W-1 | U-0 | U-0 | R/W-1 | R/W-1 | |-------------|-------|-------|-------|-----|-----|-------|--------| | ANSB[15:12] | | | | _ | _ | ANS | B[9:8] | | bit 15 | | | | | | | bit 8 | | R/W-1 |--------------------------|-------|-------|-------|-------|-------|-------|-------| | ANSB[7:0] <sup>(1)</sup> | | | | | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-12 ANSB[15:12]: Analog Select Control bits 1 = Digital input buffer is not active (use for analog input) 0 = Digital input buffer is active bit 11-10 Unimplemented: Read as '0' bit 9-0 ANSB[9:0]: Analog Select Control bits<sup>(1)</sup> 1 = Digital input buffer is not active (use for analog input) 0 = Digital input buffer is active **Note 1:** The ANSB[6:5,3] bits are not available on 20-pin devices. #### REGISTER 11-3: ANSC: PORTC ANALOG SELECTION REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | | |-------|-----|-----|-----|-----|--------------------------|-------|-------|--| | _ | _ | _ | _ | _ | ANSC[2:0] <sup>(1)</sup> | | | | | bit 7 | _ | _ | | _ | bit 0 | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-3 **Unimplemented:** Read as '0' bit 2-0 ANSC[2:0]: Analog Select Control bits<sup>(1)</sup> 1 = Digital input buffer is not active (use for analog input) 0 = Digital input buffer is active Note 1: These bits are not implemented in 20-pin and 28-pin devices. #### 11.2.2 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. #### 11.3 Input Change Notification (ICN) The Input Change Notification function of the I/O ports allows the PIC24FXXXXX family of devices to generate interrupt requests to the processor in response to a Change-of-State (COS) on selected input pins. This feature is capable of detecting input Change-of-States, even in Sleep mode, when the clocks are disabled. Depending on the device pin count, there are up to 37 external signals (CN0 through CN36) that may be selected (enabled) for generating an interrupt request on a Change-of-State. There are six control registers associated with the CN module. The CNEN1 and CNEN3 registers contain the interrupt enable control bits for each of the CNx input pins. Setting any of these bits enables a CN interrupt for the corresponding pins. Each CNx pin also has a weak pull-up/pull-down connected to it. The pull-ups act as a current source that is connected to the pin. The pull-downs act as a current sink to eliminate the need for external resistors when push button or keypad devices are connected. On any pin, only the pull-up resistor or the pull-down resistor should be enabled, but not both of them. If the push button or the keypad is connected to VDD, enable the pull-down, or if they are connected to Vss, enable the pull-up resistors. The pull-ups are enabled separately using the CNPU1 and CNPU3 registers, which contain the control bits for each of the CNx pins. Setting any of the control bits enables the weak pull-ups for the corresponding pins. The pull-downs are enabled separately using the CNPD1 and CNPD3 registers, which contain the control bits for each of the CNx pins. Setting any of the control bits enables the weak pull-downs for the corresponding pins. When the internal pull-up is selected, the pin uses VDD as the pull-up source voltage. When the internal pull-down is selected, the pins are pulled down to Vss by an internal resistor. Make sure that there is no external pull-up source/pull-down sink when the internal pull-ups/pull-downs are enabled. Note: Pull-ups and pull-downs on Change Notification (CN) pins should always be disabled whenever the port pin is configured as a digital output. #### EXAMPLE 11-1: PORT WRITE/READ EXAMPLE ``` MOV 0xFF00, W0; //Configure PORTB[15:8] as inputs and PORTB[7:0] as outputs MOV WO, TRISB; NOP: //Delay 1 cycle PORTB, #13; //Next Instruction BTSS Equivalent 'C' Code TRISB = 0xFF00; //Configure PORTB[15:8] as inputs and PORTB[7:0] as outputs NOP(): //Delay 1 cycle if(PORTBbits.RB13 == 1) // execute following code if PORTB pin 13 is set. } ``` #### 12.0 TIMER1 Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on timers, refer to "Timers" (www.microchip.com/DS39704) in the "dsPIC33/PIC24F Family Reference Manual". The Timer1 module is a 16-bit timer which operates as a free-running, interval timer/counter. Timer1 can operate in three modes: - · 16-Bit Timer - · 16-Bit Synchronous Counter - 16-Bit Asynchronous Counter Timer1 also supports these features: - · Timer Gate Operation - · Selectable Prescaler Settings - Timer Operation During CPU Idle and Sleep modes - Interrupt on 16-Bit Period Register Match or Falling Edge of External Gate Signal Figure 12-1 illustrates a block diagram of the 16-bit Timer1 module. To configure Timer1 for operation: - 1. Set the TON bit (= 1). - 2. Select the timer prescaler ratio using the TCKPS[1:0] bits. - Set the Clock and Gating modes using the TCS and TGATE bits. - 4. Set or clear the TSYNC bit to configure synchronous or asynchronous operation. - Load the timer period value into the PR1 register. - 6. If interrupts are required, set the Timer1 Interrupt Enable bit, T1IE. Use the Timer1 Interrupt Priority bits, T1IP[2:0], to set the interrupt priority. FIGURE 12-1: 16-BIT TIMER1 MODULE BLOCK DIAGRAM #### REGISTER 12-1: T1CON: TIMER1 CONTROL REGISTER | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | |--------|-----|-------|-----|-----|-----|----------------------|----------------------| | TON | _ | TSIDL | _ | _ | _ | TECS1 <sup>(1)</sup> | TECS0 <sup>(1)</sup> | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | |-------|-------|--------|--------|-----|-------|-------|-------| | _ | TGATE | TCKPS1 | TCKPS0 | _ | TSYNC | TCS | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 TON: Timer1 On bit 1 = Starts 16-bit Timer1 0 = Stops 16-bit Timer1 bit 14 **Unimplemented:** Read as '0' bit 13 TSIDL: Timer1 Stop in Idle Mode bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode bit 12-10 Unimplemented: Read as '0' bit 9-8 **TECS[1:0]:** Timer1 Extended Clock Select bits<sup>(1)</sup> 11 = Reserved; do not use 10 = Timer1 uses the LPRC as the clock source 01 = Timer1 uses the External Clock (EC) from T1CK 00 = Timer1 uses the Secondary Oscillator (SOSC) as the clock source bit 7 **Unimplemented:** Read as '0' bit 6 TGATE: Timer1 Gated Time Accumulation Enable bit When TCS = 1: This bit is ignored. When TCS = 0: 1 = Gated time accumulation is enabled0 = Gated time accumulation is disabled bit 5-4 TCKPS[1:0]: Timer1 Input Clock Prescale Select bits 11 = 1:256 10 = 1:64 01 = 1:8 00 = 1:1 bit 3 **Unimplemented:** Read as '0' bit 2 TSYNC: Timer1 External Clock Input Synchronization Select bit When TCS = 1: 1 = Synchronizes External Clock input 0 = Does not synchronize External Clock input When TCS = 0: This bit is ignored. bit 1 TCS: Timer1 Clock Source Select bit 1 = Timer1 clock source is selected by TECS[1:0] 0 = Internal clock (Fosc/2) bit 0 **Unimplemented:** Read as '0' **Note 1:** The TECSx bits are valid only when TCS = 1. #### 13.0 CAPTURE/COMPARE/PWM/ **TIMER MODULES (MCCP AND** SCCP) Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the MCCP/SCCP modules, refer to "Capture/Compare/PWM/ Timer (MCCP and SCCP)" (www.microchip.com/DS30003035) in the "dsPIC33/PIC24F Family Reference PIC24FV16KM204 family devices include several Capture/Compare/PWM/Timer base modules, which provide the functionality of three different peripherals of earlier PIC24F devices. The module can operate in one of three major modes: · General Purpose Timer Manual". - · Input Capture - Output Compare/PWM The module is provided in two different forms, distinquished by the number of PWM outputs that the module can generate. Single output modules (SCCPs) provide only one PWM output. Multiple output modules (MCCPs) can provide up to six outputs and an extended range of power control features, depending on the pin count of the particular device. All other features of the modules are identical. The SCCP and MCCP modules 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 13-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 seven control and status registers: - CCPxCON1L (Register 13-1) - CCPxCON1H (Register 13-2) - CCPxCON2L (Register 13-3) - CCPxCON2H (Register 13-4) - CCPxCON3L (Register 13-5) - CCPxCON3H (Register 13-6) - CCPxSTATL (Register 13-7) Each module also includes eight buffer/counter registers that serve as Timer Value registers or data holding buffers: - CCPxTMRH/CCPxTMRL (Timer High/Low Counters) - CCPxPRH/CCPxPRL (Timer Period High/Low) - CCPxRA (Primary Output Compare Data Buffer) - CCPxRB (Secondary Output Compare Data Buffer) - CCPxBUFH/CCPxBUFL (Input Capture High/Low Buffers) **FIGURE 13-1:** MCCPx/SCCPx CONCEPTUAL BLOCK DIAGRAM #### 13.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 13-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 and LPRC, the Secondary Oscillator, and the TCLKI External Clock inputs. The system clock is the default source (CLKSEL[2:0] = 000). On PIC24FV16KM204 family devices, clock sources to the MCCPx module must be synchronized with the system clock; as a result, when clock sources are selected, clock input timing restrictions or module operating restrictions may exist. Table 13-1 describes which time base sources are valid for the various operating modes. TABLE 13-1: VALID TIMER OPTIONS FOR MCCPx/SCCPx MODES | CLKSEL | Tir | ner | Input | Output | |----------------------|---------------------|----------------------|---------|---------| | [2:0] <sup>(1)</sup> | Sync <sup>(2)</sup> | Async <sup>(3)</sup> | Capture | Compare | | 111 | Х | _ | | | | 110 | Х | _ | _ | _ | | 101 | Х | _ | _ | _ | | 011 | Х | _ | _ | _ | | 010 | Х | _ | _ | _ | | 001 | Х | _ | _ | _ | | 000(4) | _ | Х | Х | Х | - **Note 1:** See Register 13-1 for the description of the time base sources. - 2: Synchronous Operation: TMRSYNC (CCPxCON1L[11]) = 1 and TRIGEN (CCPxCON1H[7]) = 0. - **3:** Asynchronous Operation: (TMRSYNC = 0) or Triggered mode (TRIGEN = 1). - **4:** When CLKSEL[2:0] = 000, the TMRSYNC bit must be cleared. FIGURE 13-2: TIMER CLOCK GENERATOR #### 13.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 13-2). **TABLE 13-2: TIMER OPERATION MODE** | T32<br>(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 MCCPx Sync out signals for use by other MCCP 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. 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. #### 13.2.1 SYNC AND TRIGGER OPERATION In both 16-bit and 32-bit modes, the timer can also function in either Synchronization ("Sync") or Trigger operation. Both use the SYNC[4:0] bits (CCPxCON1H[4:0]) to determine the input signal source. The difference is how that signal affects the timer. In Sync operation, the timer Reset or clear occurs when the input selected by SYNC[4:0] is asserted. The timer immediately begins to count again from zero unless it is held for some other reason. Sync operation is used whenever the TRIGEN bit (CCPxCON1H[7]) is cleared. SYNC[4:0] can have any value except '11111'. In Trigger operation, the timer is held in Reset until the input selected by SYNC[4:0] is asserted; when it occurs, the timer starts counting. Trigger operation is used whenever the TRIGEN bit is set. In Trigger mode, the timer will continue running after a Trigger event as long as the CCPTRIG bit (CCPxSTATL[7]) is set. To clear CCPTRIG, the TRCLR bit (CCPxSTATL[5]) must be set to clear the Trigger event, reset the timer and hold it at zero until another Trigger event occurs. On PIC24FV16KM204 family devices, Trigger operation can only be used when the system clock is the time base source (CLKSEL[2:0] = 000). FIGURE 13-3: DUAL 16-BIT TIMER MODE #### FIGURE 13-4: 32-BIT TIMER MODE ### 13.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 13-3 shows the various modes available in Output Compare modes. TABLE 13-3: OUTPUT COMPARE/PWM MODES | MOD[3:0]<br>(CCPxCON1L[3:0]) | T32<br>(CCPxCON1L[5]) | Operating Mode | | | | |------------------------------|-----------------------|----------------------------------------|---------------------------|--|--| | 0001 | 0 | Output High on Compare (16-bit) | | | | | 0001 | 1 | Output High on Compare (32-bit) | | | | | 0010 | 0 | Output Low on Compare (16-bit) | Cinale Edge Mede | | | | 0010 | 1 | Output Low on Compare (32-bit) | Single Edge Mode | | | | 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 | | | | 0110 | 0 | Center-Aligned Pulse (16-bit buffered) | Center PWM <sup>(1)</sup> | | | | 0111 | 0 | Variable Frequency Pulse (16-bit) | | | | | 0111 | 1 | Variable Frequency Pulse (32-bit) | | | | Note 1: Center-Aligned PWM mode is disabled on SCCP. Please use MCCP instead. **FIGURE 13-5: OUTPUT COMPARE x BLOCK DIAGRAM** ### 13.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 13-6 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 register. 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 13-4. **TABLE 13-4: INPUT CAPTURE MODES** | MOD[3:0]<br>(CCPxCON1L[3:0]) | T32<br>(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) | | | | | 0010 | 1 | Every Falling (32-bit capture) | | | | | 0011 | 0 | Every Rise/Fall (16-bit capture) | | | | | 0011 | 1 | Every Rise/Fall (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 13-6: INPUT CAPTURE x BLOCK DIAGRAM ### 13.5 Auxiliary Output The MCCPx and 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 MCCP or 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. On the PIC24FV16KM204 family of devices, only the CTMU discharge trigger has access to the auxiliary output signal. **TABLE 13-5: AUXILIARY OUTPUT** | AUXOUT[1:0] | CCSEL | MOD[3:0] | Comments | Signal Description | |-------------|-------|----------|---------------------------|-------------------------------------| | 00 | Х | 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 | #### REGISTER 13-1: CCPxCON1L: CCPx CONTROL 1 LOW REGISTERS | R/W-0 | U-0 | R/W-0 | r-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|---------|-----|---------|------------------------|------------------------|------------------------| | CCPON | _ | CCPSIDL | _ | TMRSYNC | CLKSEL2 <sup>(1)</sup> | CLKSEL1 <sup>(1)</sup> | CLKSEL0 <sup>(1)</sup> | | bit 15 | | | | | | | bit 8 | | R/W-0 |--------|--------|-------|-------|-------|-------|-------|-------| | TMRPS1 | TMRPS0 | T32 | CCSEL | MOD3 | MOD2 | MOD1 | MOD0 | | bit 7 | | | | | | | bit 0 | | Legend: | r = Reserved bit | | | |-------------------|------------------|-----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit | t, read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15 CCPON: CCPx Module Enable bit 1 = Module is enabled with an operating mode specified by the MOD[3:0] control bits 0 = Module is disabled bit 14 Unimplemented: Read as '0' bit 13 CCPSIDL: CCPx Stop in Idle Mode Bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode bit 12 Reserved: Maintain as '0' bit 11 TMRSYNC: Time Base Clock Synchronization bit 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) bit 10-8 CLKSEL[2:0]: CCPx Time Base Clock Select bits<sup>(1)</sup> 111 = External TCKIA input 110 = External TCKIB input 101 **= CLC1** 100 = Reserved 011 = LPRC (31 kHz source) 010 = Secondary Oscillator 001 = Reserved 000 = Peripheral clock (Tcy) bit 7-6 TMRPS[1:0]: Time Base Prescale Select bits 11 = 1:64 Prescaler 10 = 1:16 Prescaler 01 = 1:4 Prescaler 00 = 1:1 Prescaler bit 5 T32: 32-Bit Time Base Select bit 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 1 = Input Capture peripheral 0 = Output Compare/PWM/Timer peripheral (exact function is selected by the MOD[3:0] bits) **Note 1:** Clock options are limited in some operating modes. See Table 13-1 for restrictions. ### REGISTER 13-1: CCPxCON1L: CCPx CONTROL 1 LOW REGISTERS (CONTINUED) bit 3-0 MOD[3:0]: CCPx Mode Select bits For CCSEL = 1 (Input Capture modes): 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): 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 0110 = Center-Aligned Pulse Compare mode, buffered 0101 = Dual Edge Compare mode, buffered 0100 = Dual Edge Compare mode > 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 0011 = 16-Bit/32-Bit Single Edge mode, toggles output on compare match 0000 = 16-Bit/32-Bit Timer mode, output functions are disabled Note 1: Clock options are limited in some operating modes. See Table 13-1 for restrictions. #### REGISTER 13-2: CCPxCON1H: CCPx CONTROL 1 HIGH REGISTERS | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-----------------------|-----------------------|-----|-----|---------------------|---------------------|---------------------|---------------------| | OPSSRC <sup>(1)</sup> | RTRGEN <sup>(2)</sup> | _ | _ | OPS3 <sup>(3)</sup> | OPS2 <sup>(3)</sup> | OPS1 <sup>(3)</sup> | OPS0 <sup>(3)</sup> | | bit 15 | | | | | | | bit 8 | | R/W-0 |-----------------------|---------|---------|-------|-------|-------|-------|-------| | TRIGEN <sup>(4)</sup> | ONESHOT | ALTSYNC | SYNC4 | SYNC3 | SYNC2 | SYNC1 | SYNC0 | | bit 7 | | | | | | | bit 0 | | Legend: | | | | | | |-------------------|-----------------------------------------------------|----------------------|--------------------|--|--| | R = Readable bit | W = Writable bit U = Unimplemented bit, read as '0' | | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | | bit 15 **OPSSRC:** Output Postscaler Source Select bit<sup>(1)</sup> 1 = Output postscaler scales module Trigger output events 0 = Output postscaler scales time base interrupt events bit 14 RTRGEN: Retrigger Enable bit<sup>(2)</sup> 1 = Time base can be retriggered when TRIGEN bit = 1 0 = Time base may not be retriggered when TRIGEN bit = 1 bit 13-12 Unimplemented: Read as '0' bit 11-8 **OPS3[3:0]:** CCPx Interrupt Output Postscale Select bits<sup>(3)</sup> 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 (4) 1 = Trigger operation of time base is enabled 0 = Trigger operation of time base is disabled bit 6 ONESHOT: One-Shot Mode Enable bit 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 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 bit 4-0 SYNC[4:0]: CCPx Synchronization Source Select bits See Table 13-6 for the definition of inputs. **Note 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. 4: Clock source options are limited when Trigger operation is enabled; refer to Table 13-1. TABLE 13-6: SYNCHRONIZATION SOURCES | SYNC[4:0] | Synchronization Source | |-----------------------|----------------------------------------------------| | 00000 | None; Timer with Rollover on CCPxPR Match or FFFFh | | 00001 | MCCP1 or SCCP1 Sync Output | | 00010 | MCCP2 or SCCP2 Sync Output | | 00011 | MCCP3 or SCCP3 Sync Output | | 00100 | MCCP4 or SCCP4 Sync Output | | 00101 | MCCP5 or SCCP5 Sync Output | | 00110 <b>to</b> 01010 | Unused | | 01011 | Timer1 Sync Output <sup>(1)</sup> | | 01100 <b>to</b> 01111 | Unused | | 10000 | CLC1 Output <sup>(1)</sup> | | 10001 | CLC2 Output <sup>(1)</sup> | | 10010 <b>to</b> 11010 | Unused | | 11011 | A/D <sup>(1)</sup> | | 11110 | Unused | | 11111 | None; Timer with Auto-Rollover (FFFFh → 0000h) | Note 1: These sources are only available when the source module is being used in a Synchronous mode. #### REGISTER 13-3: CCPxCON2L: CCPx CONTROL 2 LOW REGISTERS | | R/W-0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |---|---------|-------|-----|-------|-----|-----|-----|-------| | ſ | PWMRSEN | ASDGM | _ | SSDG | _ | _ | _ | _ | | ſ | bit 15 | | | | | | | bit 8 | | R/W-0 | | | | |-------|-------------|-------|-------|-------|-------|-------|-------|--|--|--|--| | | ASDG[7:0] | | | | | | | | | | | | bit 7 | bit 7 bit 0 | | | | | | | | | | | | Legend: | | | | |-------------------|------------------|-----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit | t, read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15 **PWMRSEN:** CCPx PWM Restart Enable bit 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 1 = Waits until the next Time Base Reset or rollover for shutdown to occur 0 = Shutdown event occurs immediately bit 13 **Unimplemented:** Read as '0' bit 12 SSDG: CCPx Software Shutdown/Gate Control bit 1 = Manually forces auto-shutdown, timer clock gate or input capture signal gate event (setting of ASDGM bit still applies) 0 = Normal module operation bit 11-8 **Unimplemented:** Read as '0' bit 7-0 ASDG[7:0]: CCPx Auto-Shutdown/Gating Source Enable bits 1 = ASDGx Source n is enabled (see Table 13-7 for auto-shutdown/gating sources) 0 = ASDGx Source n is disabled #### TABLE 13-7: AUTO-SHUTDOWN AND GATING SOURCES | ASDG[7:0] Bits | Auto-Shutdown/Gating Source | | | | | |----------------|-----------------------------|--|--|--|--| | 0 | Comparator 1 Output | | | | | | 1 | Comparator 2 Output | | | | | | 2 | Comparator 3 Output | | | | | | 3 | SCCP4 Output Compare | | | | | | 4 | SCCP5 Output Compare | | | | | | 5 | CLC1 Output | | | | | | 6 | OCFA Fault Input | | | | | | 7 | OCFB Fault Input | | | | | #### REGISTER 13-4: CCPxCON2H: CCPx CONTROL 2 HIGH REGISTERS | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-1 | |---------|-----|----------------------|----------------------|----------------------|----------------------|----------------------|-------| | OENSYNC | _ | OCFEN <sup>(1)</sup> | OCEEN <sup>(1)</sup> | OCDEN <sup>(1)</sup> | OCCEN <sup>(1)</sup> | OCBEN <sup>(1)</sup> | OCAEN | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|--------|-----|---------|---------|-------|-------|-------| | ICGSM1 | ICGSM0 | _ | AUXOUT1 | AUXOUT0 | ICS2 | ICS1 | ICS0 | | bit 7 | | • | | | | | bit 0 | **Legend:**R = Readable bit W = Writable bit -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **OENSYNC:** Output Enable Synchronization bit 1 = Update by output enable bits occurs on the next Time Base Reset or rollover 0 = Update by output enable bits occurs immediately bit 14 **Unimplemented:** Read as '0' bit 13-8 **OC[F:A]EN:** Output Enable/Steering Control bits<sup>(1)</sup> 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 U = Unimplemented bit, read as '0' bit 7-6 ICGSM[1:0]: Input Capture Gating Source Mode Control bits 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 bit 5 Unimplemented: Read as '0' bit 4-3 AUXOUT[1:0]: Auxiliary Output Signal on Event Selection bits 11 = Input capture or output compare event; no signal in Timer mode 10 = Signal output is defined by module operating mode (see Table 13-5) 01 = Time base rollover event (all modes) 00 = Disabled bit 2-0 ICS[2:0]: Input Capture Source Select bits 111 = Unused 110 = CLC2 output 101 = CLC1 output 100 = Unused 011 = Comparator 3 output 010 = Comparator 2 output 001 = Comparator 1 output 000 = Input Capture x (ICx) I/O pin Note 1: OCFEN through OCBEN (bits[13:9]) are implemented in MCCPx modules only. ### REGISTER 13-5: CCPxCON3L: CCPx CONTROL 3 LOW REGISTERS (1) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-------|-------|-------|-------|-------|-------| | _ | _ | | | DT[ | 5:0] | | | | bit 7 | | • | | | | | bit 0 | | Legend: | | | | |-------------------|------------------|-----------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read | d as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15-6 **Unimplemented:** Read as '0' bit 5-0 **DT[5:0]:** CCPx Dead-Time Select bits 111111 = Inserts 63 dead-time delay periods between complementary output signals 111110 = Inserts 62 dead-time delay periods between complementary output signals . . . 000010 = Inserts 2 dead-time delay periods between complementary output signals 000001 = Inserts 1 dead-time delay period between complementary output signals 000000 = Dead-time logic is disabled Note 1: This register is implemented in MCCPx modules only. #### REGISTER 13-6: CCPxCON3H: CCPx CONTROL 3 HIGH REGISTERS | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |--------|--------|--------|--------|-----|----------------------|----------------------|----------------------| | OETRIG | OSCNT2 | OSCNT1 | OSCNT0 | _ | OUTM2 <sup>(1)</sup> | OUTM1 <sup>(1)</sup> | OUTM0 <sup>(1)</sup> | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|--------|-----------------------|---------|---------|------------------------|------------------------| | _ | _ | POLACE | POLBDF <sup>(1)</sup> | PSSACE1 | PSSACE0 | PSSBDF1 <sup>(1)</sup> | PSSBDF0 <sup>(1)</sup> | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **OETRIG:** CCPx Dead-Time Select bit 1 = For Triggered mode (TRIGEN = 1): Module does not drive enabled output pins until triggered 0 = Normal output pin operation bit 14-12 OSCNT[2:0]: One-Shot Event Count bits 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 11 **Unimplemented:** Read as '0' bit 10-8 OUTM[2:0]: PWMx Output Mode Control bits<sup>(1)</sup> 111 = Reserved 110 = Output Scan mode 101 = Brush DC Output mode, forward 100 = Brush DC Output mode, reverse 011 = Reserved 010 = Half-Bridge Output mode 001 = Push-Pull Output mode 000 = Steerable Single Output mode bit 7-6 **Unimplemented:** Read as '0' bit 5 **POLACE:** CCPx Output Pins, OCxA, OCxC and OCxE, Polarity Control bit 1 = Output pin polarity is active-low 0 = Output pin polarity is active-high bit 4 **POLBDF:** CCPx Output Pins, OCxB, OCxD and OCxF, Polarity Control bit<sup>(1)</sup> 1 = Output pin polarity is active-low 0 = Output pin polarity is active-high bit 3-2 PSSACE[1:0]: PWMx Output Pins, OCxA, OCxC and OCxE, Shutdown State Control bits 11 = Pins are driven active when a shutdown event occurs 10 = Pins are driven inactive when a shutdown event occurs 0x = Pins are tri-stated when a shutdown event occurs bit 1-0 **PSSBDF[1:0]:** PWMx Output Pins, OCxB, OCxD, and OCxF, Shutdown State Control bits<sup>(1)</sup> 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 Note 1: These bits are implemented in MCCPx modules only. #### REGISTER 13-7: CCPxSTATL: CCPx STATUS REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R-0 | W1-0 | W1-0 | R/C-0 | R/C-0 | R/C-0 | R/C-0 | R/C-0 | |---------|-------|-------|-------|-------|-------|-------|-------| | CCPTRIG | TRSET | TRCLR | ASEVT | SCEVT | ICDIS | ICOV | ICBNE | | bit 7 | | | | | | | bit 0 | | Legend: | C = Clearable bit | | | |-------------------|---------------------|----------------------------|--------------------| | R = Readable bit | W1 = Write '1' only | U = Unimplemented bit, rea | d as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15-8 Unimplemented: Read as '0' bit 7 **CCPTRIG:** CCPx Trigger Status bit 1 = Timer has been triggered and is running 0 = Timer has not been triggered and is held in Reset TRSET: CCPx Trigger Set Request bit bit 6 Write '1' to this location to trigger the timer when TRIGEN = 1 (location always reads as '0'). bit 5 TRCLR: CCPx Trigger Clear Request bit Write '1' to this location to cancel the timer Trigger when TRIGEN = 1 (location always reads as '0'). ASEVT: CCPx Auto-Shutdown Event Status/Control bit bit 4 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 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 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 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 1 = Input Capture x buffer has data available 0 = Input Capture x buffer is empty | PIC24F | V16KN | /1204 I | FAMIL | .Y | | | |--------|-------|---------|-------|----|--|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 14.0 MASTER SYNCHRONOUS SERIAL PORT (MSSP) Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on MSSP, refer to "Master Synchronous Serial Port (MSSP)" (www.microchip.com/DS30627) in the "dsPIC33/PIC24F Family Reference Manual". The Master Synchronous Serial Port (MSSP) module is an 8-bit 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 MSSP module can operate in one of two modes: - Serial Peripheral Interface (SPI) - Inter-Integrated Circuit (I<sup>2</sup>C) - Full Master mode - Slave mode (with general address call) The SPI interface supports these modes in hardware: - · Master mode - · Slave mode - · Daisy-Chaining Operation in Slave mode - · Synchronized Slave Operation The I<sup>2</sup>C interface supports the following modes in hardware: - · Master mode - Multi-Master mode - Slave mode with 10-Bit and 7-Bit Addressing and Address Masking - Byte NACKing - Selectable Address and Data Hold, and Interrupt Masking ### 14.1 I/O Pin Configuration for SPI In SPI Master mode, the MSSP module will assert control over any pins associated with the SDOx and SCKx outputs. This does not automatically disable other digital functions associated with the pin and may result in the module driving the digital I/O port inputs. To prevent this, the MSSP module outputs must be disconnected from their output pins while the module is in SPI Master mode. While disabling the module temporarily may be an option, it may not be a practical solution in all applications. The SDOx and SCKx outputs for the module can be selectively disabled by using the SDOxDIS and SCKxDIS bits in the PADCFG1 register (Register 14-10). Setting the bit disconnects the corresponding output for a particular module from its assigned pin. FIGURE 14-1: MSSPx BLOCK DIAGRAM (SPI MODE) FIGURE 14-2: SPI MASTER/SLAVE CONNECTION FIGURE 14-3: MSSPx BLOCK DIAGRAM (I<sup>2</sup>C MODE) FIGURE 14-4: MSSPx BLOCK DIAGRAM (I<sup>2</sup>C MASTER MODE) ### REGISTER 14-1: SSPxSTAT: MSSPx STATUS REGISTER (SPI MODE) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | |-------|--------------------|-----------------|-----|-----|-----|-----|-------| | SMP | CKE <sup>(1)</sup> | D/ <del>A</del> | Р | S | R/W | UA | BF | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 **Unimplemented:** Read as '0' bit 7 SMP: Sample bit SPI Master mode: 1 = Input data are sampled at the end of data output time0 = Input data are sampled at the middle of data output time SPI Slave mode: SMP must be cleared when SPI is used in Slave mode. bit 6 **CKE:** SPI Clock Select bit<sup>(1)</sup> 1 = Transmit occurs on transition from active to Idle Clock state 0 = Transmit occurs on transition from Idle to Active Clock state bit 5 **D/A:** Data/Address bit Used in I<sup>2</sup>C mode only. bit 4 **P:** Stop bit Used in I<sup>2</sup>C mode only. This bit is cleared when the MSSPx module is disabled; SSPEN bit is cleared. bit 3 S: Start bit Used in I<sup>2</sup>C mode only. bit 2 R/W: Read/Write Information bit Used in I<sup>2</sup>C mode only. bit 1 **UA:** Update Address bit Used in I<sup>2</sup>C mode only. bit 0 BF: Buffer Full Status bit 1 = Receive is complete, SSPxBUF is full 0 = Receive is not complete, SSPxBUF is empty Note 1: Polarity of clock state is set by the CKP bit (SSPxCON1[4]). ### REGISTER 14-2: SSPxSTAT: MSSPx STATUS REGISTER (I<sup>2</sup>C MODE) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R-0 | R-0 | R-0 | R-0 | R-0 | R-0 | |-------|-------|-----|------|------------------|-----|-----|-------| | SMP | CKE | D/A | P(1) | S <sup>(1)</sup> | R/W | UA | BF | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 **Unimplemented:** Read as '0' bit 7 SMP: Slew Rate Control bit In Master or Slave mode: 1 = Slew rate control is disabled for Standard Speed mode (100 kHz and 1 MHz) 0 = Slew rate control is enabled for High-Speed mode (400 kHz) bit 6 **CKE:** SMBus Select bit In Master or Slave mode: 1 = Enables SMBus-specific inputs 0 = Disables SMBus-specific inputs bit 5 D/A: Data/Address bit In Master mode: Reserved. In Slave mode: 1 = Indicates that the last byte received or transmitted was data 0 = Indicates that the last byte received or transmitted was address bit 4 **P:** Stop bit<sup>(1)</sup> 1 = Indicates that a Stop bit has been detected last 0 = Stop bit was not detected last bit 3 S: Start bit<sup>(1)</sup> 1 = Indicates that a Start bit has been detected last 0 = Start bit was not detected last bit 2 R/W: Read/Write Information bit In Slave mode: (2) 1 = Read 0 = Write In Master mode: (3) 1 = Transmit is in progress 0 = Transmit is not in progress bit 1 **UA:** Update Address bit (10-Bit Slave mode only) 1 = Indicates that the user needs to update the address in the SSPxADD register 0 = Address does not need to be updated Note 1: This bit is cleared on Reset and when SSPEN is cleared. 2: This bit holds the R/W bit information following the last address match. This bit is only valid from the address match to the next Start bit, Stop bit or not ACK bit. 3: ORing this bit with SEN, RSEN, PEN, RCEN or ACKEN will indicate if the MSSPx is in Active mode. ### REGISTER 14-2: SSPxSTAT: MSSPx STATUS REGISTER (I<sup>2</sup>C MODE) (CONTINUED) bit 0 **BF:** Buffer Full Status bit #### In Transmit mode: 1 = Transmit is in progress, SSPxBUF is full0 = Transmit is complete, SSPxBUF is empty #### In Receive mode: - 1 = SSPxBUF is full (does not include the $\overline{ACK}$ and Stop bits) 0 = SSPxBUF is empty (does not include the $\overline{ACK}$ and Stop bits) - Note 1: This bit is cleared on Reset and when SSPEN is cleared. - 2: This bit holds the R/W bit information following the last address match. This bit is only valid from the address match to the next Start bit, Stop bit or not ACK bit. - 3: ORing this bit with SEN, RSEN, PEN, RCEN or ACKEN will indicate if the MSSPx is in Active mode. ### REGISTER 14-3: SSPxCON1: MSSPx CONTROL REGISTER 1 (SPI MODE) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|----------------------|----------------------|-------|----------------------|----------------------|----------------------|----------------------| | WCOL | SSPOV <sup>(1)</sup> | SSPEN <sup>(2)</sup> | CKP | SSPM3 <sup>(3)</sup> | SSPM2 <sup>(3)</sup> | SSPM1 <sup>(3)</sup> | SSPM0 <sup>(3)</sup> | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15-8 **Unimplemented:** Read as '0' bit 7 WCOL: Write Collision Detect bit 1 = The SSPxBUF register is written while it is still transmitting the previous word (must be cleared in software) 0 = No collision bit 6 SSPOV: Master Synchronous Serial Port Receive Overflow Indicator bit (1) SPI Slave mode: 1 = A new byte is received while the SSPxBUF register is still holding the previous data. In case of overflow, the data in SSPxSR are lost. Overflow can only occur in Slave mode. The user must read the SSPxBUF, even if only transmitting data, to avoid setting overflow (must be cleared in software). 0 = No overflow bit 5 SSPEN: Master Synchronous Serial Port Enable bit (2) 1 = Enables the serial port and configures SCKx, SDOx, SDIx and SSx as serial port pins 0 = Disables the serial port and configures these pins as I/O port pins bit 4 **CKP:** Clock Polarity Select bit 1 = Idle state for clock is a high level 0 = Idle state for clock is a low level bit 3-0 SSPM[3:0]: Master Synchronous Serial Port Mode Select bits<sup>(3)</sup> 1010 = SPI Master mode, Clock = Fosc/(2 \* ([SSPxADD] + 1)) 0101 = SPI Slave mode, Clock = SCKx pin; SSx pin control is disabled, SSx can be used as an I/O pin 0100 = SPI Slave mode, Clock = SCKx pin; SSx pin control is enabled 0011 = Reserved 0010 = SPI Master mode, Clock = Fosc/32 0001 = SPI Master mode, Clock = Fosc/8 0000 = SPI Master mode. Clock = Fosc/2 **Note 1:** In Master mode, the overflow bit is not set since each new reception (and transmission) is initiated by writing to the SSPxBUF register. 2: When enabled, these pins must be properly configured as inputs or outputs. 3: Bit combinations not specifically listed here are either reserved or implemented in I<sup>2</sup>C mode only. ### REGISTER 14-4: SSPxCON1: MSSPx CONTROL REGISTER 1 (I<sup>2</sup>C MODE) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|----------------------|-------|----------------------|----------------------|----------------------|----------------------| | WCOL | SSPOV | SSPEN <sup>(1)</sup> | CKP | SSPM3 <sup>(2)</sup> | SSPM2 <sup>(2)</sup> | SSPM1 <sup>(2)</sup> | SSPM0 <sup>(2)</sup> | | bit 7 | | | | | | | bit 0 | ### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown ### bit 15-8 Unimplemented: Read as '0' bit 7 WCOL: Write Collision Detect bit #### In Master Transmit mode: - 1 = A write to the SSPxBUF register was attempted while the I<sup>2</sup>C conditions were not valid for a transmission to be started (must be cleared in software) - 0 = No collision #### In Slave Transmit mode: - 1 = The SSPxBUF register is written while it is still transmitting the previous word (must be cleared in software) - 0 = No collision #### In Receive mode (Master or Slave modes): This is a "don't care" bit. bit 6 SSPOV: Master Synchronous Serial Port Receive Overflow Indicator bit #### In Receive mode: - 1 = A byte is received while the SSPxBUF register is still holding the previous byte (must be cleared in software) - 0 = No overflow #### In Transmit mode: This is a "don't care" bit in Transmit mode. - bit 5 SSPEN: Master Synchronous Serial Port Enable bit (1) - 1 = Enables the serial port and configures the SDAx and SCLx pins as the serial port pins - 0 = Disables the serial port and configures these pins as I/O port pins - bit 4 CKP: SCLx Release Control bit #### In Slave mode: - 1 = Releases clock - 0 = Holds clock low (clock stretch), used to ensure data setup time ### In Master mode: Unused in this mode. - bit 3-0 SSPM[3:0]: Master Synchronous Serial Port Mode Select bits<sup>(2)</sup> - 1111 = I<sup>2</sup>C Slave mode, 10-bit address with Start and Stop bit interrupts enabled - 1110 = I<sup>2</sup>C Slave mode, 7-bit address with Start and Stop bit interrupts enabled - 1011 = I<sup>2</sup>C Firmware Controlled Master mode (Slave Idle) - 1000 = $I^2C$ Master mode, Clock = Fosc/(2 \* ([SSPxADD] + 1))<sup>(3)</sup> - 0111 = I<sup>2</sup>C Slave mode, 10-bit address - $0110 = I^2C$ Slave mode, 7-bit address - Note 1: When enabled, the SDAx and SCLx pins must be configured as inputs. - 2: Bit combinations not specifically listed here are either reserved or implemented in SPI mode only. - 3: SSPxADD values of 0, 1 or 2 are not supported when the Baud Rate Generator is used with I<sup>2</sup>C mode. ### REGISTER 14-5: SSPxCON2: MSSPx CONTROL REGISTER 2 (I<sup>2</sup>C MODE) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|---------|----------------------|----------------------|---------------------|--------------------|---------------------|--------------------| | GCEN | ACKSTAT | ACKDT <sup>(1)</sup> | ACKEN <sup>(2)</sup> | RCEN <sup>(2)</sup> | PEN <sup>(2)</sup> | RSEN <sup>(2)</sup> | SEN <sup>(2)</sup> | | bit 7 | | | | | | | bit 0 | Legend: bit 5 R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15-8 **Unimplemented:** Read as '0' bit 7 GCEN: General Call Enable bit (Slave mode only) 1 = Enables interrupt when a general call address (0000h) is received in the SSPxSR 0 = General call address is disabled bit 6 ACKSTAT: Acknowledge Status bit (Master Transmit mode only) 1 = Acknowledge was not received from Slave0 = Acknowledge was received from Slave **ACKDT:** Acknowledge Data bit (Master Receive mode only)<sup>(1)</sup> 1 = No Acknowledge 0 = Acknowledge bit 4 ACKEN: Acknowledge Sequence Enable bit (Master mode only)(2) 1 = Initiates Acknowledge sequence on SDAx and SCLx pins and transmits ACKDT data bit; automatically cleared by hardware 0 = Acknowledge sequence is Idle bit 3 RCEN: Receive Enable bit (Master Receive mode only)(2) 1 = Enables Receive mode for I<sup>2</sup>C 0 = Receive is Idle bit 2 **PEN:** Stop Condition Enable bit (Master mode only)<sup>(2)</sup> 1 = Initiates Stop condition on SDAx and SCLx pins; automatically cleared by hardware 0 = Stop condition is Idle bit 1 RSEN: Repeated Start Condition Enable bit (Master mode only)(2) 1 = Initiates Repeated Start condition on SDAx and SCLx pins; automatically cleared by hardware 0 = Repeated Start condition is Idle bit 0 SEN: Start Condition Enable bit<sup>(2)</sup> Master Mode: 1 = Initiates Start condition on SDAx and SCLx pins; automatically cleared by hardware 0 = Start condition is Idle Slave Mode: 1 = Clock stretching is enabled for both Slave transmit and Slave receive (stretch is enabled) 0 = Clock stretching is disabled **Note 1:** The value that will be transmitted when the user initiates an Acknowledge sequence at the end of a receive. 2: If the I<sup>2</sup>C module is active, these bits may not be set (no spooling) and the SSPxBUF may not be written (or writes to the SSPxBUF are disabled). ### REGISTER 14-6: SSPxCON3: MSSPx CONTROL REGISTER 3 (SPI MODE) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | | _ | _ | | _ | | bit 15 | | | | | | | bit 8 | | R-0 | R/W-0 |--------|-------|-------|---------------------|-------|-------|-------|-------| | ACKTIM | PCIE | SCIE | BOEN <sup>(1)</sup> | SDAHT | SBCDE | AHEN | DHEN | | bit 7 | | | | | | | bit 0 | Legend: bit 3 R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 **Unimplemented:** Read as '0' bit 7 **ACKTIM:** Acknowledge Time Status bit (I<sup>2</sup>C mode only) Unused in SPI mode. bit 6 **PCIE**: Stop Condition Interrupt Enable bit (I<sup>2</sup>C mode only) Unused in SPI mode. bit 5 SCIE: Start Condition Interrupt Enable bit (I<sup>2</sup>C mode only) Unused in SPI mode. bit 4 **BOEN:** Buffer Overwrite Enable bit<sup>(1)</sup> In SPI Slave mode: 1 = SSPxBUF updates every time that a new data byte is shifted in, ignoring the BF bit 0 = If a new byte is received with the BF bit of the SSPxSTAT register already set, the SSPOV bit of the SSPxCON1 register is set and the buffer is not updated **SDAHT:** SDAx Hold Time Selection bit (I<sup>2</sup>C mode only) Unused in SPI mode. bit 2 **SBCDE:** Slave Mode Bus Collision Detect Enable bit (I<sup>2</sup>C Slave mode only) Unused in SPI mode. bit 1 AHEN: Address Hold Enable bit (I<sup>2</sup>C Slave mode only) Unused in SPI mode. bit 0 DHEN: Data Hold Enable bit (Slave mode only) Unused in SPI mode. **Note 1:** For Daisy-Chained SPI Operation: Allows the user to ignore all but the last received byte. SSPOV is still set when a new byte is received and BF = 1, but hardware continues to write the most recent byte to SSPxBUF. ### REGISTER 14-7: SSPxCON3: MSSPx CONTROL REGISTER 3 (I<sup>2</sup>C MODE) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R-0 | R/W-0 |-----------------------|-------|-------|-------|-------|-------|-------|-------| | ACKTIM <sup>(1)</sup> | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15-8 **Unimplemented:** Read as '0' bit 7 ACKTIM: Acknowledge Time Status bit<sup>(1)</sup> 1 = Indicates the I<sup>2</sup>C bus is in an Acknowledge sequence, sets on the 8<sup>th</sup> falling edge of the SCLx clock 0 = Not an Acknowledge sequence, cleared on the 9th rising edge of the SCLx clock bit 6 PCIE: Stop Condition Interrupt Enable bit 1 = Enables interrupt on detection of a Stop condition 0 = Stop detection interrupts are disabled<sup>(2)</sup> bit 5 SCIE: Start Condition Interrupt Enable bit 1 = Enables interrupt on detection of a Start or Restart condition 0 = Start detection interrupts are disabled<sup>(2)</sup> bit 4 **BOEN:** Buffer Overwrite Enable bit I<sup>2</sup>C Master mode: This bit is ignored. I<sup>2</sup>C Slave mode: 1 = SSPxBUF is updated and an ACK is generated for a received address/data byte, ignoring the state of the SSPOV bit only if the BF bit = 0 0 = SSPxBUF is only updated when SSPOV is clear bit 3 SDAHT: SDAx Hold Time Selection bit 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: Slave Mode Bus Collision Detect Enable bit (Slave mode only) 1 = Enables Slave bus collision interrupts 0 = Slave bus collision interrupts are disabled bit 1 AHEN: Address Hold Enable bit (Slave mode only) 1 = Following the 8th falling edge of SCLx for a matching received address byte; CKP bit of the SSPxCON1 register will be cleared and SCLx will be held low 0 = Address holding is disabled bit 0 DHEN: Data Hold Enable bit (Slave mode only) 1 = Following the 8th falling edge of SCLx for a received data byte; Slave hardware clears the CKP bit of the SSPxCON1 register and SCLx is held low 0 = Data holding is disabled **Note 1:** This bit has no effect in Slave modes for which Start and Stop condition detection is explicitly listed as enabled. 2: The ACKTIM status bit is active only when the AHEN bit or DHEN bit is set. #### REGISTER 14-8: SSPxADD: MSSPx SLAVE ADDRESS/BAUD RATE GENERATOR REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | | | | ADD | [7:0] | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 **Unimplemented:** Read as '0' bit 7-0 ADD[7:0]: Slave Address/Baud Rate Generator Value bits SPI Master and I<sup>2</sup>C Master modes: Reload value for the Baud Rate Generator. Clock period is (([SPxADD] + 1) \* 2)/Fosc. I<sup>2</sup>C Slave modes: Represents 7 or 8 bits of the Slave address, depending on the addressing mode used: 7-Bit mode: Address is ADD[7:1]; ADD[0] is ignored. 10-Bit LSb mode: ADD[7:0] are the Least Significant bits of the address. 10-Bit MSb mode: ADD[2:1] are the two Most Significant bits of the address; ADD[7:3] are always '11110' as a specification requirement; ADD[0] is ignored. ### REGISTER 14-9: SSPxMSK: I<sup>2</sup>C SLAVE ADDRESS MASK REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-1 | |-------------------------|-------|-------|-------|-------|-------|-------|-------|--| | MSK[7:0] <sup>(1)</sup> | | | | | | | | | | bit 7 | | | | | | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 **Unimplemented:** Read as '0' bit 7-0 MSK[7:0]: Slave Address Mask Select bits<sup>(1)</sup> 1 = Masking of corresponding bit of SSPxADD is enabled 0 = Masking of corresponding bit of SSPxADD is disabled Note 1: MSK0 is not used as a mask bit in 7-bit addressing. #### REGISTER 14-10: PADCFG1: PAD CONFIGURATION CONTROL REGISTER | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|-----|-----|------------------------|------------------------|---------|---------| | _ | _ | _ | _ | SDO2DIS <sup>(1)</sup> | SCK2DIS <sup>(1)</sup> | SDO1DIS | SCK1DIS | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15-12 Unimplemented: Read as '0' bit 11 SDO2DIS: MSSP2 SDO2 Pin Disable bit<sup>(1)</sup> 1 = The SPI output data (SDO2) of MSSP2 to the pin are disabled 0 = The SPI output data (SDO2) of MSSP2 are output to the pin bit 10 SCK2DIS: MSSP2 SCK2 Pin Disable bit<sup>(1)</sup> 1 = The SPI clock (SCK2) of MSSP2 to the pin is disabled 0 = The SPI clock (SCK2) of MSSP2 is output to the pin bit 9 SDO1DIS: MSSP1 SDO1 Pin Disable bit 1 = The SPI output data (SDO1) of MSSP1 to the pin are disabled 0 = The SPI output data (SDO1) of MSSP1 are output to the pin bit 8 SCK1DIS: MSSP1 SCK1 Pin Disable bit 1 = The SPI clock (SCK1) of MSSP1 to the pin is disabled 0 = The SPI clock (SCK1) of MSSP1 is output to the pin bit 7-0 **Unimplemented:** Read as '0' Note 1: These bits are implemented only on PIC24FXXKM20X devices. NOTES: # 15.0 UNIVERSAL ASYNCHRONOUS RECEIVER TRANSMITTER (UART) Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Universal Asynchronous Receiver Transmitter, refer to "Universal Asynchronous Receiver Transmitter (UART)" (www.microchip.com/DS70000582) in the "dsPIC33/PIC24F Family Reference Manual". The Universal Asynchronous Receiver Transmitter (UART) module is one of the serial I/O modules available in this PIC24F device family. The UART is a full-duplex, asynchronous system that can communicate with peripheral devices, such as personal computers, LIN/J2602, RS-232 and RS-485 interfaces. This module also supports a hardware flow control option with the $\overline{\text{UxCTS}}$ and $\overline{\text{UxRTS}}$ pins, and also includes an IrDA® encoder and decoder. The primary features of the UART module are: - Full-Duplex, 8-Bit or 9-Bit Data Transmission through the UxTX and UxRX Pins - · Even, Odd or No Parity Options (for 8-bit data) - One or Two Stop bits - Hardware Flow Control Option with UxCTS and UxRTS Pins - Fully Integrated Baud Rate Generator (IBRG) with 16-Bit Prescaler - Baud Rates Ranging from 1 Mbps to 15 bps at 16 MIPS - 4-Deep, First-In-First-Out (FIFO) Transmit Data Buffer - · 4-Deep FIFO Receive Data Buffer - Parity, Framing and Buffer Overrun Error Detection - Support for 9-Bit mode with Address Detect (9<sup>th</sup> bit = 1) - · Transmit and Receive Interrupts - · Loopback mode for Diagnostic Support - · Support for Sync and Break Characters - · Supports Automatic Baud Rate Detection - IrDA<sup>®</sup> Encoder and Decoder Logic - · 16x Baud Clock Output for IrDA Support A simplified block diagram of the UARTx module is shown in Figure 15-1. The UARTx module consists of these important hardware elements: - · Baud Rate Generator - · Asynchronous Transmitter - · Asynchronous Receiver Note: Throughout this section, references to register and bit names that may be associated with a specific USART module are referred to generically by the use of 'x' in place of the specific module number. Thus, "UxSTA" might refer to the USART Status register for either USART1 or USART2. # 15.1 UARTx Baud Rate Generator (BRG) The UARTx module includes a dedicated 16-bit Baud Rate Generator (BRG). The UxBRG register controls the period of a free-running, 16-bit timer. Equation 15-1 provides the formula for computation of the baud rate with BRGH = 0. # EQUATION 15-1: UARTX BAUD RATE WITH BRGH = $0^{(1)}$ Baud Rate = $$\frac{FCY}{16 \cdot (UxBRG + 1)}$$ $$UxBRG = \frac{FCY}{16 \cdot Baud Rate} - 1$$ **Note 1:** Based on FCY = FOSC/2; Doze mode and PLL are disabled. Example 15-1 provides the calculation of the baud rate error for the following conditions: - Fcy = 4 MHz - Desired Baud Rate = 9600 The maximum baud rate (BRGH = 0) possible is Fcy/16 (for UxBRG = 0) and the minimum baud rate possible is Fcy/(16 \* 65536). Equation 15-2 shows the formula for computation of the baud rate with BRGH = 1. # EQUATION 15-2: UARTX BAUD RATE WITH BRGH = 1<sup>(1)</sup> Baud Rate = $$\frac{FCY}{4 \cdot (UxBRG + 1)}$$ $$UxBRG = \frac{FCY}{4 \cdot Baud Rate} - 1$$ **Note 1:** Based on Fcy = Fosc/2; Doze mode and PLL are disabled. The maximum baud rate (BRGH = 1) possible is FCY/4 (for UxBRG = 0) and the minimum baud rate possible is FCY/(4 \* 65536). Writing a new value to the UxBRG register causes the BRG timer to be reset (cleared). This ensures the BRG does not wait for a timer overflow before generating the new baud rate. ### EXAMPLE 15-1: BAUD RATE ERROR CALCULATION (BRGH = 0)<sup>(1)</sup> Desired Baud Rate = FCY/(16 (UxBRG + 1))Solving for UxBRG value: UxBRG = ((FCY/Desired Baud Rate)/16) - 1UxBRG = ((4000000/9600)/16) - 1UxBRG = 25Calculated Baud Rate = 4000000/(16(25+1))= 9615Error = (Calculated Baud Rate – Desired Baud Rate) Desired Baud Rate = (9615 - 9600)/9600= 0.16% Note 1: Based on Fcy = Fosc/2; Doze mode and PLL are disabled. ### 15.2 Transmitting in 8-Bit Data Mode - 1. Set up the UARTx: - a) Write the appropriate values for data, parity and Stop bits. - b) Write the appropriate baud rate value to the UxBRG register. - Set up transmit and receive interrupt enable and priority bits. - 2. Enable the UARTx. - 3. Set the UTXEN bit (causes a transmit interrupt, two cycles after being set). - Write the data byte to the lower byte of the UxTXREG word. The value will be immediately transferred to the Transmit Shift Register (TSR) and the serial bit stream will start shifting out with the next rising edge of the baud clock. - Alternately, the data byte may be transferred while UTXEN = 0, and then, the user may set UTXEN. This will cause the serial bit stream to begin immediately, because the baud clock will start from a cleared state. - A transmit interrupt will be generated as per interrupt control bit, UTXISELx. ### 15.3 Transmitting in 9-Bit Data Mode - Set up the UARTx (as described in Section 15.2 "Transmitting in 8-Bit Data Mode"). - 2. Enable the UARTx. - 3. Set the UTXEN bit (causes a transmit interrupt, two cycles after being set). - 4. Write UxTXREG as a 16-bit value only. - A word write to UxTXREG triggers the transfer of the 9-bit data to the TSR. The serial bit stream will start shifting out with the first rising edge of the baud clock. - 6. A transmit interrupt will be generated as per the setting of control bit, UTXISELx. # 15.4 Break and Sync Transmit Sequence The following sequence will send a message frame header, made up of a Break, followed by an Auto-Baud Sync byte. - 1. Configure the UARTx for the desired mode. - Set UTXEN and UTXBRK this sets up the Break character. - 3. Load the UxTXREG with a dummy character to initiate transmission (value is ignored). - 4. Write '55h' to UxTXREG loads the Sync character into the transmit FIFO. - After the Break has been sent, the UTXBRK bit is reset by hardware. The Sync character now transmits. # 15.5 Receiving in 8-Bit or 9-Bit Data Mode - 1. Set up the UARTx (as described in Section 15.2 "Transmitting in 8-Bit Data Mode"). - 2. Enable the UARTx. - A receive interrupt will be generated when one or more data characters have been received, as per interrupt control bit, URXISELx. - Read the OERR bit to determine if an overrun error has occurred. The OERR bit must be reset in software. - Read UxRXREG. The act of reading the UxRXREG character will move the next character to the top of the receive FIFO, including a new set of PERR and FERR values. # 15.6 Operation of UxCTS and UxRTS Control Pins UARTx Clear-to-Send (UxCTS) and Request-to-Send (UxRTS) are the two hardware controlled pins that are associated with the UARTx module. These two pins allow the UARTx to operate in Simplex and Flow Control modes. They are implemented to control the transmission and reception between the Data Terminal Equipment (DTE). The UEN[1:0] bits in the UxMODE register configure these pins. ### 15.7 Infrared Support The UARTx module provides two types of infrared UARTx support: one is the IrDA clock output to support an external IrDA encoder and decoder device (legacy module support), and the other is the full implementation of the IrDA encoder and decoder. As the IrDA modes require a 16x baud clock, they will only work when the BRGH bit (UxMODE[3]) is '0'. # 15.7.1 EXTERNAL IrDA SUPPORT – IrDA CLOCK OUTPUT To support external IrDA encoder and decoder devices, the UxBCLK pin (same as the $\overline{\text{UxRTS}}$ pin) can be configured to generate the 16x baud clock. When UEN[1:0] = 11, the UxBCLK pin will output the 16x baud clock if the UARTx module is enabled; it can be used to support the IrDA codec chip. # 15.7.2 BUILT-IN IrDA ENCODER AND DECODER The UARTx has full implementation of the IrDA encoder and decoder as part of the UARTx module. The built-in IrDA encoder and decoder functionality is enabled using the IREN bit (UxMODE[12]). When enabled (IREN = 1), the receive pin (UxRX) acts as the input from the infrared receiver. The transmit pin (UxTX) acts as the output to the infrared transmitter. #### REGISTER 15-1: UxMODE: UARTx MODE REGISTER | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 <sup>(2)</sup> | R/W-0 <sup>(2)</sup> | |--------|-----|-------|---------------------|-------|-----|----------------------|----------------------| | UARTEN | _ | USIDL | IREN <sup>(1)</sup> | RTSMD | _ | UEN1 | UEN0 | | bit 15 | | | | | | | bit 8 | | HC/R/C-0 | R/W-0 | HC/R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |----------|--------|----------|--------|-------|--------|--------|-------| | WAKE | LPBACK | ABAUD | URXINV | BRGH | PDSEL1 | PDSEL0 | STSEL | | bit 7 | | | | | | | bit 0 | | Legend: | C = Clearable bit | HC = Hardware Clearable bit | | | |-------------------|-------------------|------------------------------------|--------------------|--| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read as '0' | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | - bit 15 **UARTEN:** UARTx Enable bit - 1 = UARTx is enabled; all UARTx pins are controlled by UARTx, as defined by UEN[1:0] - 0 = UARTx is disabled; all UARTx pins are controlled by port latches, UARTx power consumption is minimal - bit 14 **Unimplemented:** Read as '0' - bit 13 USIDL: UARTx Stop in Idle Mode bit - 1 = Discontinues module operation when the device enters Idle mode - 0 = Continues module operation in Idle mode - bit 12 IREN: IrDA® Encoder and Decoder Enable bit(1) - 1 = IrDA encoder and decoder are enabled - 0 = IrDA encoder and decoder are disabled - bit 11 RTSMD: Mode Selection for UxRTS Pin bit - 1 = UxRTS pin is in Simplex mode - $0 = \overline{\text{UxRTS}}$ pin is in Flow Control mode - bit 10 **Unimplemented:** Read as '0' - bit 9-8 **UEN[1:0]:** UARTx Enable bits<sup>(2)</sup> - 11 = UxTX, UxRX and UxBCLK pins are enabled and used; UxCTS pin is controlled by port latches - 10 = UxTX, UxRX, UxCTS and UxRTS pins are enabled and used - 01 = UxTX, UxRX and $\overline{\text{UxRTS}}$ pins are enabled and used; $\overline{\text{UxCTS}}$ pin is controlled by port latches - 00 = UxTX and UxRX pins are enabled and used; UxCTS and UxRTS/UxBCLK pins are controlled by port latches - bit 7 WAKE: Wake-up on Start Bit Detect During Sleep Mode Enable bit - 1 = UARTx will continue to sample the UxRX pin; interrupt is generated on the falling edge, bit is cleared in hardware on the following rising edge - 0 = No wake-up is enabled - bit 6 LPBACK: UARTx Loopback Mode Select bit - 1 = Enables Loopback mode - 0 = Loopback mode is disabled - bit 5 ABAUD: Auto-Baud Enable bit - 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 completed - bit 4 URXINV: UARTx Receive Polarity Inversion bit - 1 = UxRX Idle state is '0' - 0 = UxRX Idle state is '1' - **Note 1:** This feature is is only available for the 16x BRG mode (BRGH = 0). - 2: The bit availability depends on the pin availability. ### REGISTER 15-1: UxMODE: UARTx MODE REGISTER (CONTINUED) bit 3 BRGH: High Baud Rate Enable bit 1 = BRG generates 4 clocks per bit period (4x baud clock, High-Speed mode) 0 = BRG generates 16 clocks per bit period (16x baud clock, Standard mode) bit 2-1 PDSEL[1:0]: Parity and Data Selection bits 11 = 9-bit data, no parity 10 = 8-bit data, odd parity 01 = 8-bit data, even parity 00 = 8-bit data, no parity bit 0 STSEL: Stop Bit Selection bit 1 = Two Stop bits 0 = One Stop bit **Note 1:** This feature is is only available for the 16x BRG mode (BRGH = 0). 2: The bit availability depends on the pin availability. #### REGISTER 15-2: UxSTA: UARTX STATUS AND CONTROL REGISTER | R/W-0 | R/W-0 | R/W-0 | U-0 | HC/R/W-0 | R/W-0 | HSC/R-0 | HSC/R-1 | |----------|--------|----------|-----|----------|-------|---------|---------| | UTXISEL1 | UTXINV | UTXISEL0 | _ | UTXBRK | UTXEN | UTXBF | TRMT | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R/W-0 | HSC/R-1 | HSC/R-0 | HSC/R-0 | HS/R/C-0 | HSC/R-0 | |----------|----------|-------|---------|---------|---------|----------|---------| | URXISEL1 | URXISEL0 | ADDEN | RIDLE | PERR | FERR | OERR | URXDA | | bit 7 | | | | | | | bit 0 | **Legend:** HC = Hardware Clearable bit HS = Hardware Settable bit C = Clearable bit HSC = Hardware Settable/Clearable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' ### bit 15,13 UTXISEL[1:0]: UARTx Transmission Interrupt Mode Selection bits - 11 = Reserved; do not use - 10 = Interrupt when a character is transferred to the Transmit Shift Register (TSR) and as a result, the transmit buffer becomes empty - 01 = Interrupt when the last character is shifted out of the Transmit Shift Register; all transmit operations are completed - 00 = Interrupt when a character is transferred to the Transmit Shift Register (this implies there is at least one character open in the transmit buffer) - bit 14 UTXINV: IrDA® Encoder Transmit Polarity Inversion bit If IREN = 0: 1 = UxTX Idle '0' 0 = UxTX Idle '1' <u>If IREN = 1:</u> 1 = UxTX Idle '1' 0 = UxTX Idle '0' ### bit 12 **Unimplemented:** Read as '0' ### bit 11 UTXBRK: UARTx Transmit Break bit - 1 = Sends Sync Break on next transmission Start bit, followed by twelve '0' bits, followed by Stop bit; cleared by hardware upon completion - 0 = Sync Break transmission is disabled or completed - bit 10 UTXEN: UARTx Transmit Enable bit - 1 = Transmit is enabled; UxTX pin is controlled by UARTx - 0 = Transmit is disabled; any pending transmission is aborted and the buffer is reset; UxTX pin is controlled by the PORT register - bit 9 UTXBF: UARTx Transmit Buffer Full Status bit (read-only) - 1 = Transmit buffer is full - 0 = Transmit buffer is not full, at least one more character can be written - bit 8 **TRMT:** Transmit Shift Register Empty bit (read-only) - 1 = Transmit Shift Register is empty and the transmit buffer is empty (the last transmission has completed) - 0 = Transmit Shift Register is not empty; a transmission is in progress or queued - bit 7-6 URXISEL[1:0]: UARTx Receive Interrupt Mode Selection bits - 11 = Interrupt is set on an RSR transfer, making the receive buffer full (i.e., has four data characters) - 10 = Interrupt is set on an RSR transfer, making the receive buffer 3/4 full (i.e., has three data characters) - 0x = Interrupt is set when any character is received and transferred from the RSR to the receive buffer; receive buffer has one or more characters ### REGISTER 15-2: UxSTA: UARTx STATUS AND CONTROL REGISTER (CONTINUED) | bit 5 | ADDEN: Address Character Detect bit (bit 8 of received data = 1) | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <ul><li>1 = Address Detect mode is enabled; if 9-bit mode is not selected, this does not take effect</li><li>0 = Address Detect mode is disabled</li></ul> | | bit 4 | RIDLE: Receiver Idle bit (read-only) | | | <ul><li>1 = Receiver is Idle</li><li>0 = Receiver is active</li></ul> | | bit 3 | PERR: Parity Error Status bit (read-only) | | | <ul><li>1 = Parity error has been detected for the current character (character at the top of the receive FIFO)</li><li>0 = Parity error has not been detected</li></ul> | | bit 2 | FERR: Framing Error Status bit (read-only) | | | <ul><li>1 = Framing error has been detected for the current character (character at the top of the receive FIFO)</li><li>0 = Framing error has not been detected</li></ul> | | bit 1 | OERR: Receive Buffer Overrun Error Status bit (clear/read-only) | | | 1 = Receive buffer has overflowed<br>0 = Receive buffer has not overflowed (clearing a previously set OERR bit (1 $\rightarrow$ 0 transition) will reset<br>the receiver buffer and the RSR to the Empty state) | | bit 0 | URXDA: UARTx Receive Buffer Data Available bit (read-only) | | | <ul><li>1 = Receive buffer has data; at least one more character can be read</li><li>0 = Receive buffer is empty</li></ul> | #### REGISTER 15-3: UXTXREG: UARTX TRANSMIT REGISTER | U-x W-x | |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | | _ | _ | | | UTX8 | | bit 15 | | | | | | | bit 8 | | W-x | | |----------|-----|-----|-----|-----|-----|-----|-------|--|--| | UTX[7:0] | | | | | | | | | | | bit 7 | | | | | | | bit 0 | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-9 **Unimplemented:** Read as '0' bit 8 **UTX8:** Data of the Transmitted Character bit (in 9-bit mode) bit 7-0 UTX[7:0]: Data of the Transmitted Character bits #### REGISTER 15-4: UxRXREG: UARTx RECEIVE REGISTER | U-0 HSC/R-0 | |--------|-----|-----|-----|-----|-----|-----|---------| | _ | _ | _ | _ | _ | _ | _ | URX8 | | bit 15 | | | | | | | bit 8 | | HSC/R-0 | |----------|---------|---------|---------|---------|---------|---------|---------|--| | URX[7:0] | | | | | | | | | | bit 7 | | | | | | | bit 0 | | **Legend:** HSC = Hardware Settable/Clearable bit R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-9 **Unimplemented:** Read as '0' bit 8 **URX8:** Data of the Received Character bit (in 9-bit mode) bit 7-0 URX[7:0]: Data of the Received Character bits # 16.0 REAL-TIME CLOCK AND CALENDAR (RTCC) Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Real-Time Clock and Calendar, refer to "RTCC with External Power Control" (www.microchip.com/DS39745) in the "dsPIC33/PIC24F Family Reference Manual". The RTCC provides the user with a Real-Time Clock and Calendar (RTCC) function that can be calibrated. Key features of the RTCC module are: - · Operates in Sleep and Retention Sleep Modes - · Selectable Clock Source - Provides Hours, Minutes and Seconds Using 24-Hour Format - · Visibility of One Half Second Period - Provides Calendar Weekday, Date, Month and Year - Alarm-Configurable for Half a second, One Second, Ten Seconds, One Minute, Ten Minutes, One Hour, One Day, One Week, One Month or One Year - · Alarm Repeat with Decrementing Counter - · Alarm with Indefinite Repeat Chime - · Year 2000 to 2099 Leap Year Correction - · BCD Format for Smaller Software Overhead - · Optimized for Long-Term Battery Operation - User Calibration of the 32.768 kHz Clock Crystal/32K INTRC Frequency with Periodic Auto-Adjust - · Optimized for Long-Term Battery Operation - · Fractional Second Synchronization - Calibration to within ±2.64 Seconds Error per Month - · Calibrates Up to 260 ppm of Crystal Error - Ability to Periodically Wake-up External Devices without CPU Intervention (External Power Control) - Power Control Output for External Circuit Control - · Calibration takes Effect Every 15 Seconds - · Runs from Any One of the Following: - External Real-Time Clock of 32.768 kHz - Internal 31.25 kHz LPRC Clock - 50 Hz or 60 Hz External Input #### 16.1 RTCC Source Clock The user can select between the SOSC crystal oscillator, LPRC internal oscillator or an external 50 Hz/60 Hz power line input as the clock reference for the RTCC module. This gives the user an option to trade off system cost, accuracy and power consumption, based on the overall system needs. #### 16.2 RTCC Module Registers The RTCC module registers are organized into three categories: - RTCC Control Registers - · RTCC Value Registers - · Alarm Value Registers #### 16.2.1 REGISTER MAPPING To limit the register interface, the RTCC Timer and Alarm Time registers are accessed through corresponding register pointers. The RTCC Value register window (RTCVALH and RTCVALL) uses the RTCPTRx bits (RCFGCAL[9:8]) to select the desired Timer register pair (see Table 16-1). By writing the RTCVALH byte, the RTCC Pointer value, the RTCPTR[1:0] bits decrement by one until they reach '00'. Once they reach '00', the MINUTES and SECONDS value will be accessible through RTCVALH and RTCVALL until the pointer value is manually changed. TABLE 16-1: RTCVAL REGISTER MAPPING | RTCPTR[1:0] | RTCC Value Register Window | | | | | | |-------------|----------------------------|-------------|--|--|--|--| | KIOPIK[I.0] | RTCVAL[15:8] | RTCVAL[7:0] | | | | | | 00 | MINUTES | SECONDS | | | | | | 01 | WEEKDAY | HOURS | | | | | | 10 | MONTH | DAY | | | | | | 11 | _ | YEAR | | | | | The Alarm Value register window (ALRMVALH and ALRMVALL) uses the ALRMPTRx bits (ALCFGRPT[9:8]) to select the desired Alarm register pair (see Table 16-2). By writing the ALRMVALH byte, the ALRMPTR[1:0] bits (Alarm Pointer value) decrement by one until they reach '00'. Once they reach '00', the ALRMMIN and ALRMSEC value will be accessible through ALRMVALH and ALRMVALL, until the pointer value is manually changed. TABLE 16-2: ALRMVAL REGISTER MAPPING | ALRMPTR | Alarm Value Register Window | | | | | | |---------|-----------------------------|---------------|--|--|--|--| | [1:0] | ALRMVALH[15:8] | ALRMVALL[7:0] | | | | | | 0 0 | ALRMMIN | ALRMSEC | | | | | | 01 | ALRMWD | ALRMHR | | | | | | 10 | ALRMMNTH | ALRMDAY | | | | | | 11 | PWCSTAB | PWCSAMP | | | | | Considering that the 16-bit core does not distinguish between 8-bit and 16-bit read operations, the user must be aware that when reading either the ALRMVALH or ALRMVALL bytes, the ALRMPTR[1:0] value will be decremented. The same applies to the RTCVALH or RTCVALL bytes with the RTCPTR[1:0] being decremented. **Note:** This only applies to read operations and not write operations. #### 16.2.2 WRITE LOCK In order to perform a write to any of the RTCC Timer registers, the RTCWREN bit (RCFGCAL[13]) must be set (see Example 16-1 and Example 16-2). Note: To avoid accidental writes to the timer, it is recommended that the RTCWREN bit (RCFGCAL[13]) is kept clear at any other time. For the RTCWREN bit to be set, there is only one instruction cycle time window allowed between the 55h/AA sequence and the setting of RTCWREN. Therefore, it is recommended that code follow the procedure in Example 16-2. #### 16.2.3 SELECTING RTCC CLOCK SOURCE There are four reference source clock options that can be selected for the RTCC using the RTCCLK[1:0] bits (RTCPWC[11:10]): 00 = Secondary Oscillator, 01 = LPRC, 10 = 50 Hz External Clock and 11 = 60 Hz External Clock. #### **EXAMPLE 16-1: SETTING THE RTCWREN BIT IN ASSEMBLY** ``` push ; Store W7 and W8 values on the stack. w7 push w8 disi #5 ; Disable interrupts until sequence is complete. mov #0x55, w7 ; Write 0x55 unlock value to NVMKEY. w7, NVMKEY mov mov #0xAA, w8 ; Write OxAA unlock value to NVMKEY. w8, NVMKEY mov bset RCFGCAL, #13 ; Set the RTCWREN bit. ; Restore the original W register values from the stack. pop w8 pop w7 ``` #### **EXAMPLE 16-2:** SETTING THE RTCWREN BIT IN 'C' ``` //This builtin function executes implements the unlock sequence and sets //the RTCWREN bit. __builtin_write_RTCWEN(); ``` #### 16.2.4 RTCC CONTROL REGISTERS ### REGISTER 16-1: RCFGCAL: RTCC CALIBRATION AND CONFIGURATION REGISTER<sup>(1)</sup> | R/W-0 | U-0 | R/W-0 | HSC/R-0 | HSC/R-0 | R/W-0 | R/W-0 | R/W-0 | |----------------------|-----|---------|---------|------------------------|-------|---------|---------| | RTCEN <sup>(2)</sup> | _ | RTCWREN | RTCSYNC | HALFSEC <sup>(3)</sup> | RTCOE | RTCPTR1 | RTCPTR0 | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | | | | CAL | [7:0] | | | | | bit 7 | | | | | | | bit 0 | | Legend: | HSC = Hardware Settable/Clearable bit | | | | | |-------------------|---------------------------------------|-----------------------------------------|--|--|--| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read as '0' | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared x = Bit is unknown | | | | bit 15 RTCEN: RTCC Enable bit<sup>(2)</sup> 1 = RTCC module is enabled 0 = RTCC module is disabled bit 14 **Unimplemented:** Read as '0' bit 13 RTCWREN: RTCC Value Registers Write Enable bit 1 = RTCVALH and RTCVALL registers can be written to by the user 0 = RTCVALH and RTCVALL registers are locked out from being written to by the user bit 12 RTCSYNC: RTCC Value Registers Read Synchronization bit 1 = RTCVALH, RTCVALL and ALCFGRPT registers can change while reading due to a rollover ripple resulting in an invalid data read. If the register is read twice and results in the same data, the data can be assumed to be valid. 0 = RTCVALH, RTCVALL or ALCFGRPT registers can be read without concern over a rollover ripple bit 11 HALFSEC: Half Second Status bit (3) 1 = Second half period of a second 0 = First half period of a second bit 10 RTCOE: RTCC Output Enable bit 1 = RTCC output is enabled 0 = RTCC output is disabled bit 9-8 RTCPTR[1:0]: RTCC Value Register Window Pointer bits Points to the corresponding RTCC Value registers when reading the RTCVALH and RTCVALL registers. The RTCPTR[1:0] value decrements on every read or write of RTCVALH until it reaches '00'. #### RTCVAL[15:8]: 00 = MINUTES 01 = WEEKDAY 10 **= MONTH** 11 = Reserved #### RTCVAL[7:0]: 00 = SECONDS 01 = HOURS 10 = DAY 11 = YEAR Note 1: The RCFGCAL register is only affected by a POR. 2: A write to the RTCEN bit is only allowed when RTCWREN = 1. 3: This bit is read-only; it is cleared to '0' on a write to the lower half of the MINSEC register. ### REGISTER 16-1: RCFGCAL: RTCC CALIBRATION AND CONFIGURATION REGISTER<sup>(1)</sup> (CONTINUED) bit 7-0 **CAL[7:0]:** RTC Drift Calibration bits 01111111 = Maximum positive adjustment; adds 508 RTC clock pulses every one minute . 00000001 = Minimum positive adjustment; adds 4 RTC clock pulses every one minute 00000000 = **No** adjustment 11111111 = Minimum negative adjustment; subtracts 4 RTC clock pulses every one minute • • 10000000 = Maximum negative adjustment; subtracts 512 RTC clock pulses every one minute **Note 1:** The RCFGCAL register is only affected by a POR. **2:** A write to the RTCEN bit is only allowed when RTCWREN = 1. 3: This bit is read-only; it is cleared to '0' on a write to the lower half of the MINSEC register. #### REGISTER 16-2: RTCPWC: RTCC CONFIGURATION REGISTER 2<sup>(1)</sup> | R/W-0 |--------|--------|---------|---------|------------------------|------------------------|---------|---------| | PWCEN | PWCPOL | PWCCPRE | PWCSPRE | RTCCLK1 <sup>(2)</sup> | RTCCLK0 <sup>(2)</sup> | RTCOUT1 | RTCOUT0 | | bit 15 | | | | | | | bit 8 | | U-0 |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 7 | | | | | | | bit 0 | | Legend: | | | | |-------------------|------------------|--------------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit, r | read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15 **PWCEN:** Power Control Enable bit 1 = Power control is enabled 0 = Power control is disabled bit 14 **PWCPOL:** Power Control Polarity bit 1 = Power control output is active-high 0 = Power control output is active-low bit 13 PWCCPRE: Power Control/Stability Prescaler bits 1 = PWC stability window clock is divide-by-2 of source RTCC clock 0 = PWC stability window clock is divide-by-1 of source RTCC clock bit 12 **PWCSPRE:** Power Control Sample Prescaler bits 1 = PWC sample window clock is divide-by-2 of source RTCC clock 0 = PWC sample window clock is divide-by-1 of source RTCC clock bit 11-10 RTCCLK[1:0]: RTCC Clock Select bits<sup>(2)</sup> Determines the source of the internal RTCC clock, which is used for all RTCC timer operations. 00 = External Secondary Oscillator (SOSC) 01 = Internal LPRC Oscillator 10 = External power line source – 50 Hz 11 = External power line source – 60 Hz bit 9-8 RTCOUT[1:0]: RTCC Output Select bits Determines the source of the RTCC pin output. 00 = RTCC alarm pulse 01 = RTCC seconds clock 10 = RTCC clock 11 = Power control bit 7-0 **Unimplemented:** Read as '0' Note 1: The RTCPWC register is only affected by a POR. **2:** When a new value is written to these register bits, the Seconds Value register should also be written to properly reset the clock prescalers in the RTCC. #### REGISTER 16-3: ALCFGRPT: ALARM CONFIGURATION REGISTER | R/W-0 |--------|-------|--------|--------|--------|--------|----------|----------| | ALRMEN | CHIME | AMASK3 | AMASK2 | AMASK1 | AMASK0 | ALRMPTR1 | ALRMPTR0 | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|--------|-------|-------|-------| | | | | ARP | T[7:0] | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 ALRMEN: Alarm Enable bit 1 = Alarm is enabled (cleared automatically after an alarm event whenever ARPT[7:0] = 00h and CHIME = 0) 0 = Alarm is disabled bit 14 CHIME: Chime Enable bit 1 = Chime is enabled; ARPT[7:0] bits are allowed to roll over from 00h to FFh 0 = Chime is disabled; ARPT[7:0] bits stop once they reach 00h bit 13-10 **AMASK[3:0]:** Alarm Mask Configuration bits 0000 = Every half second 0001 = Every second 0010 = Every ten seconds 0011 = Every minute 0100 = Every ten minutes 0101 = Every hour 0110 = Once a day 0111 = Once a week 1000 = Once a month 1001 = Once a year (except when configured for February 29<sup>th</sup>, once every 4 years) 101x = Reserved - do not use 11xx = Reserved – do not use bit 9-8 ALRMPTR[1:0]: Alarm Value Register Window Pointer bits Points to the corresponding Alarm Value registers when reading the ALRMVALH and ALRMVALL registers. The ALRMPTR[1:0] value decrements on every read or write of ALRMVALH until it reaches '00'. ALRMVAL[15:8]: 00 = ALRMMIN 01 = ALRMWD 10 = ALRMMNTH 11 = Unimplemented ALRMVAL[7:0]: 00 = ALRMSEC 01 = ALRMHR 10 = ALRMDAY 11 = Unimplemented bit 7-0 ARPT[7:0]: Alarm Repeat Counter Value bits 11111111 = Alarm will repeat 255 more times . . 00000000 = Alarm will not repeat The counter decrements on any alarm event; it is prevented from rolling over from 00h to FFh unless CHIME = 1. #### 16.2.5 RTCVAL REGISTER MAPPINGS #### REGISTER 16-4: YEAR: YEAR VALUE REGISTER(1) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-x |--------|--------|--------|--------|--------|--------|--------|--------| | YRTEN3 | YRTEN2 | YRTEN1 | YRTEN0 | YRONE3 | YRONE2 | YRONE1 | YRONE0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 Unimplemented: Read as '0' bit 7-4 YRTEN[3:0]: Binary Coded Decimal Value of Year's Tens Digit bits Contains a value from 0 to 9. bit 3-0 YRONE[3:0]: Binary Coded Decimal Value of Year's Ones Digit bits Contains a value from 0 to 9. **Note 1:** A write to the YEAR register is only allowed when RTCWREN = 1. ### REGISTER 16-5: MTHDY: MONTH AND DAY VALUE REGISTER<sup>(1)</sup> | U-0 | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | |--------|-----|-----|---------|---------|---------|---------|---------| | _ | _ | _ | MTHTEN0 | MTHONE3 | MTHONE2 | MTHONE1 | MTHONE0 | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | |-------|-----|---------|---------|---------|---------|---------|---------| | _ | _ | DAYTEN1 | DAYTEN0 | DAYONE3 | DAYONE2 | DAYONE1 | DAYONE0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-13 Unimplemented: Read as '0' bit 12 MTHTEN0: Binary Coded Decimal Value of Month's Tens Digit bit Contains a value of '0' or '1'. bit 11-8 MTHONE[3:0]: Binary Coded Decimal Value of Month's Ones Digit bits Contains a value from 0 to 9. bit 7-6 **Unimplemented:** Read as '0' bit 5-4 DAYTEN[1:0]: Binary Coded Decimal Value of Day's Tens Digit bits Contains a value from 0 to 3. bit 3-0 **DAYONE[3:0]:** Binary Coded Decimal Value of Day's Ones Digit bits Contains a value from 0 to 9. **Note 1:** A write to this register is only allowed when RTCWREN = 1. #### REGISTER 16-6: WKDYHR: WEEKDAY AND HOURS VALUE REGISTER(1) | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-x | R/W-x | R/W-x | |--------|-----|-----|-----|-----|-------|-----------|-------| | _ | _ | _ | _ | _ | | WDAY[2:0] | | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | |-------|-----|--------|--------|--------|--------|--------|--------| | _ | _ | HRTEN1 | HRTEN0 | HRONE3 | HRONE2 | HRONE1 | HRONE0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-11 **Unimplemented:** Read as '0' bit 10-8 WDAY[2:0]: Binary Coded Decimal Value of Weekday Digit bits Contains a value from 0 to 6. bit 7-6 Unimplemented: Read as '0' bit 5-4 HRTEN[1:0]: Binary Coded Decimal Value of Hour's Tens Digit bits Contains a value from 0 to 2. bit 3-0 **HRONE[3:0]:** Binary Coded Decimal Value of Hour's Ones Digit bits Contains a value from 0 to 9. **Note 1:** A write to this register is only allowed when RTCWREN = 1. #### REGISTER 16-7: MINSEC: MINUTES AND SECONDS VALUE REGISTER | U-0 | R/W-x |--------|---------|---------|---------|---------|---------|---------|---------| | _ | MINTEN2 | MINTEN1 | MINTEN0 | MINONE3 | MINONE2 | MINONE1 | MINONE0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-x |-------|---------|---------|---------|---------|---------|---------|---------| | _ | SECTEN2 | SECTEN1 | SECTEN0 | SECONE3 | SECONE2 | SECONE1 | SECONE0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 MINTEN[2:0]: Binary Coded Decimal Value of Minute's Tens Digit bits Contains a value from 0 to 5. bit 11-8 MINONE[3:0]: Binary Coded Decimal Value of Minute's Ones Digit bits Contains a value from 0 to 9. bit 7 **Unimplemented:** Read as '0' bit 6-4 SECTEN[2:0]: Binary Coded Decimal Value of Second's Tens Digit bits Contains a value from 0 to 5. bit 3-0 SECONE[3:0]: Binary Coded Decimal Value of Second's Ones Digit bits Contains a value from 0 to 9. #### 16.2.6 ALRMVAL REGISTER MAPPINGS #### REGISTER 16-8: ALMTHDY: ALARM MONTH AND DAY VALUE REGISTER(1) | U-0 | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | |--------|-----|-----|---------|---------|---------|---------|---------| | _ | _ | _ | MTHTEN0 | MTHONE3 | MTHONE2 | MTHONE1 | MTHONE0 | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | |-------|-----|---------|---------|---------|---------|---------|---------| | _ | _ | DAYTEN1 | DAYTEN0 | DAYONE3 | DAYONE2 | DAYONE1 | DAYONE0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-13 **Unimplemented:** Read as '0' bit 12 MTHTEN0: Binary Coded Decimal Value of Month's Tens Digit bit Contains a value of '0' or '1'. bit 11-8 MTHONE[3:0]: Binary Coded Decimal Value of Month's Ones Digit bits Contains a value from 0 to 9. bit 7-6 **Unimplemented:** Read as '0' bit 5-4 **DAYTEN[1:0]:** Binary Coded Decimal Value of Day's Tens Digit bits Contains a value from 0 to 3. bit 3-0 DAYONE[3:0]: Binary Coded Decimal Value of Day's Ones Digit bits Contains a value from 0 to 9. **Note 1:** A write to this register is only allowed when RTCWREN = 1. #### REGISTER 16-9: ALWDHR: ALARM WEEKDAY AND HOURS VALUE REGISTER(1) | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-x | R/W-x | R/W-x | |--------|-----|-----|-----|-----|-------|-----------|-------| | _ | _ | _ | _ | _ | | WDAY[2:0] | | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | |-------|-----|--------|--------|--------|--------|--------|--------| | _ | _ | HRTEN1 | HRTEN0 | HRONE3 | HRONE2 | HRONE1 | HRONE0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-11 **Unimplemented:** Read as '0' bit 10-8 WDAY[2:0]: Binary Coded Decimal Value of Weekday Digit bits Contains a value from 0 to 6. bit 7-6 **Unimplemented:** Read as '0' bit 5-4 HRTEN[1:0]: Binary Coded Decimal Value of Hour's Tens Digit bits Contains a value from 0 to 2. bit 3-0 HRONE[3:0]: Binary Coded Decimal Value of Hour's Ones Digit bits Contains a value from 0 to 9. **Note 1:** A write to this register is only allowed when RTCWREN = 1. #### REGISTER 16-10: ALMINSEC: ALARM MINUTES AND SECONDS VALUE REGISTER | U-0 | R/W-x |--------|---------|---------|---------|---------|---------|---------|---------| | _ | MINTEN2 | MINTEN1 | MINTEN0 | MINONE3 | MINONE2 | MINONE1 | MINONE0 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-x |-------|---------|---------|---------|---------|---------|---------|---------| | _ | SECTEN2 | SECTEN1 | SECTEN0 | SECONE3 | SECONE2 | SECONE1 | SECONE0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-12 MINTEN[2:0]: Binary Coded Decimal Value of Minute's Tens Digit bits Contains a value from 0 to 5. bit 11-8 MINONE[3:0]: Binary Coded Decimal Value of Minute's Ones Digit bits Contains a value from 0 to 9. bit 7 **Unimplemented:** Read as '0' bit 6-4 **SECTEN[2:0]:** Binary Coded Decimal Value of Second's Tens Digit bits Contains a value from 0 to 5. bit 3-0 SECONE[3:0]: Binary Coded Decimal Value of Second's Ones Digit bits Contains a value from 0 to 9. #### REGISTER 16-11: RTCCSWT: RTCC CONTROL/SAMPLE WINDOW TIMER REGISTER(1) | R/W-x | |--------------|-------|-------|-------|-------|-------|-------|-------|--| | PWCSTAB[7:0] | | | | | | | | | | bit 15 | | | | | | | bit 8 | | | R/W-x | |--------------|-------|-------|-------|-------|-------|-------|-------|--| | PWCSAMP[7:0] | | | | | | | | | | bit 7 | | | | | | | bit 0 | | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### bit 15-8 **PWCSTAB[7:0]:** PWM Stability Window Timer bits 11111111 = Stability window is 255 TPWCCLK clock periods • • 00000000 = Stability window is 0 TPWCCLK clock periods The sample window starts when the alarm event triggers. The stability window timer starts counting from every alarm event when PWCEN = 1. #### bit 7-0 **PWCSAMP[7:0]:** PWM Sample Window Timer bits 11111111 = Sample window is always enabled, even when PWCEN = 0 111111110 = Sample window is 254 TPWCCLK clock periods • • 00000000 = Sample window is 0 TPWCCLK clock periods The sample window timer starts counting at the end of the stability window when PWCEN = 1. If PWCSTAB[7:0] = 000000000, the sample window timer starts counting from every alarm event when PWCEN = 1. **Note 1:** A write to this register is only allowed when RTCWREN = 1. #### 16.3 Calibration The real-time crystal input can be calibrated using the periodic auto-adjust feature. When properly calibrated, the RTCC can provide an error of less than three seconds per month. This is accomplished by finding the number of error clock pulses and storing the value into the lower half of the RCFGCAL register. The 8-bit signed value, loaded into the lower half of RCFGCAL, is multiplied by four and will be either added or subtracted from the RTCC timer, once every minute. Refer to the steps below for RTCC calibration: - Using another timer resource on the device, the user must find the error of the 32.768 kHz crystal. - Once the error is known, it must be converted to the number of error clock pulses per minute. - a) If the oscillator is faster than ideal (negative result from Step 2), the RCFGCAL register value must be negative. This causes the specified number of clock pulses to be subtracted from the timer counter, once every minute. - b) If the oscillator is slower than ideal (positive result from Step 2), the RCFGCAL register value must be positive. This causes the specified number of clock pulses to be subtracted from the timer counter, once every minute. #### **EQUATION 16-1:** (Ideal Frequency† – Measured Frequency) \* 60 = Clocks per Minute † Ideal Frequency = 32,768 Hz Writes to the lower half of the RCFGCAL register should only occur when the timer is turned off, or immediately after the rising edge of the seconds pulse, except when SECONDS = 00, 15, 30 or 45. This is due to the auto-adjust of the RTCC at 15 second intervals. **Note:** It is up to the user to include, in the error value, the initial error of the crystal: drift due to temperature and drift due to crystal aging. #### 16.4 Alarm - · Configurable from half second to one year - Enabled using the ALRMEN bit (ALCFGRPT[15]) - One-time alarm and repeat alarm options are available #### 16.4.1 CONFIGURING THE ALARM The alarm feature is enabled using the ALRMEN bit. This bit is cleared when an alarm is issued. Writes to ALRMVAL should only take place when ALRMEN = 0. As shown in Figure 16-2, the interval selection of the alarm is configured through the AMASKx bits (ALCFGRPT[13:10]). These bits determine which and how many digits of the alarm must match the clock value for the alarm to occur. The alarm can also be configured to repeat based on a preconfigured interval. The amount of times this occurs, once the alarm is enabled, is stored in the ARPT[7:0] bits (ALCFGRPT[7:0]). When the value of the ARPTx bits equals 00h and the CHIME bit (ALCFGRPT[14]) is cleared, the repeat function is disabled, and only a single alarm will occur. The alarm can be repeated up to 255 times by loading ARPT[7:0] with FFh After each alarm is issued, the value of the ARPTx bits is decremented by one. Once the value has reached 00h, the alarm will be issued one last time, after which, the ALRMEN bit will be cleared automatically and the alarm will turn off. Indefinite repetition of the alarm can occur if the CHIME bit = 1. Instead of the alarm being disabled when the value of the ARPTx bits reaches 00h, it rolls over to FFh and continues counting indefinitely while CHIME is set. #### 16.4.2 ALARM INTERRUPT At every alarm event, an interrupt is generated. In addition, an alarm pulse output is provided that operates at half the frequency of the alarm. This output is completely synchronous to the RTCC clock and can be used as a Trigger clock to other peripherals. Note: Changing any of the registers, other than the RCFGCAL and ALCFGRPT registers, and the CHIME bit while the alarm is enabled (ALRMEN = 1), can result in a false alarm event leading to a false alarm interrupt. To avoid a false alarm event, the timer and alarm values should only be changed while the alarm is disabled (ALRMEN = 0). It is recommended that changed when RTCSYNC = 0. the ALCFGRPT register and CHIME bit be #### FIGURE 16-2: ALARM MASK SETTINGS | Alarm Mask Setting<br>(AMASK[3:0]) | Day of<br>the<br>Week | Month Day | Hours Minutes Seconds | |-------------------------------------------------|-----------------------|-----------------------------------------------|-----------------------| | 0000 - Every half second<br>0001 - Every second | | | | | 0010 - Every 10 seconds | | | : s | | 0011 - Every minute | | | | | 0100 - Every 10 minutes | | | m : s s | | 0101 - Every hour | | | : m m : s s | | 0110 - Every day | | | h h m m s s s | | 0111 - Every week | d | | h h m m s s | | 1000 - Every month | | d d | h h m m s s | | 1001 - Every year <sup>(1)</sup> | | $ \boxed{m} \boxed{m} / \boxed{d} \boxed{d} $ | h h m m s s | | Note 1: Annually, except when co | nfigured fo | or February 29. | | #### 16.5 Power Control The RTCC includes a power control feature that allows the device to periodically wake-up an external device, wait for the device to be stable before sampling wake-up events from that device and then shut down the external device. This can be done completely autonomously by the RTCC, without the need to wake from the current low-power mode (Sleep, Deep Sleep, etc.). To enable this feature, the RTCC must be enabled (RTCEN = 1), the PWCEN register bit must be set and the RTCC pin must be driving the PWC control signal (RTCOE = 1 and RTCCLK[1:0] = 11). The polarity of the PWC control signal may be chosen using the PWCPOL register bit. Active-low or active-high may be used with the appropriate external switch to turn on or off the power to one or more external devices. The active-low setting may also be used in conjunction with an open-drain setting on the RTCC pin. This setting is able to drive the GND pin(s) of the external device directly (with the appropriate external VDD pull-up device), without the need for external switches. Finally, the CHIME bit should be set to enable the PWC periodicity. | PIC24F | V16KM | 204 F <i>F</i> | AMILY | | | |--------|-------|----------------|-------|--|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 17.0 CONFIGURABLE LOGIC CELL (CLC) Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Comparator Voltage Reference, refer to "Configurable Logic Cell (CLC)" (www.microchip.com/DS70005298) in the "dsPIC33/PIC24 Family Reference Manual". 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 17-1 shows an overview of the module. Figure 17-3 shows the details of the data source multiplexers and logic input gate connections. #### FIGURE 17-1: CLCx MODULE #### **FIGURE 17-2: CLCx LOGIC FUNCTION COMBINATORIAL OPTIONS** **FIGURE 17-3: CLCx INPUT SOURCE SELECTION DIAGRAM Data Selection** CLCIN[0] 000 CLCIN[1] -Data Gate 1 CLCIN[2] Data 1 Noninverted G1D1T CLCIN[3] CLCIN[4] Data 1 Inverted CLCIN[5] G1D1N CLCIN[6] CLCIN[7] -G1D2T -DS1x (CLCxSEL[2:0]) G1D2N -Gate 1 CLCIN[8] CLCIN[9] G1D3T | CLCIN[10] -G1POL (CLCxCONH[0]) Data 2 Noninverted CLCIN[11] G1D3N CLCIN[12] Data 2 Inverted CLCIN[13] -G1D4T CLCIN[14] -CLCIN[15] -G1D4N -DS2x (CLCxSEL[6:4]) CLCIN[16] -000 Data Gate 2 CLCIN[17] CLCIN[18] -Gate 2 Data 3 Noninverted CLCIN[19] (Same as Data Gate 1) | CLCIN[20] Data 3 Inverted CLCIN[21] Data Gate 3 CLCIN[22] CLCIN[23] --Gate 3 DS3x (CLCxSEL[10:8]) (Same as Data Gate 1) | CLCIN[24] Data Gate 4 000 CLCIN[25] -Gate 4 CLCIN[26] (Same as Data Gate 1) Data 4 Noninverted CLCIN[27] -CLCIN[28] Data 4 CLCIN[29] Inverted CLCIN[30] | CLCIN[31] -DS4x (CLCxSEL[14:12]) All controls are undefined at power-up. Note: #### 17.1 Control Registers The CLCx module is controlled by the following registers: - CLCxCONL - CLCxCONH - CLCxSEL - CLCxGLSL - CLCxGLSH The CLCx Control registers (CLCxCONL and CLCxCONH) are used to enable the module and interrupts, control the output enable bit, select output polarity and select the logic function. The CLCx Control registers also allow the user to control the logic polarity of not only the cell output, but also some intermediate variables. The CLCx Source Select register (CLCxSEL) allows the user to select up to four data input sources using the four data input selection multiplexers. Each multiplexer has a list of eight data sources available. The CLCx Gate Logic Select registers (CLCxGLSL and CLCxGLSH) allow the user to select which outputs from each of the selection MUXes are used as inputs to the input gates of the logic cell. Each data source MUX outputs both a true and a negated version of its output. All of these eight signals are enabled, ORed together by the logic cell input gates. #### REGISTER 17-1: CLCxCONL: CLCx CONTROL REGISTER (LOW) | R/W-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | |--------|-----|-----|-----|-------|-------|-----|-------| | LCEN | _ | _ | _ | INTP | INTN | _ | _ | | bit 15 | | | | | | | bit 8 | | R-0 | R-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-------|-------|-----|-----|-------|-------|-------| | LCOE | LCOUT | LCPOL | _ | _ | MODE2 | MODE1 | MODE0 | | bit 7 | | | | | | | bit 0 | | Ιe | a | e | n | d | ٠ | |----|-----|---|----|---|---| | _ | . 9 | · | •• | u | | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 LCEN: CLCx Enable bit 1 = CLCx is enabled and mixing input signals0 = CLCx is disabled and has logic zero outputs bit 14-12 Unimplemented: Read as '0' bit 11 INTP: CLCx Positive Edge Interrupt Enable bit 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 1 = Interrupt will be generated when a falling edge occurs on LCOUT 0 = Interrupt will not be generated bit 9-8 **Unimplemented:** Read as '0' bit 7 LCOE: CLCx Port Enable bit 1 = CLCx port pin output is enabled0 = CLCx port pin output is disabled bit 6 LCOUT: CLCx Data Output Status bit 1 = CLCx output high 0 = CLCx output low bit 5 LCPOL: CLCx Output Polarity Control bit 1 = The output of the module is inverted0 = The output of the module is not inverted bit 4-3 **Unimplemented:** Read as '0' #### REGISTER 17-1: CLCxCONL: CLCx CONTROL REGISTER (LOW) (CONTINUED) #### bit 2-0 MODE[2:0]: CLCx Mode bits 111 = Cell is a 1-input transparent latch with S and R 110 = Cell is a JK flip-flop with R 101 = Cell is a 2-input D flip-flop with R 100 = Cell is a 1-input D flip-flop with S and R 011 = Cell is an SR latch 010 = Cell is a 4-input AND 001 = Cell is an OR-XOR 000 = Cell is a AND-OR #### REGISTER 17-2: CLCxCONH: CLCx CONTROL REGISTER (HIGH) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-------|-------|-------|-------| | _ | _ | _ | _ | G4POL | G3POL | G2POL | G1POL | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15-4 Unimplemented: Read as '0' bit 3 G4POL: Gate 4 Polarity Control bit 1 = The output of Channel 4 logic is inverted when applied to the logic cell 0 = The output of Channel 4 logic is not inverted bit 2 G3POL: Gate 3 Polarity Control bit 1 = The output of Channel 3 logic is inverted when applied to the logic cell 0 = The output of Channel 3 logic is not inverted bit 1 G2POL: Gate 2 Polarity Control bit 1 = The output of Channel 2 logic is inverted when applied to the logic cell 0 = The output of Channel 2 logic is not inverted bit 0 G1POL: Gate 1 Polarity Control bit 1 = The output of Channel 1 logic is inverted when applied to the logic cell 0 = The output of Channel 1 logic is not inverted #### REGISTER 17-3: CLCxSel: CLCx INPUT MUX SELECT REGISTER | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-------|-------|-------|-----|-------|-------|-------| | _ | DS42 | DS41 | DS40 | _ | DS32 | DS31 | DS30 | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-------|-------|-------|-----|-------|-------|-------| | _ | DS22 | DS21 | DS20 | _ | DS12 | DS11 | DS10 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 Unimplemented: Read as '0' bit 14-12 DS4[2:0]: Data Selection MUX 4 Signal Selection bits 111 = MCCP3 Compare Event Flag (CCP3IF) 110 = MCCP1 Compare Event Flag (CCP1IF) 101 = Digital logic low 100 = CTMU Trigger interrupt For CLC1: 011 = SPI1 SDIx 010 = Comparator 3 output 001 = CLC2 output 000 = CLCINB I/O pin For CLC2: 011 = SPI2 SDIx 010 = Comparator 3 output 001 = CLC1 output 000 = CLCINB I/O pin bit 11 **Unimplemented:** Read as '0' bit 10-8 DS3[2:0]: Data Selection MUX 3 Signal Selection bits 111 = MCCP3 Compare Event Flag (CCP3IF) 110 = MCCP2 Compare Event Flag (CCP2IF) 101 = Digital logic low For CLC1: 100 **= UART1 RX** 011 = SPI1 SDOx 010 = Comparator 2 output 001 = CLC1 output 000 = CLCINA I/O pin For CLC2: 100 **= UART2 RX** 011 = SPI2 SDOx 010 = Comparator 2 output 001 = CLC2 output 000 = CLCINA I/O pin bit 7 Unimplemented: Read as '0' #### REGISTER 17-3: CLCxSEL: CLCx INPUT MUX SELECT REGISTER (CONTINUED) bit 6-4 DS2[2:0]: Data Selection MUX 2 Signal Selection bits 111 = MCCP2 Compare Event Flag (CCP2IF) 110 = MCCP1 Compare Event Flag (CCP1IF) 101 = Digital logic low 100 = A/D end of conversion event For CLC1: 011 **= UART1 TX** 010 = Comparator 1 output 001 = CLC2 output 000 = CLCINB I/O pin For CLC2: 011 = UART2 TX 010 = Comparator 1 output 001 = CLC1 output 000 = CLCINB I/O pin bit 3 **Unimplemented:** Read as '0' bit 2-0 **DS1[2:0]:** Data Selection MUX 1 Signal Selection bits 111 = SCCP5 Compare Event Flag (CCP5IF) 110 = SCCP4 Compare Event Flag (CCP4IF) 101 = Digital logic low 100 = 8 MHz FRC clock source 011 = LPRC clock source 010 = SOSC clock source 001 = System clock (TcY) 000 = CLCINA I/O pin #### REGISTER 17-4: CLCxGLSL: CLCx GATE LOGIC INPUT SELECT LOW REGISTER | R/W-0 |--------|-------|-------|-------|-------|-------|-------|-------| | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | bit 7 | | | | | | | bit 0 | | | ^ | ~ | ^ | n | ᆈ | i | |---|---|---|---|---|---|---| | _ | e | u | e | п | u | ı | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown | bit 15 | G2D4T: Gate 2 Data Source 4 True Enable bit | |--------|--------------------------------------------------------------| | | 1 = The Data Source 4 signal is enabled for Gate 2 | | | 0 = The Data Source 4 signal is disabled for Gate 2 | | bit 14 | G2D4N: Gate 2 Data Source 4 Negated Enable bit | | | 1 = The Data Source 4 inverted signal is enabled for Gate 2 | | | 0 = The Data Source 4 inverted signal is disabled for Gate 2 | | bit 13 | G2D3T: Gate 2 Data Source 3 True Enable bit | | | 1 = The Data Source 3 signal is enabled for Gate 2 | | | 0 = The Data Source 3 signal is disabled for Gate 2 | | bit 12 | G2D3N: Gate 2 Data Source 3 Negated Enable bit | | | 1 = The Data Source 3 inverted signal is enabled for Gate 2 | | | 0 = The Data Source 3 inverted signal is disabled for Gate 2 | | bit 11 | G2D2T: Gate 2 Data Source 2 True Enable bit | | | 1 = The Data Source 2 signal is enabled for Gate 2 | | | 0 = The Data Source 2 signal is disabled for Gate 2 | | bit 10 | G2D2N: Gate 2 Data Source 2 Negated Enable bit | | | 1 = The Data Source 2 inverted signal is enabled for Gate 2 | | | 0 = The Data Source 2 inverted signal is disabled for Gate 2 | | bit 9 | G2D1T: Gate 2 Data Source 1 True Enable bit | | | 1 = The Data Source 1 signal is enabled for Gate 2 | | | 0 = The Data Source 1 signal is disabled for Gate 2 | | bit 8 | G2D1N: Gate 2 Data Source 1 Negated Enable bit | | | 1 = The Data Source 2 inverted signal is enabled for Gate 1 | | | 0 = The Data Source 2 inverted signal is disabled for Gate 1 | | bit 7 | G1D4T: Gate 1 Data Source 4 True Enable bit | | | 1 = The Data Source 4 signal is enabled for Gate 1 | | | 0 = The Data Source 4 signal is disabled for Gate 1 | | bit 6 | G1D4N: Gate 1 Data Source 4 Negated Enable bit | | | 1 = The Data Source 4 inverted signal is enabled for Gate 1 | | | 0 = The Data Source 4 inverted signal is disabled for Gate 1 | | bit 5 | G1D3T: Gate 1 Data Source 3 True Enable bit | | | 1 = The Data Source 3 signal is enabled for Gate 1 | | | 0 = The Data Source 3 signal is disabled for Gate 1 | | bit 4 | G1D3N: Gate 1 Data Source 3 Negated Enable bit | | | 1 = The Data Source 3 inverted signal is enabled for Gate 1 | | | 0 = The Data Source 3 inverted signal is disabled for Gate 1 | #### REGISTER 17-4: CLCxGLSL: CLCx GATE LOGIC INPUT SELECT LOW REGISTER (CONTINUED) | bit 3 | G1D2T: Gate 1 Data Source 2 True Enable bit | |-------|--------------------------------------------------------------| | | 1 = The Data Source 2 signal is enabled for Gate 1 | | | 0 = The Data Source 2 signal is disabled for Gate 1 | | bit 2 | G1D2N: Gate 1 Data Source 2 Negated Enable bit | | | 1 = The Data Source 2 inverted signal is enabled for Gate 1 | | | 0 = The Data Source 2 inverted signal is disabled for Gate 1 | | bit 1 | G1D1T: Gate 1 Data Source 1 True Enable bit | | | 1 = The Data Source 1 signal is enabled for Gate 1 | | | 0 = The Data Source 1 signal is disabled for Gate 1 | | bit 0 | G1D1N: Gate 1 Data Source 1 Negated Enable bit | | | 1 = The Data Source 1 inverted signal is enabled for Gate 1 | | | 0 = The Data Source 1 inverted signal is disabled for Gate 1 | #### REGISTER 17-5: CLCxGLSH: CLCx GATE LOGIC INPUT SELECT HIGH REGISTER | R/W-0 |--------|-------|-------|-------|-------|-------|-------|-------| | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | bit 7 | | | | | | | bit 0 | | Le | ^ | ^ | n | ч | | |----|---|---|-----|---|---| | LC | y | C | ••• | u | • | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown | bit 15 | G4D4T: Gate 4 Data Source 4 True Enable bit | |--------|--------------------------------------------------------------| | | 1 = The Data Source 4 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 4 inverted signal is disabled for Gate 4 | | bit 14 | G4D4N: Gate 4 Data Source 4 Negated Enable bit | | | 1 = The Data Source 4 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 4 inverted signal is disabled for Gate 4 | | bit 13 | G4D3T: Gate 4 Data Source 3 True Enable bit | | | 1 = The Data Source 3 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 3 inverted signal is disabled for Gate 4 | | bit 12 | G4D3N: Gate 4 Data Source 3 Negated Enable bit | | | 1 = The Data Source 3 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 3 inverted signal is disabled for Gate 4 | | bit 11 | G4D2T: Gate 4 Data Source 2 True Enable bit | | | 1 = The Data Source 2 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 2 inverted signal is disabled for Gate 4 | | bit 10 | G4D2N: Gate 4 Data Source 2 Negated Enable bit | | | 1 = The Data Source 2 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 2 inverted signal is disabled for Gate 4 | | bit 9 | G4D1T: Gate 4 Data Source 1 True Enable bit | | | 1 = The Data Source 1 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 1 inverted signal is disabled for Gate 4 | | bit 8 | G4D1N: Gate 4 Data Source 1 Negated Enable bit | | | 1 = The Data Source 1 inverted signal is enabled for Gate 4 | | | 0 = The Data Source 1 inverted signal is disabled for Gate 4 | | bit 7 | G3D4T: Gate 3 Data Source 4 True Enable bit | | | 1 = The Data Source 4 inverted signal is enabled for Gate 3 | | | 0 = The Data Source 4 inverted signal is disabled for Gate 3 | | bit 6 | G3D4N: Gate 3 Data Source 4 Negated Enable bit | | | 1 = The Data Source 4 inverted signal is enabled for Gate 3 | | | 0 = The Data Source 4 inverted signal is disabled for Gate 3 | | bit 5 | G3D3T: Gate 3 Data Source 3 True Enable bit | | | 1 = The Data Source 3 inverted signal is enabled for Gate 3 | | | 0 = The Data Source 3 inverted signal is disabled for Gate 3 | | bit 4 | G3D3N: Gate 3 Data Source 3 Negated Enable bit | | | 1 = The Data Source 3 inverted signal is enabled for Gate 3 | | | 0 = The Data Source 3 inverted signal is disabled for Gate 3 | | | | #### REGISTER 17-5: CLCxGLSH: CLCx GATE LOGIC INPUT SELECT HIGH REGISTER (CONTINUED) | bit 3 | G3D2T: Gate 3 Data Source 2 True Enable bit | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 = The Data Source 2 inverted signal is enabled for Gate 3<br>0 = The Data Source 2 inverted signal is disabled for Gate 3 | | bit 2 | G3D2N: Gate 3 Data Source 2 Negated Enable bit | | | 1 = The Data Source 2 inverted signal is enabled for Gate 3<br>0 = The Data Source 2 inverted signal is disabled for Gate 3 | | bit 1 | G3D1T: Gate 3 Data Source 1 True Enable bit | | | <ul><li>1 = The Data Source 1 inverted signal is enabled for Gate 3</li><li>0 = The Data Source 1 inverted signal is disabled for Gate 3</li></ul> | | bit 0 | G3D1N: Gate 3 Data Source 1 Negated Enable bit | | | $\tt 1$ = The Data Source 1 inverted signal is enabled for Gate 3 $\tt 0$ = The Data Source 1 inverted signal is disabled for Gate 3 | NOTES: ### 18.0 HIGH/LOW-VOLTAGE DETECT (HLVD) Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the High/Low-Voltage Detect, refer to "High-Level Integration with Programmable High/Low-Voltage Detect (HLVD)" (www.microchip.com/DS39725) in the "dsPIC33/PIC24F Family Reference Manual". The High/Low-Voltage Detect module (HLVD) is a programmable circuit that allows the user to specify both the device voltage trip point and the direction of change. An interrupt flag is set if the device experiences an excursion past the trip point in the direction of change. If the interrupt is enabled, the program execution will branch to the interrupt vector address and the software can then respond to the interrupt. The HLVD Control register (see Register 18-1) completely controls the operation of the HLVD module. This allows the circuitry to be "turned off" by the user under software control, which minimizes the current consumption for the device. **FIGURE 18-1:** HIGH/LOW-VOLTAGE DETECT (HLVD) MODULE BLOCK DIAGRAM #### **REGISTER 18-1: HLVDCON: HIGH/LOW-VOLTAGE DETECT CONTROL REGISTER** | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|-----|--------|-----|-----|-----|-----|-------| | HLVDEN | _ | HLSIDL | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-------|-------|-----|--------|--------|--------|--------| | VDIR | BGVST | IRVST | _ | HLVDL3 | HLVDL2 | HLVDL1 | HLVDL0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit U = Unimplemented bit, read as '0' W = Writable bit -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 HLVDEN: High/Low-Voltage Detect Power Enable bit > 1 = HLVD is enabled 0 = HLVD is disabled bit 14 Unimplemented: Read as '0' bit 13 **HLSIDL:** HLVD Stop in Idle Mode bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode Unimplemented: Read as '0' bit 12-8 bit 7 VDIR: Voltage Change Direction Select bit 1 = Event occurs when voltage equals or exceeds trip point (HLVDL[3:0]) 0 = Event occurs when voltage equals or falls below trip point (HLVDL[3:0]) bit 6 **BGVST:** Band Gap Voltage Stable Flag bit 1 = Indicates that the band gap voltage is stable 0 = Indicates that the band gap voltage is unstable bit 5 IRVST: Internal Reference Voltage Stable Flag bit 1 = Indicates that the internal reference voltage is stable and the High-Voltage Detect logic generates the interrupt flag at the specified voltage range 0 = Indicates that the internal reference voltage is unstable and the High-Voltage Detect logic will not generate the interrupt flag at the specified voltage range, and the HLVD interrupt should not be enabled bit 4 Unimplemented: Read as '0' bit 3-0 HLVDL[3:0]: High/Low-Voltage Detection Limit bits 1111 = External analog input is used (input comes from the HLVDIN pin) 1110 = Trip Point 1<sup>(1)</sup> 1101 = Trip Point 2<sup>(1)</sup> 1100 = Trip Point 3<sup>(1)</sup> 0000 = Trip Point 15<sup>(1)</sup> Note 1: For the actual trip point, see Section 27.0 "Electrical Characteristics". # 19.0 12-BIT A/D CONVERTER WITH THRESHOLD DETECT Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the 12-Bit A/D Converter with Threshold Detect, refer to "12-Bit A/D Converter with Threshold Detect" (www.microchip.com/DS39739) in the "dsPIC33/PIC24F Family Reference Manual". The PIC24F 12-bit A/D Converter has the following key features: - Successive Approximation Register (SAR) Conversion - · Conversion Speeds of Up to 100 ksps - Up to 32 Analog Input Channels (internal and external) - · Multiple Internal Reference Input Channels - External Voltage Reference Input Pins - Unipolar Differential Sample-and-Hold (S/H) Amplifier - Automated Threshold Scan and Compare Operation to Pre-Evaluate Conversion Results - · Selectable Conversion Trigger Source - Fixed-Length (one word per channel), Configurable Conversion Result Buffer - · Four Options for Results Alignment - · Configurable Interrupt Generation - · Operation During CPU Sleep and Idle modes The 12-bit A/D Converter module is an enhanced version of the 10-bit module offered in some PIC24 devices. Both modules are Successive Approximation Register (SAR) converters at their cores, surrounded by a range of hardware features for flexible configuration. This version of the module extends functionality by providing 12-bit resolution, a wider range of automatic sampling options and tighter integration with other analog modules, such as the CTMU, and a configurable results buffer. There is a legacy 10-bit mode on this A/D to allow the option to run with lower resolution in order to obtain higher throughput. This module also includes a unique Threshold Detect feature that allows the module itself to make simple decisions based on the conversion results. A simplified block diagram for the module is illustrated in Figure 19-1. To perform an A/D conversion: - 1. Configure the A/D module: - a) Configure the port pins as analog inputs and/or select band gap reference inputs (ANSx registers). - Select the voltage reference source to match the expected range on the analog inputs (AD1CON2[15:13]). - Select the analog conversion clock to match the desired data rate with the processor clock (AD1CON3[7:0]). - d) Select the appropriate sample/conversion sequence (AD1CON1[7:4] and AD1CON3[12:8]). - e) Configure the MODE12 bit to select A/D resolution (AD1CON1[10]). - Select how conversion results are presented in the buffer (AD1CON1[9:8]). - g) Select the interrupt rate (AD1CON2[6:2]). - h) Turn on the A/D module (AD1CON1[15]). - 2. Configure the A/D interrupt (if required): - a) Clear the AD1IF bit. - b) Select the A/D interrupt priority. To perform an A/D sample and conversion using Threshold Detect scanning: - 1. Configure the A/D module: - a) Configure the port pins as analog inputs (ANSx registers). - Select the voltage reference source to match the expected range on the analog inputs (AD1CON2[15:13]). - Select the analog conversion clock to match the desired data rate with the processor clock (AD1CON3[7:0]). - d) Select the appropriate sample/conversion sequence (AD1CON1[7:4] and AD1CON3[12:8]). - e) Configure the MODE12 bit to select A/D resolution (AD1CON1[10]). - Select how the conversion results are presented in the buffer (AD1CON1[9:8]). - g) Select the interrupt rate (AD1CON2[6:2]). - 2. Configure the threshold compare channels: - a) Enable auto-scan; set the ASEN bit (AD1CON5[15]). - b) Select the Compare mode, "Greater Than, Less Than or Windowed"; set the CMx bits (AD1CON5[1:0]). - Select the threshold compare channels to be scanned (AD1CSSH, AD1CSSL). - d) If the CTMU is required as a current source for a threshold compare channel, enable the corresponding CTMU channel (AD1CTMENH, AD1CTMENL). - e) Write the threshold values into the corresponding ADC1BUFx registers. - f) Turn on the A/D module (AD1CON1[15]). Note: If performing an A/D sample and conversion, using Threshold Detect in Sleep Mode, the RC A/D clock source must be selected before entering into Sleep mode. - 3. Configure the A/D interrupt (OPTIONAL): - a) Clear the AD1IF bit. - b) Select the A/D interrupt priority. #### 19.1 A/D Control Registers The 12-bit A/D Converter module uses up to 43 registers for its operation. All registers are mapped in the data memory space. #### 19.1.1 CONTROL REGISTERS Depending on the specific device, the module has up to eleven control and status registers: - · AD1CON1: A/D Control Register 1 - AD1CON2: A/D Control Register 2 - AD1CON3: A/D Control Register 3 - AD1CON5: A/D Control Register 5 - AD1CHS: A/D Sample Select Register - AD1CHITH and AD1CHITL: A/D Scan Compare Hit Registers - AD1CSSH and AD1CSSL: A/D Input Scan Select Registers - AD1CTMENH and AD1CTMENL: CTMU Enable Registers The AD1CON1, AD1CON2 and AD1CON3 registers (Register 19-1, Register 19-2 and Register 19-3) control the overall operation of the A/D module. This includes enabling the module, configuring the conversion clock and voltage reference sources, selecting the sampling and conversion Triggers, and manually controlling the sample/convert sequences. The AD1CON5 register (Register 19-4) specifically controls features of the Threshold Detect operation, including its function in power-saving modes. The AD1CHS register (Register 19-5) selects the input channels to be connected to the S/H amplifier. It also allows the choice of input multiplexers and the selection of a reference source for differential sampling. The AD1CHITH and AD1CHITL registers (Register 19-6 and Register 19-7) are semaphore registers used with Threshold Detect operations. The status of individual bits, or bit pairs in some cases, indicates if a match condition has occurred. AD1CHITL is always implemented, whereas AD1CHITH may not be implemented in devices with 16 or fewer channels. The AD1CSSH/L registers (Register 19-8 and Register 19-9) select the channels to be included for sequential scanning. The AD1CTMENH/L registers (Register 19-10 and Register 19-11) select the channel(s) to be used by the CTMU during conversions. Selecting a particular channel allows the A/D Converter to control the CTMU (particularly, its current source) and read its data through that channel. AD1CTMENL is always implemented, whereas AD1CTMENH may not be implemented in devices with 16 or fewer channels. #### 19.1.2 A/D RESULT BUFFERS The module incorporates a multi-word, dual port buffer, called ADC1BUFx. Each of the locations is mapped into the data memory space and is separately addressable. The buffer locations are referred to as ADC1BUF0 through ADC1BUFx (x = up to 17). The A/D result buffers are both readable and writable. When the module is active (AD1CON[15] = 1), the buffers are read-only and store the results of A/D conversions. When the module is inactive (AD1CON[15] = 0), the buffers are both readable and writable. In this state, writing to a buffer location programs a conversion threshold for Threshold Detect operations. Buffer contents are not cleared when the module is deactivated with the ADON bit (AD1CON1[15]). Conversion results and any programmed threshold values are maintained when ADON is set or cleared. #### REGISTER 19-1: AD1CON1: A/D CONTROL REGISTER 1 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|--------|-----|-----|--------|-------|-------| | ADON | _ | ADSIDL | _ | _ | MODE12 | FORM1 | FORM0 | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | HSC/R/W-0 | HSC/R/C-0 | |-------|-------|-------|-------|-----|-------|-----------|-----------| | SSRC3 | SSRC2 | SSRC1 | SSRC0 | _ | ASAM | SAMP | DONE | | bit 7 | | | | | | | bit 0 | | Legend: C = Clearable bit | | U = Unimplemented bit, | U = Unimplemented bit, read as '0' | | | |---------------------------|------------------|------------------------|------------------------------------|--|--| | R = Readable bit | W = Writable bit | HSC = Hardware Settab | ole/Clearable bit | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | | bit 15 ADON: A/D Operating Mode bit 1 = A/D Converter is operating 0 = A/D Converter is off bit 14 Unimplemented: Read as '0' bit 13 ADSIDL: A/D Stop in Idle Mode bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode bit 12-11 Unimplemented: Read as '0' bit 10 MODE12: 12-Bit A/D Operation Mode bit 1 = 12-bit A/D operation0 = 10-bit A/D operation bit 9-8 **FORM[1:0]:** Data Output Format bits (see the following formats) 11 = Fractional result, signed, left justified 10 = Absolute fractional result, unsigned, left justified 01 = Decimal result, signed, right justified 00 = Absolute decimal result, unsigned, right justified bit 7-4 SSRC[3:0]: Sample Clock Source Select bits 1111 = Reserved • • 1101 = Reserved 1100 = CLC2 event ends sampling and starts conversion 1011 = SCCP4 Capture/Compare Event or Timer (CCP4IF/CCT4IF) ends sampling and starts conversion 1010 = MCCP3 Capture/Compare Event or Timer (CCP3IF/CCT3IF) ends sampling and starts conversion 1001 = MCCP2 Capture/Compare Event or Timer (CCP2IF/CCT2IF) ends sampling and starts conversion 1000 = CLC1 event ends sampling and starts conversion 0111 = Internal counter ends sampling and starts conversion (auto-convert) 0110 = TMR1 Sleep mode Trigger event ends sampling and starts conversion<sup>(1)</sup> 0101 = TMR1 event ends sampling and starts conversion 0100 = CTMU event ends sampling and starts conversion 0011 = SCCP5 Capture/Compare Event or Timer (CCP5IF/CCT5IF) ends sampling and starts conversion 0010 = MCCP1 Capture/Compare Event or Timer (CCP1IF/CCT1IF) ends sampling and starts conversion 0001 = INT0 event ends sampling and starts conversion 0000 = Clearing the Sample bit ends sampling and starts conversion **Note 1:** This version of the TMR1 Trigger allows A/D conversions to be triggered from TMR1 while the device is operating in Sleep mode. The SSRC[3:0] = 0101 option allows conversions to be triggered in Run or Idle modes only. #### REGISTER 19-1: AD1CON1: A/D CONTROL REGISTER 1 (CONTINUED) bit 3 Unimplemented: Read as '0' bit 2 ASAM: A/D Sample Auto-Start bit 1 = Sampling begins immediately after the last conversion; SAMP bit is auto-set 0 = Sampling begins when the SAMP bit is manually set bit 1 SAMP: A/D Sample Enable bit 1 = A/D Sample-and-Hold amplifiers are sampling0 = A/D Sample-and-Hold amplifiers are holding bit 0 **DONE:** A/D Conversion Status bit 1 = A/D conversion cycle has completed 0 = A/D conversion cycle has not started or is in progress **Note 1:** This version of the TMR1 Trigger allows A/D conversions to be triggered from TMR1 while the device is operating in Sleep mode. The SSRC[3:0] = 0101 option allows conversions to be triggered in Run or Idle modes only. #### REGISTER 19-2: AD1CON2: A/D CONTROL REGISTER 2 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | |--------|--------|--------|-----|----------|-------|-----|-------| | PVCFG1 | PVCFG0 | NVCFG0 | _ | BUFREGEN | CSCNA | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |---------------------|-------|-------|-------|-------|-------|---------------------|-------| | BUFS <sup>(1)</sup> | SMPI4 | SMPI3 | SMPI2 | SMPI1 | SMPI0 | BUFM <sup>(1)</sup> | ALTS | | bit 7 | | | | | | | bit 0 | | Legend: | | | | |-------------------|------------------|-----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented bit | , read as '0' | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | bit 15-14 **PVCFG[1:0]:** A/D Converter Positive Voltage Reference Configuration bits 11 = 4 \* Internal VBG(2) 10 = 2 \* Internal VBG<sup>(3)</sup> 01 = External VREF+ 00 = AVDD bit 13 NVCFG0: A/D Converter Negative Voltage Reference Configuration bit 1 = External VREF- 0 = AVss bit 12 **Unimplemented:** Read as '0' bit 11 BUFREGEN: A/D Buffer Register Enable bit 1 = Conversion result is loaded into a buffer location determined by the converted channel 0 = A/D result buffer is treated as a FIFO bit 10 CSCNA: Scan Input Selections for CH0+ S/H Input for MUX A Setting bit 1 = Scans inputs 0 = Does not scan inputs bit 9-8 **Unimplemented:** Read as '0' bit 7 **BUFS:** A/D Buffer Fill Status bit<sup>(1)</sup> ${\tt 1}$ = A/D is filling the upper half of the buffer; user should access data in the lower half 0 = A/D is filling the lower half of the buffer; user should access data in the upper half bit 6-2 SMPI[4:0]: Interrupt Sample Rate Select bits 11111 = Interrupts at the completion of the conversion for each 32nd sample 11110 = Interrupts at the completion of the conversion for each 31st sample • • 00001 = Interrupts at the completion of the conversion for every other sample 00000 = Interrupts at the completion of the conversion for each sample bit 1 **BUFM:** A/D Buffer Fill Mode Select bit<sup>(1)</sup> 1 = Starts filling the buffer at address, ADC1BUF0, on the first interrupt and ADC1BUF(x/2) on the next interrupt (Split Buffer mode) 0 = Starts filling the buffer at address, ADC1BUF0, and each sequential address on successive interrupts (FIFO mode) bit 0 ALTS: Alternate Input Sample Mode Select bit 1 = Uses channel input selects for Sample A on the first sample and Sample B on the next sample 0 = Always uses channel input selects for Sample A Note 1: This is only applicable when the buffer is used in FIFO mode (BUFREGEN = 0). In addition, BUFS is only used when BUFM = 1. 2: PIC24FV16KMXXX devices only. Reference setting will not be within specification for VDD below 4.5V. 3: Reference setting will not be within specification for VDD below 2.3V. #### REGISTER 19-3: AD1CON3: A/D CONTROL REGISTER 3 | R/W-0 | R-0 | r-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|--------|-----|-------|-------|-------|-------|-------| | ADRC | EXTSAM | _ | SAMC4 | SAMC3 | SAMC2 | SAMC1 | SAMC0 | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|--------|-------|-------|-------| | | | | ADC | S[7:0] | | | | | bit 7 | | | | | | | bit 0 | Legend:r = Reserved bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown bit 15 ADRC: A/D Conversion Clock Source bit 1 = RC clock 0 = Clock is derived from the system clock bit 14 **EXTSAM:** Extended Sampling Time bit 1 = A/D is still sampling after SAMP = 0 0 = A/D is finished sampling bit 13 Reserved: Maintain as '0' bit 12-8 **SAMC[4:0]:** Auto-Sample Time Select bits 11111 = **31** TAD • • 00001 = 1 TAD 00000 = **0** TAD bit 7-0 ADCS[7:0]: A/D Conversion Clock Select bits 111111111-01000000 = Reserved 00111111 = 64 \* Tcy = TAD • • 00000001 = 2 \* TCY = TAD 00000000 = Tcy = TAD #### REGISTER 19-4: AD1CON5: A/D CONTROL REGISTER 5 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | r-0 | U-0 | R/W-0 | R/W-0 | |---------------------|-------|--------|-------|-----|-----|--------|--------| | ASEN <sup>(1)</sup> | LPEN | CTMREQ | BGREQ | _ | _ | ASINT1 | ASINT0 | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-------|-------|-------|-------| | _ | _ | _ | _ | WM1 | WM0 | CM1 | CM0 | | bit 7 | | | | | | | bit 0 | Legend:r = Reserved bitR = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown - bit 15 **ASEN:** A/D Auto-Scan Enable bit<sup>(1)</sup> - 1 = Auto-scan is enabled - 0 = Auto-scan is disabled - bit 14 LPEN: A/D Low-Power Enable bit - 1 = Returns to Low-Power mode after scan - 0 = Remains in Full-Power mode after scan - bit 13 **CTMREQ:** CTMU Request bit - 1 = CTMU is enabled when the A/D is enabled and active - 0 = CTMU is not enabled by the A/D - bit 12 BGREQ: Band Gap Request bit - 1 = Band gap is enabled when the A/D is enabled and active - 0 = Band gap is not enabled by the A/D - bit 11 Reserved: Maintain as '0' - bit 10 Unimplemented: Read as '0' - bit 9-8 ASINT[1:0]: Auto-Scan (Threshold Detect) Interrupt Mode bits - 11 = Interrupt after a Threshold Detect sequence has completed and a valid compare has occurred - 10 = Interrupt after a valid compare has occurred - 01 = Interrupt after a Threshold Detect sequence has completed - 00 = No interrupt - bit 7-4 Unimplemented: Read as '0' - bit 3-2 WM[1:0]: A/D Write Mode bits - 11 = Reserved - 10 = Auto-compare only (conversion results are not saved, but interrupts are generated when a valid match, as defined by the CMx and ASINTx bits, occurs) - 01 = Convert and save (conversion results are saved to locations as determined by the register bits when a match, as defined by the CMx bits, occurs) - 00 = Legacy operation (conversion data are saved to a location determined by the buffer register bits) - bit 1-0 CM[1:0]: A/D Compare Mode bits - 11 = Outside Window mode (valid match occurs if the conversion result is outside of the window defined by the corresponding buffer pair) - 10 = Inside Window mode (valid match occurs if the conversion result is inside the window defined by the corresponding buffer pair) - 01 = Greater Than mode (valid match occurs if the result is greater than the value in the corresponding buffer register) - 00 = Less Than mode (valid match occurs if the result is less than the value in the corresponding buffer register) - **Note 1:** When using auto-scan with Threshold Detect (ASEN = 1), do not configure the sample clock source to Auto-Convert mode (SSRC[3:0] = 7). Any other available SSRC selection is valid. To use auto-convert as the sample clock source (SSRC[3:0] = 7), make sure ASEN is cleared. #### REGISTER 19-5: AD1CHS: A/D SAMPLE SELECT REGISTER W = Writable bit | R/W-0 |--------|--------|--------|--------|--------|--------|--------|--------| | CH0NB2 | CH0NB1 | CH0NB0 | CH0SB4 | CH0SB3 | CH0SB2 | CH0SB1 | CH0SB0 | | bit 15 | | | | | | | bit 8 | | R/W-0 |--------|--------|--------|--------|--------|--------|--------|--------| | CH0NA2 | CH0NA1 | CH0NA0 | CH0SA4 | CH0SA3 | CH0SA2 | CH0SA1 | CH0SA0 | | bit 7 | | | | | | | bit 0 | U = Unimplemented bit, read as '0' ``` -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-13 CHONB[2:0]: Sample B Channel 0 Negative Input Select bits 111 = AN6<sup>(1)</sup> 110 = AN5<sup>(2)</sup> 101 = AN4 100 = AN3 011 = AN2 010 = AN1 001 = AN0 000 = AVss bit 12-8 CH0SB[4:0]: S/H Amplifier Positive Input Select for MUX B Multiplexer Setting bits 11111 = Unimplemented, do not use 11110 = AVDD^{(3)} 11101 = AVss<sup>(3)</sup> 11100 = Upper guardband rail (0.785 * VDD) 11011 = Lower guardband rail (0.215 * VDD) 11010 = Internal Band Gap Reference (VBG)(3) 11000-11001 = Unimplemented, do not use 10001 = No channels are connected, all inputs are floating (used for CTMU) 10111 = No channels are connected, all inputs are floating (used for CTMU) 10110 = No channels are connected, all inputs are floating (used for CTMU temperature sensor input); does not require the corresponding CTMEN22 (AD1CTMENH[6]) bit) 10101 = Channel 0 positive input is AN21 10100 = Channel 0 positive input is AN20 10011 = Channel 0 positive input is AN19 10010 = Channel 0 positive input is AN18<sup>(2)</sup> 10001 = Channel 0 positive input is AN17<sup>(2)</sup> ``` - Note 1: This is implemented on 44-pin devices only. - This is implemented on 28-pin and 44-pin devices only. 01001 = Channel 0 positive input is AN9 01000 = Channel 0 positive input is AN8<sup>(1)</sup> 00111 = Channel 0 positive input is AN7<sup>(1)</sup> 00110 = Channel 0 positive input is AN6<sup>(1)</sup> 00101 = Channel 0 positive input is AN5<sup>(2)</sup> 00100 = Channel 0 positive input is AN4 00011 = Channel 0 positive input is AN3 00010 = Channel 0 positive input is AN2 00001 = Channel 0 positive input is AN1 00000 = Channel 0 positive input is AN1 3: The band gap value used for this input is 2x or 4x the internal VBG, which is selected when PVCFG[1:0] = 1x. Legend: R = Readable bit #### REGISTER 19-5: AD1CHS: A/D SAMPLE SELECT REGISTER (CONTINUED) bit 7-5 CH0NA[2:0]: Sample A Channel 0 Negative Input Select bits The same definitions as for CHONB[2:0]. bit 4-0 CH0SA[4:0]: Sample A Channel 0 Positive Input Select bits The same definitions as for CHONA[4:0]. Note 1: This is implemented on 44-pin devices only. 2: This is implemented on 28-pin and 44-pin devices only. 3: The band gap value used for this input is 2x or 4x the internal VBG, which is selected when PVCFG[1:0] = 1x. ### REGISTER 19-6: AD1CHITH: A/D SCAN COMPARE HIT REGISTER (HIGH WORD)(1) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|----------------------|-------|-------|-------| | | | | CHH[2 | 3:16] <sup>(2)</sup> | | | | | bit 7 | | | | | | | bit 0 | #### Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 **Unimplemented:** Read as '0'. bit 7-0 CHH[23:16]: A/D Compare Hit bits<sup>(2)</sup> If CM[1:0] = 11: 1 = A/D Result Buffer x has been written with data or a match has occurred 0 = A/D Result Buffer x has not been written with data For All Other Values of CM[1:0]: 1 = A match has occurred on A/D Result Channel x 0 = No match has occurred on A/D Result Channel x Note 1: Unimplemented channels are read as '0'. 2: The CHH[18:17] bits are not implemented in 20-pin devices. ### REGISTER 19-7: AD1CHITL: A/D SCAN COMPARE HIT REGISTER (LOW WORD)(1) | R/W-0 | |----------------------------|-------|-------|-------|-------|-------|-------|-------|--| | CHH[15:8] <sup>(2,3)</sup> | | | | | | | | | | bit 15 | | | | | | | bit 8 | | | R/W-0 |-------|-------|-------|-------|-----------------------|-------|-------|-------| | | | | CHH[7 | 7:0] <sup>(2,3)</sup> | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-0 **CHH[15:0]:** A/D Compare Hit bits<sup>(2,3)</sup> If CM[1:0] = 11: 1 = A/D Result Buffer x has been written with data or a match has occurred 0 = A/D Result Buffer x has not been written with data For All Other Values of CM[1:0]: 1 = A match has occurred on A/D Result Channel x 0 = No match has occurred on A/D Result Channel x Note 1: Unimplemented channels are read as '0'. 2: The CHH[8:5] bits are not implemented in 20-pin devices. 3: The CHH[8:6] bits are not implemented in 28-pin devices. #### REGISTER 19-8: AD1CSSH: A/D INPUT SCAN SELECT REGISTER (HIGH WORD)(1) | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | |--------|-------|-------|------------|-------|-------|-----|-------| | _ | | | CSS[30:26] | | | _ | _ | | bit 15 | | | _ | | _ | | bit 8 | | R/W-0 |-------|-------|-------|-------|----------------------|-------|-------|-------| | | | | CSS[2 | 3:16] <sup>(2)</sup> | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **Unimplemented:** Read as '0' bit 14-10 CSS[30:26]: A/D Input Scan Selection bits 1 = Includes the corresponding channel for input scan 0 = Skips the channel for input scan bit 9-8 **Unimplemented:** Read as '0' bit 7-0 CSS[23:16]: A/D Input Scan Selection bits<sup>(2)</sup> 1 = Includes the corresponding channel for input scan 0 = Skips the channel for input scan **Note 1:** Unimplemented channels are read as '0'. Do not select unimplemented channels for sampling as indeterminate results may be produced. 2: The CSS[18:17] bits are not implemented in 20-pin devices. #### REGISTER 19-9: AD1CSSL: A/D INPUT SCAN SELECT REGISTER (LOW WORD)(1) | R/W-0 |--------|-------|-------|-------|-----------------------|-------|-------|-------| | | | | CSS[1 | 5:8] <sup>(2,3)</sup> | | | | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-----------------------|-------|-------|-------| | | | | CSS[7 | ′:0] <sup>(2,3)</sup> | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15-0 CSS[15:0]: A/D Input Scan Selection bits<sup>(2,3)</sup> 1 = Includes the corresponding ANx input for scan 0 = Skips the channel for input scan **Note 1:** Unimplemented channels are read as '0'. Do not select unimplemented channels for sampling as indeterminate results may be produced. 2: The CSS[8:5] bits are not implemented in 20-pin devices. 3: The CSS[8:6] bits are not implemented in 28-pin devices. #### REGISTER 19-10: AD1CTMENH: CTMU ENABLE REGISTER (HIGH WORD)(1) | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|------------------------|-------|-------|-------| | | | | CTMEN | [23:16] <sup>(2)</sup> | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 Unimplemented: Read as '0'. bit 7-0 CTMEN[23:16]: CTMU Enabled During Conversion bits<sup>(2)</sup> 1 = CTMU is enabled and connected to the selected channel during conversion 0 = CTMU is not connected to this channel Note 1: Unimplemented channels are read as '0'. 2: The CTMEN[18:17] bits are not implemented in 20-pin devices. ### REGISTER 19-11: AD1CTMENL: CTMU ENABLE REGISTER (LOW WORD)(1) | R/W-0 |--------|-------|-------|-------|-------------------------|-------|-------|-------| | | | | CTMEN | [15:8] <sup>(2,3)</sup> | | | | | bit 15 | | | | | | | bit 8 | | R/W-0 | |-----------------------------|-------|-------|-------|-------|-------|-------|-------|--| | CTMEN[7:0] <sup>(2,3)</sup> | | | | | | | | | | bit 7 | | | | | | | bit 0 | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-0 CTMEN[15:0]: CTMU Enabled During Conversion bits<sup>(2,3)</sup> 1 = CTMU is enabled and connected to the selected channel during conversion 0 = CTMU is not connected to this channel Note 1: Unimplemented channels are read as '0'. 2: The CTMEN[8:5] bits are not implemented in 20-pin devices. 3: The CTMEN[8:6] bits are not implemented in 28-pin devices. #### 19.2 A/D Sampling Requirements The analog input model of the 12-bit A/D Converter is shown in Figure 19-2. The total sampling time for the A/D is a function of the holding capacitor charge time. For the A/D Converter to meet its specified accuracy, the Charge Holding Capacitor (CHOLD) must be allowed to fully charge to the voltage level on the analog input pin. The Source Impedance (Rs), the Interconnect Impedance (Ric) and the Internal Sampling Switch Impedance (Rss) combine to directly affect the time required to charge CHOLD. The combined impedance of the analog sources must, therefore, be small enough to fully charge the holding capacitor within the chosen sample time. To minimize the effects of pin leakage currents on the accuracy of the A/D Converter, the maximum recommended source impedance, Rs, is 2.5 k $\Omega$ . After the analog input channel is selected (changed), this sampling function must be completed prior to starting the conversion. The internal holding capacitor will be in a Discharged state prior to each sample operation. At least 1 TAD time period should be allowed between conversions for the sample time. For more details, see Section 27.0 "Electrical Characteristics" #### **EQUATION 19-1: A/D CONVERSION CLOCK PERIOD** $$TAD = TCY (ADCS + 1)$$ $$ADCS = \frac{TAD}{TCY} - 1$$ Based on Tcy = 2/Fosc; Doze mode Note: and PLL are disabled. #### **FIGURE 19-2:** 12-BIT A/D CONVERTER ANALOG INPUT MODEL #### 19.3 Transfer Function The transfer functions of the A/D Converter in 12-bit resolution are shown in Figure 19-3. The difference of the input voltages (VINH - VINL) is compared to the reference ((VR+) - (VR-)). - The first code transition occurs when the input voltage is ((VR+) – (VR-))/4096 or 1.0 LSb. - The '0000 0000 0001' code is centered at VR- + (1.5 \* ((VR+) (VR-))/4096). - The '0010 0000 0000' code is centered at VREFL + (2048.5 \* ((VR+) – (VR-))/4096). - An input voltage less than VR- + (((VR-) (VR-))/4096) converts as '0000 0000 0000'. - An input voltage greater than (VR-) + (4095 ((VR+) – (VR-))/4096) converts as '1111 1111 1111'. FIGURE 19-3: 12-BIT A/D TRANSFER FUNCTION #### 19.4 Buffer Data Formats The A/D conversions are fully differential 12-bit values when MODE12 = 1 (AD1CON1[10]) and 10-bit values when MODE12 = 0. When absolute fractional or absolute integer formats are used, the results are 12 or 10 bits wide, respectively. When signed decimal formatting is used, the conversion also includes a Sign bit, making 12-bit conversions 13 bits wide and 10-bit conversions 11 bits wide. The signed decimal format yields 12-bit and 10-bit values, respectively. The Sign bit (bit 12 or bit 10) is sign-extended to fill the buffer. The FORM[1:0] bits (AD1CON1[9:8]) select the format. Figure 19-4 and Figure 19-5 show the data output formats that can be selected. Table 19-1 through Table 19-4 show the numerical equivalents for the various conversion result codes. #### FIGURE 19-4: A/D OUTPUT DATA FORMATS (12-BIT) | RAM Contents: | | | | | d11 | d10 | d09 | d08 | d07 | d06 | d05 | d04 | d03 | d02 | d01 | d00 | |--------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------------------| | Read to Bus: | | | | | | | | | | | | | | | | · · · · · · · · · | | Integer | 0 | 0 | 0 | 0 | d11 | d10 | d09 | d08 | d07 | d06 | d05 | d04 | d03 | d02 | d01 | d00 | | | | | | | | | | | | | | | | | | | | Signed Integer | s0 | s0 | s0 | s0 | d11 | d10 | d09 | d08 | d07 | d06 | d05 | d04 | d03 | d02 | d01 | d00 | | | - | | | | | | | | | | | | | | | | | Fractional (1.15) | d11 | d10 | d09 | d08 | d07 | d06 | d05 | d04 | d03 | d02 | d01 | d00 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Signed Fractional (1.15) | s0 | d11 | d10 | d09 | d08 | d07 | d06 | d05 | d04 | d03 | d02 | d01 | d00 | 0 | 0 | 0 | | | | • | • | • | • | • | | • | • | • | | • | | • | • | | TABLE 19-1: NUMERICAL EQUIVALENTS OF VARIOUS RESULT CODES: 12-BIT INTEGER FORMATS | Vin/Vref | 12-Bit Differential<br>Output Code<br>(13-bit result) | 16-Bit Integer Format/<br>Equivalent Decimal Value | | 16-Bit Signed Integer Format/<br>Equivalent Decimal Value | | | |------------|-------------------------------------------------------|----------------------------------------------------|-------|-----------------------------------------------------------|-------|--| | +4095/4096 | 0 1111 1111 1111 | 0000 1111 1111 1111 | +4095 | 0000 1111 1111 1111 | +4095 | | | +4094/4096 | 0 1111 1111 1110 | 0000 1111 1111 1110 | +4094 | 0000 1111 1111 1110 | +4094 | | | | | • • • | | | | | | +1/4096 | 0 1000 0000 0001 | 0000 0000 0000 0001 | +1 | 0000 0000 0000 0001 | +1 | | | 0/4096 | 0 0000 0000 0000 | 0000 0000 0000 0000 | 0 | 0000 0000 0000 0000 | 0 | | | -1/4096 | 1 0111 1111 1111 | 0000 0000 0000 0000 | 0 | 1111 1111 1111 1111 | -1 | | | | | • • • | | | | | | -4095/4096 | 1 0000 0000 0001 | 0000 0000 0000 0000 | 0 | 1111 0000 0000 0001 | -4095 | | | -4096/4096 | 1 0000 0000 0000 | 0000 0000 0000 0000 | 0 | 1111 0000 0000 0000 | -4096 | | TABLE 19-2: NUMERICAL EQUIVALENTS OF VARIOUS RESULT CODES: 12-BIT FRACTIONAL FORMATS | Vin/VREF | 12-Bit<br>Output Code | 16-Bit Fractional Format/ 16-Bit Signed Fractional Fequivalent Decimal Value Equivalent Decimal Va | | | | |------------|-----------------------|----------------------------------------------------------------------------------------------------|-------|---------------------|--------| | +4095/4096 | 0 1111 1111 1111 | 1111 1111 1111 0000 | 0.999 | 0111 1111 1111 1000 | 0.999 | | +4094/4096 | 0 1111 1111 1110 | 1111 1111 1110 0000 | 0.998 | 0111 1111 1110 1000 | 0.998 | | | | • • • | | | | | +1/4096 | 0 0000 0000 0001 | 0000 0000 0001 0000 | 0.001 | 0000 0000 0000 1000 | 0.001 | | 0/4096 | 0 0000 0000 0000 | 0000 0000 0000 0000 | 0.000 | 0000 0000 0000 0000 | 0.000 | | -1/4096 | 1 0111 1111 1111 | 0000 0000 0000 0000 | 0.000 | 1111 1111 1111 1000 | -0.001 | | | | ••• | | | | | -4095/4096 | 1 0000 0000 0001 | 0000 0000 0000 0000 | 0.000 | 1000 0000 0000 1000 | -0.999 | | -4096/4096 | 1 0000 0000 0000 | 0000 0000 0000 0000 | 0.000 | 1000 0000 0000 0000 | -1.000 | FIGURE 19-5: A/D OUTPUT DATA FORMATS (10-BIT) TABLE 19-3: NUMERICAL EQUIVALENTS OF VARIOUS RESULT CODES: 10-BIT INTEGER FORMATS | Vin/Vref | 10-Bit Differential<br>Output Code<br>(11-bit result) | 16-Bit Integer Format/ 16-Bit Signed Integer For Equivalent Decimal Value Equivalent Decimal Val | | | | |------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------|------|---------------------|-------| | +1023/1024 | 011 1111 1111 | 0000 0011 1111 1111 | 1023 | 0000 0001 1111 1111 | 1023 | | +1022/1024 | 011 1111 1110 | 0000 0011 1111 1110 | 1022 | 0000 0001 1111 1110 | 1022 | | | | • • • | | | | | +1/1024 | 000 0000 0001 | 0000 0000 0000 0001 | 1 | 0000 0000 0000 0001 | 1 | | 0/1024 | 000 0000 0000 | 0000 0000 0000 0000 | 0 | 0000 0000 0000 0000 | 0 | | -1/1024 | 101 1111 1111 | 0000 0000 0000 0000 | 0 | 1111 1111 1111 1111 | -1 | | | | • • • | | | | | -1023/1024 | 100 0000 0001 | 0000 0000 0000 0000 | 0 | 1111 1110 0000 0001 | -1023 | | -1024/1024 | 100 0000 0000 | 0000 0000 0000 0000 | 0 | 1111 1110 0000 0000 | -1024 | ## TABLE 19-4: NUMERICAL EQUIVALENTS OF VARIOUS RESULT CODES: 10-BIT FRACTIONAL FORMATS | Vin/Vref | 10-Bit Differential<br>Output Code<br>(11-bit result) | 16-Bit Fractional Format<br>Equivalent Decimal Value | 16-Bit Signed Fractional Format/<br>Equivalent Decimal Value | | | |------------|-------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------|---------------------|--------| | +1023/1024 | 011 1111 1111 | 1111 1111 1100 0000 | 0.999 | 0111 1111 1110 0000 | 0.999 | | +1022/1024 | 011 1111 1110 | 1111 1111 1000 0000 | 0.998 | 0111 1111 1000 0000 | 0.998 | | | | ••• | | | | | +1/1024 | 000 0000 0001 | 0000 0000 0100 0000 | 0.001 | 0000 0000 0010 0000 | 0.001 | | 0/1024 | 000 0000 0000 | 0000 0000 0000 0000 | 0.000 | 0000 0000 0000 0000 | 0.000 | | -1/1024 | 101 1111 1111 | 0000 0000 0000 0000 | 0.000 | 1111 1111 1110 0000 | -0.001 | | | | ••• | | | | | -1023/1024 | 100 0000 0001 | 0000 0000 0000 0000 | 0.000 | 1000 0000 0010 0000 | -0.999 | | -1024/1024 | 100 0000 0000 | 0000 0000 0000 0000 | 0.000 | 1000 0000 0000 0000 | -1.000 | | NO | T | E | S | | |----|---|---|---|--| |----|---|---|---|--| # 20.0 8-BIT DIGITAL-TO-ANALOG CONVERTER (DAC) PIC24FV16KM204 family devices include two 8-bit Digital-to-Analog Converters (DACs) for generating analog outputs from digital data. A simplified block diagram for a single DAC is shown in Figure 20-1. Both of the DACs are identical. The DAC generates an analog output voltage based on the digital input code, according to the formula: $$V_{DAC} = \frac{V_{DACREF} \times DACxDAT}{256}$$ where *VDAC* is the analog output voltage and *VDACREF* is the reference voltage selected by DACREF[1:0]. Each DAC includes these features: - · Precision 8-Bit Resistor Ladder for High Accuracy - Fast Settling Time, Supporting 1 Msps Effective Sampling Rates - Three User-Selectable Voltage Reference Options - Multiple Conversion Trigger Options, Plus a Manual Convert-on-Write Option - · Left and Right Justified Input Data Options - · User-Selectable Sleep and Idle Mode Operation When using the DAC, it is recommended to set the ANSx and TRISx bits for the DACx output pin to configure it as an analog output. See **Section 11.2 "Configuring Analog Port Pins"** for more information. FIGURE 20-1: SINGLE DACX SIMPLIFIED BLOCK DIAGRAM #### REGISTER 20-1: DACxCON: DACx CONTROL REGISTER | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | |--------|-----|---------|--------|-------|-----|-------|---------| | DACEN | _ | DACSIDL | DACSLP | DACFM | _ | SRDIS | DACTRIG | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|----------|----------|----------|----------|----------|---------|---------| | DACOE | DACTSEL4 | DACTSEL3 | DACTSEL2 | DACTSEL1 | DACTSEL0 | DACREF1 | DACREF0 | | bit 7 | | | | | | | bit 0 | | Le | a | en | d | |----|---|----|---| | | | | | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 DACEN: DACx Enable bit 1 = Module is enabled 0 = Module is disabled bit 14 Unimplemented: Read as '0' bit 13 DACSIDL: DACx Stop in Idle Mode bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode bit 12 DACSLP: DACx Enable Peripheral During Sleep bit 1 = DACx continues to output the most recent value of DACxDAT during Sleep mode 0 = DACx is powered down in Sleep mode; DACxOUT pin is controlled by the TRISx and LATx bits bit 11 DACFM: DACx Data Format Select bit 1 = Data are left justified (data stored in DACxDAT[15:8]) 0 = Data are right justified (data stored in DACxDAT[7:0]) bit 10 **Unimplemented:** Read as '0' bit 9 SRDIS: Soft Reset Disable bit 1 = DACxCON and DACxDAT SFRs reset only on a POR or BOR Reset 0 = DACxCON and DACxDAT SFRs reset on any type of device Reset bit 8 DACTRIG: DACx Trigger Input Enable bit 1 = Analog output value updates when the selected (by DACTSEL[4:0]) event occurs 0 = Analog output value updates as soon as DACxDAT is written (DAC Trigger is ignored) bit 7 DACOE: DACx Output Enable bit 1 = DACx output pin is enabled and driven on the DACxOUT pin 0 = DACx output pin is disabled, DACx output is available internally to other peripherals only Note 1: BGBUF1 voltage is configured by BUFREF[1:0] (BUFCON0[1:0]). #### REGISTER 20-1: DACxCON: DACx CONTROL REGISTER (CONTINUED) ``` bit 6-2 DACTSEL[4:0]: DACx Trigger Source Select bits 11101-11111 = Unused 11100 = CTMU 11011 = A/D 11010 = Comparator 3 11001 = Comparator 2 11000 = Comparator 1 10011 to 10111 = Unused 10010 = CLC2 output 10001 = CLC1 output 01100 to 10000 = Unused 01011 = Timer1 Sync output 01010 = External Interrupt 2 01001 = External Interrupt 1 01000 = External Interrupt 0 0011x = Unused 00101 = MCCP5 or SCCP5 Sync output 00100 = MCCP4 or SCCP4 Sync output 00011 = MCCP3 or SCCP3 Sync output 00010 = MCCP2 or SCCP2 Sync output 00001 = MCCP1 or SCCP1 Sync output 00000 = Unused bit 1-0 DACREF[1:0]: DACx Reference Source Select bits 11 = Internal Band Gap Buffer 1 (BGBUF1)(1) 10 = AVDD 01 = DVREF+ 00 = Reference is not connected (lowest power but no DAC functionality) Note 1: BGBUF1 voltage is configured by BUFREF[1:0] (BUFCON0[1:0]). ``` #### REGISTER 20-2: BUFCON0: INTERNAL VOLTAGE REFERENCE CONTROL REGISTER 0 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-1 | |-------|-----|-----|-----|-----|-----|-------|---------| | _ | _ | _ | _ | _ | _ | BUFRI | EF[1:0] | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-2 **Unimplemented:** Read as '0' bit 1-0 BUFREF[1:0]: Internal Voltage Reference Select bits 11 = Reference output is set at 4 \* BGBUF1<sup>(1)</sup> 10 = Reference output is set at 2 \* BGBUF1(2) 01 = Reference output is set at BGBUF1 00 = Reserved, do not use **Note 1:** Available only on PIC24FV16KMXXX devices. The reference may not be within specifications for VDD below specified levels; see Table 27-15 for minimum VDD limits. 2: The reference may not be within specifications for VDD below specified levels; see Table 27-15 for minimum VDD limits. ## 21.0 DUAL OPERATIONAL AMPLIFIER MODULE Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information, refer to "Operational Amplifier (Op Amp)" (www.microchip.com/DS30505) in the "dsPIC33/PIC24F Family Reference Manual". Device-specific information in this data sheet supersedes the information in the "dsPIC33/PIC24F Family Reference Manual". PIC24FV16KM204 family devices include two operational amplifiers to complement the microcontroller's other analog features. They may be used to provide analog signal conditioning, either as stand-alone devices or in addition to other analog peripherals. The two op amps are functionally identical; the block diagram for a single amplifier is shown in Figure 21-1. Each op amp has these features: - · Internal Unity Gain Buffer Option - Multiple Input Options Each on the Inverting and Noninverting Amplifier Inputs - · Rail-to-Rail Input and Output Capabilities - User-Selectable Option for Regular or Low-Power Operation - User-Selectable Operation in Idle and Sleep Modes When using the op amps, it is recommended to set the ANSx and TRISx bits of both the input and output pins to configure them as analog pins. See Section 11.2 "Configuring Analog Port Pins" for more information. FIGURE 21-1: SINGLE OPERATIONAL AMPLIFIER BLOCK DIAGRAM #### REGISTER 21-1: AMPXCON: OP AMP x CONTROL REGISTER (1) | R/W-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |--------|-----|---------|--------|-----|-----|-----|-------| | AMPEN | _ | AMPSIDL | AMPSLP | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|---------|---------|---------|---------|---------|---------| | SPDSEL | _ | NINSEL2 | NINSEL1 | NINSEL0 | PINSEL2 | PINSEL1 | PINSEL0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' '1' = Bit is set -n = Value at POR '0' = Bit is cleared x = Bit is unknown bit 15 AMPEN: Op Amp x Control Module Enable bit > 1 = Module is enabled 0 = Module is disabled Unimplemented: Read as '0' bit 14 bit 13 AMPSIDL: Op Amp x Peripheral Stop in Idle Mode bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode bit 12 AMPSLP: Op Amp x Peripheral Enabled in Sleep Mode bit 1 = Continues module operation when device enters Sleep mode 0 = Discontinues module operation in Sleep mode bit 11-8 Unimplemented: Read as '0' bit 7 SPDSEL: Op Amp x Power/Speed Select bit 1 = Higher power and bandwidth (faster response time) 0 = Lower power and bandwidth (slower response time) bit 6 Unimplemented: Read as '0' bit 5-3 NINSEL[2:0]: Negative Op Amp Input Select bits 111 = Reserved; do not use 110 = Reserved; do not use 101 = Op amp negative input is connected to the op amp output (voltage follower) 100 = Reserved; do not use 011 = Reserved; do not use 010 = Op amp negative input is connected to the OAxIND pin 001 = Op amp negative input is connected to the OAxINB pin 000 = Op amp negative input is connected to AVss bit 2-0 PINSEL[2:0]: Positive Op Amp Input Select bits 111 = Op amp positive input is connected to the output of the A/D input multiplexer 110 = Reserved; do not use 101 = Op amp positive input is connected to the DAC1 output for OA1 (DAC2 output for OA2) 100 = Reserved; do not use 011 = Reserved; do not use 010 = Op amp positive input is connected to the OAxINC pin 001 = Op amp positive input is connected to the OAxINA pin 000 = Op amp positive input is connected to AVss Note 1: This register is available only on PIC24F(V)16KM2XX devices. #### 22.0 COMPARATOR MODULE Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Comparator module, refer to "Scalable Comparator Module" (www.microchip.com/DS39734) in the "dsPIC33/PIC24F Family Reference Manual". The comparator module provides three dual input comparators. The inputs to the comparator can be configured to use any one of four external analog inputs, as well as a voltage reference input from either the Internal Band Gap Buffer 1 (BGBUF1) or the comparator voltage reference generator. The comparator outputs may be directly connected to the CxOUT pins. When the respective COE bit equals '1', the I/O pad logic makes the unsynchronized output of the comparator available on the pin. A simplified block diagram of the module is shown in Figure 22-1. Diagrams of the possible individual comparator configurations are shown in Figure 22-2. Each comparator has its own control register, CMxCON (Register 22-1), for enabling and configuring its operation. The output and event status of all three comparators is provided in the CMSTAT register (Register 22-2). FIGURE 22-1: COMPARATOR x MODULE BLOCK DIAGRAM #### FIGURE 22-2: INDIVIDUAL COMPARATOR CONFIGURATIONS #### REGISTER 22-1: CMxCON: COMPARATOR x CONTROL REGISTERS | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R-0 | |--------|-------|-------|-------|-----|-----|-------|-------| | CON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | |-----------------------|-----------------------|-------|-------|-----|-----|-------|-------| | EVPOL1 <sup>(2)</sup> | EVPOL0 <sup>(2)</sup> | CREF1 | CREF0 | _ | _ | CCH1 | CCH0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **CON:** Comparator x Enable bit 1 = Comparator is enabled 0 = Comparator is disabled bit 14 **COE**: Comparator x Output Enable bit 1 = Comparator output is present on the CxOUT pin 0 = Comparator output is internal only bit 13 **CPOL:** Comparator x Output Polarity Select bit 1 = Comparator output is inverted 0 = Comparator output is not inverted bit 12 **CLPWR:** Comparator x Low-Power Mode Select bit 1 = Comparator operates in Low-Power mode 0 = Comparator does not operate in Low-Power mode bit 11-10 Unimplemented: Read as '0' bit 9 **CEVT:** Comparator x Event bit 1 = Comparator event, defined by EVPOL[1:0], has occurred; subsequent Triggers and interrupts are disabled until the bit is cleared 0 = Comparator event has not occurred bit 8 **COUT:** Comparator x Output bit When CPOL = 0: 1 = VIN+ > VIN- 0 = VIN+ < VIN- When CPOL = 1: 1 = Vin+ < Vin- 0 = VIN+ > VIN- bit 7-6 **EVPOL[1:0]:** Trigger/Event/Interrupt Polarity Select bits<sup>(2)</sup> 11 = Trigger/event/interrupt is generated on any change of the comparator output (while CEVT = 0) 10 = Trigger/event/interrupt is generated on the high-to-low transition of the comparator output 01 = Trigger/event/interrupt is generated on the low-to-high transition of the comparator output 00 = Trigger/event/interrupt generation is disabled bit 5-4 **CREF[1:0]:** Comparator x Reference Select bits (noninverting input) 11 = Noninverting input connects to the DAC2 output 10 = Noninverting input connects to the DAC1 output 01 = Noninverting input connects to the internal CVREF voltage 00 = Noninverting input connects to the CxINA pin bit 3-2 **Unimplemented:** Read as '0' **Note 1:** BGBUF1 voltage is configured by BUFREF1[1:0] (BUFCON0[1:0]). 2: If the EVPOL[1:0] bits are set to a value other than '00', the first interrupt generated will occur on any transition of COUT. Subsequent interrupts will occur based on the EVPOLx bits setting. #### REGISTER 22-1: CMxCON: COMPARATOR x CONTROL REGISTERS (CONTINUED) bit 1-0 **CCH[1:0]:** Comparator x Channel Select bits 11 = Inverting input of the comparator connects to BGBUF1<sup>(1)</sup> 10 = Inverting input of the comparator connects to the CxIND pin 01 = Inverting input of the comparator connects to the CxINC pin 00 = Inverting input of the comparator connects to the CxINB pin Note 1: BGBUF1 voltage is configured by BUFREF1[1:0] (BUFCON0[1:0]). 2: If the EVPOL[1:0] bits are set to a value other than '00', the first interrupt generated will occur on any transition of COUT. Subsequent interrupts will occur based on the EVPOLx bits setting. #### REGISTER 22-2: CMSTAT: COMPARATOR MODULE STATUS REGISTER | R/W-0 | U-0 | U-0 | U-0 | U-0 | R-0, HSC | R-0, HSC | R-0, HSC | |--------|-----|-----|-----|-----|----------------------|----------------------|----------| | CMIDL | _ | _ | _ | _ | C3EVT <sup>(1)</sup> | C2EVT <sup>(1)</sup> | C1EVT | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | U-0 | R-0, HSC | R-0, HSC | R-0, HSC | |-------|-----|-----|-----|-----|----------------------|----------------------|----------| | _ | _ | _ | _ | _ | C3OUT <sup>(1)</sup> | C2OUT <sup>(1)</sup> | C1OUT | | bit 7 | | | | | | | bit 0 | | Legend: | HSC = Hardware Settable/C | HSC = Hardware Settable/Clearable bit | | | | | | |-------------------|---------------------------|---------------------------------------|--------------------|--|--|--|--| | R = Readable bit | W = Writable bit | U = Unimplemented bit, read as '0' | | | | | | | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | | | | bit 15 **CMIDL:** Comparator x Stop in Idle Mode bit 1 = Comparator interrupts are disabled in Idle mode; enabled comparators remain operational 0 = Continues operation of all enabled comparators in Idle mode bit 14-11 **Unimplemented:** Read as '0' bit 10 **C3EVT:** Comparator 3 Event Status bit (read-only)<sup>(1)</sup> Shows the current event status of Comparator 3 (CM3CON[9]). bit 9 **C2EVT:** Comparator 2 Event Status bit (read-only)<sup>(1)</sup> Shows the current event status of Comparator 2 (CM2CON[9]). bit 8 **C1EVT:** Comparator 1 Event Status bit (read-only) Shows the current event status of Comparator 1 (CM1CON[9]). bit 7-3 **Unimplemented:** Read as '0' bit 2 C3OUT: Comparator 3 Output Status bit (read-only)<sup>(1)</sup> Shows the current output of Comparator 3 (CM3CON[8]). bit 1 C2OUT: Comparator 2 Output Status bit (read-only)(1) Shows the current output of Comparator 2 (CM2CON[8]). bit 0 C10UT: Comparator 1 Output Status bit (read-only) Shows the current output of Comparator 1 (CM1CON[8]). Note 1: Comparator 2 and Comparator 3 are only available on PIC24F(V)16KM2XX devices. # 23.0 COMPARATOR VOLTAGE REFERENCE Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Comparator Voltage Reference, refer to "Comparator Voltage Reference Module" (www.microchip.com/DS39709) in the "dsPIC33/PIC24F Family Reference Manual". ## 23.1 Configuring the Comparator Voltage Reference The comparator voltage reference module is controlled through the CVRCON register (Register 23-1). The comparator voltage reference provides a range of output voltages with 32 distinct levels. The comparator voltage reference supply voltage can come from either VDD and VSS, or the external VREF+ and VREF-. The voltage source is selected by the CVRSS bit (CVRCON[5]). The settling time of the comparator voltage reference must be considered when changing the CVREF output. FIGURE 23-1: COMPARATOR VOLTAGE REFERENCE BLOCK DIAGRAM #### REGISTER 23-1: CVRCON: COMPARATOR VOLTAGE REFERENCE CONTROL REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | CVREN | CVROE | CVRSS | CVR4 | CVR3 | CVR2 | CVR1 | CVR0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-8 **Unimplemented:** Read as '0' bit 7 CVREN: Comparator Voltage Reference Enable bit 1 = CVREF circuit is powered on0 = CVREF circuit is powered down bit 6 **CVROE:** Comparator VREF Output Enable bit 1 = CVREF voltage level is output on the CVREF pin 0 = CVREF voltage level is disconnected from the CVREF pin bit 5 CVRSS: Comparator VREF Source Selection bit 1 = Comparator reference source, CVRSRC = VREF+ - VREF-0 = Comparator reference source, CVRSRC = AVDD - AVSS bit 4-0 **CVR[4:0]:** Comparator VREF Value Selection $0 \le CVR[4:0] \le 31$ bits When CVRSS = 1: CVREF = (VREF-) + (CVR[4:0]/32) • (VREF+ - VREF-) When CVRSS = 0: $\overline{\text{CVREF}} = (\text{AVSS}) + (\text{CVR}[4:0]/32) \cdot (\text{AVDD} - \text{AVSS})$ # 24.0 CHARGE TIME MEASUREMENT UNIT (CTMU) Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Charge Time Measurement Unit, refer to "Charge Time Measurement Unit (CTMU) and CTMU Operation with Threshold Detect" (www.microchip.com/DS30009743) in the "dsPIC33/PIC24F Family Reference Manual". The Charge Time Measurement Unit (CTMU) is a flexible analog module that provides charge measurement, accurate differential time measurement between pulse sources and asynchronous pulse generation. Its key features include: - Thirteen External Edge Input Trigger Sources - Polarity Control for Each Edge Source - · Control of Edge Sequence - Control of Response to Edge Levels or Edge Transitions - · Time Measurement Resolution of One Nanosecond - Accurate Current Source Suitable for Capacitive Measurement Together with other on-chip analog modules, the CTMU can be used to precisely measure time, measure capacitance, measure relative changes in capacitance or generate output pulses that are independent of the system clock. The CTMU module is ideal for interfacing with capacitive-based touch sensors. The CTMU is controlled through three registers: CTMUCON1, CTMUCON2 and CTMUICON. CTMUCON1 enables the module and controls the mode of operation of the CTMU, as well as controlling edge sequencing. CTMUCON2 controls edge source selection and edge source polarity selection. The CTMUICON register selects the current range of current source and trims the current. #### 24.1 Measuring Capacitance The CTMU module measures capacitance by generating an output pulse, with a width equal to the time between edge events, on two separate input channels. The pulse edge events to both input channels can be selected from several internal peripheral modules (OC1, Timer1, any input capture or comparator module) and up to 13 external pins (CTED1 through CTED13). This pulse is used with the module's precision current source to calculate capacitance according to the relationship: #### **EQUATION 24-1:** $$I = C \cdot \frac{dV}{dT}$$ For capacitance measurements, the A/D Converter samples an External Capacitor (CAPP) on one of its input channels after the CTMU output's pulse. A Precision Resistor (RPR) provides current source calibration on a second A/D channel. After the pulse ends, the converter determines the voltage on the capacitor. The actual calculation of capacitance is performed in software by the application. Figure 24-1 illustrates the external connections used for capacitance measurements, and how the CTMU and A/D modules are related in this application. This example also shows the edge events coming from Timer1, but other configurations using external edge sources are possible. A detailed discussion on measuring capacitance and time with the CTMU module is provided in the "dsPIC33/PIC24F Family Reference Manual". FIGURE 24-1: TYPICAL CONNECTIONS AND INTERNAL CONFIGURATION FOR CAPACITANCE MEASUREMENT ### 24.2 Measuring Time Time measurements on the pulse width can be similarly performed using the A/D module's Internal Capacitor (CAD) and a precision resistor for current calibration. Figure 24-2 displays the external connections used for time measurements, and how the CTMU and A/D modules are related in this application. This example also shows both edge events coming from the external CTEDx pins, but other configurations using internal edge sources are possible. FIGURE 24-2: TYPICAL CONNECTIONS AND INTERNAL CONFIGURATION FOR TIME MEASUREMENT #### 24.3 Pulse Generation and Delay The CTMU module can also generate an output pulse with edges that are not synchronous with the device's system clock. More specifically, it can generate a pulse with a programmable delay from an edge event input to the module. When the module is configured for pulse generation delay by setting the TGEN bit (CTMUCON1L[12]), the internal current source is connected to the B input of Comparator 2. A capacitor (CDELAY) is connected to the Comparator 2 pin, C2INB, and the Comparator Voltage Reference, CVREF, is connected to C2INA. CVREF is then configured for a specific trip point. The module begins to charge CDELAY when an edge event is detected. While CVREF is greater than the voltage on CDELAY, the CTPLS pin is high. When the voltage on CDELAY equals CVREF, CTPLS goes low. With Comparator 2 configured as the second edge, this stops the CTMU from charging. In this state event, the CTMU automatically connects to ground. The IDISSEN bit doesn't need to be set and cleared before the next CTPLS cycle. Figure 24-3 illustrates the external connections for pulse generation, as well as the relationship of the different analog modules required. While CTED1 is shown as the input pulse source, other options are available. A detailed discussion on pulse generation with the CTMU module is provided in the "dsPIC33/PIC24F Family Reference Manual". FIGURE 24-3: TYPICAL CONNECTIONS AND INTERNAL CONFIGURATION FOR PULSE DELAY GENERATION #### REGISTER 24-1: CTMUCON1L: CTMU CONTROL 1 LOW REGISTER | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|----------|-------|-------|----------|---------|--------| | CTMUEN | _ | CTMUSIDL | TGEN | EDGEN | EDGSEQEN | IDISSEN | CTTRIG | | bit 15 | | | | | | | bit 8 | | R/W-0 |--------|--------|--------|--------|--------|--------|-------|-------| | ITRIM5 | ITRIM4 | ITRIM3 | ITRIM2 | ITRIM1 | ITRIM0 | IRNG1 | IRNG0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15 **CTMUEN:** CTMU Enable bit 1 = Module is enabled 0 = Module is disabled bit 14 **Unimplemented:** Read as '0' bit 13 CTMUSIDL: CTMU Stop in Idle Mode bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode bit 12 TGEN: Time Generation Enable bit 1 = Enables edge delay generation 0 = Disables edge delay generation bit 11 EDGEN: Edge Enable bit 1 = Edges are not blocked 0 = Edges are blocked bit 10 **EDGSEQEN:** Edge Sequence Enable bit 1 = Edge 1 event must occur before Edge 2 event can occur 0 = No edge sequence is needed bit 9 IDISSEN: Analog Current Source Control bit 1 = Analog current source output is grounded 0 = Analog current source output is not grounded bit 8 CTTRIG: CTMU Trigger Control bit 1 = Trigger output is enabled 0 = Trigger output is disabled bit 7-2 ITRIM[5:0]: Current Source Trim bits 011111 = Maximum positive change from nominal current 011110 . 000001 = Minimum positive change from nominal current 000000 = Nominal current output specified by IRNG[1:0] 111111 = Minimum negative change from nominal current \_ • 100010 100001 = Maximum negative change from nominal current bit 1-0 IRNG[1:0]: Current Source Range Select bits 11 = 100 × Base Current 10 = 10 × Base Current 01 = Base Current Level (0.55 μA nominal) 00 = 1000 × Base Current #### REGISTER 24-2: CTMUCON1H: CTMU CONTROL 1 HIGH REGISTER | R/W-0 |---------|---------|----------|----------|----------|----------|----------|----------| | EDG1MOD | EDG1POL | EDG1SEL3 | EDG1SEL2 | EDG1SEL1 | EDG1SEL0 | EDG2STAT | EDG1STAT | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | |---------|---------|----------|----------|----------|----------|-----|-------| | EDG2MOD | EDG2POL | EDG2SEL3 | EDG2SEL2 | EDG2SEL1 | EDG2SEL0 | _ | _ | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 15 EDG1MOD: Edge 1 Edge-Sensitive Select bit 1 = Input is edge-sensitive 0 = Input is level-sensitive bit 14 **EDG1POL:** Edge 1 Polarity Select bit 1 = Edge 1 is programmed for a positive edge response 0 = Edge 1 is programmed for a negative edge response bit 13-10 EDG1SEL[3:0]: Edge 1 Source Select bits 1111 = Edge 1 source is the Comparator 3 output 1110 = Edge 1 source is the Comparator 2 output 1101 = Edge 1 source is the Comparator 1 output 1100 = Edge 1 source is CLC2 1011 = Edge 1 source is CLC1 1010 = Edge 1 source is the MCCP2 Compare Event Flag (CCP2IF) 1001 = Edge 1 source is CTED8<sup>(1)</sup> 1000 = Edge 1 source is CTED7<sup>(1)</sup> 0111 = Edge 1 source is CTED6 0110 = Edge 1 source is CTED5 0101 = Edge 1 source is CTED4 0100 = Edge 1 source is CTED3<sup>(2)</sup> 0011 = Edge 1 source is CTED1 0010 = Edge 1 source is CTED2 0001 = Edge 1 source is the MCCP1 Compare Event Flag (CCP1IF) 0000 = Edge 1 source is Timer1 bit 9 EDG2STAT: Edge 2 Status bit Indicates the status of Edge 2 and can be written to control the current source. 1 = Edge 2 has occurred 0 = Edge 2 has not occurred bit 8 EDG1STAT: Edge 1 Status bit Indicates the status of Edge 1 and can be written to control the current source. 1 = Edge 1 has occurred 0 = Edge 1 has not occurred bit 7 EDG2MOD: Edge 2 Edge-Sensitive Select bit 1 = Input is edge-sensitive 0 = Input is level-sensitive bit 6 EDG2POL: Edge 2 Polarity Select bit 1 = Edge 2 is programmed for a positive edge 0 = Edge 2 is programmed for a negative edge Note 1: Edge sources, CTED7 and CTED8, are not available on 28-pin and 20-pin devices. 2: Edge sources, CTED3, CTED9 and CTED11, are not available on 20-pin devices. #### REGISTER 24-2: CTMUCON1H: CTMU CONTROL 1 HIGH REGISTER (CONTINUED) ``` bit 5-2 EDG2SEL[3:0]: Edge 2 Source Select bits 1111 = Edge 2 source is the Comparator 3 output 1110 = Edge 2 source is the Comparator 2 output 1101 = Edge 2 source is the Comparator 1 output 1100 = Unimplemented; do not use 1011 = Edge 2 source is CLC1 1010 = Edge 2 source is the MCCP2 Compare Event Flag (CCP2IF) 1001 = Unimplemented; do not use 1000 = Edge 2 source is CTED13 0111 = Edge 2 source is CTED12 0110 = Edge 2 source is CTED11(2) 0101 = Edge 2 source is CTED10 0100 = Edge 2 source is CTED9<sup>(2)</sup> 0011 = Edge 2 source is CTED1 0010 = Edge 2 source is CTED2 0001 = Edge 2 source is the MCCP1 Compare Event Flag (CCP1IF) 0000 = Edge 2 source is Timer1 bit 1-0 Unimplemented: Read as '0' ``` - Note 1: Edge sources, CTED7 and CTED8, are not available on 28-pin and 20-pin devices. - 2: Edge sources, CTED3, CTED9 and CTED11, are not available on 20-pin devices. #### REGISTER 24-3: CTMUCON2L: CTMU CONTROL 2 LOW REGISTER | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|--------|-----|---------|---------|---------| | _ | _ | _ | IRSTEN | _ | DISCHS2 | DISCHS1 | DISCHS0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-5 Unimplemented: Read as '0' bit 4 IRSTEN: CTMU Current Source Reset Enable bit 1 = Signal selected by the DISCHS[2:0] bits or the IDISSEN control bit will reset the CTMU edge detect logic 0 = CTMU edge detect logic will not occur bit 3 **Unimplemented:** Read as '0' bit 2-0 DISCHS[2:0]: Discharge Source Select bits 111 = CLC2 output 110 = CLC1 output 110 - CLC i output 101 = Reserved; do not use. 100 = A/D end of conversion signal 011 = SCCP5 auxiliary output 110 = MCCP2 auxiliary output 001 = MCCP1 auxiliary output 000 = No discharge source selected, use the IDISSEN bit | NOTES: | | | | |--------|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 25.0 SPECIAL FEATURES #### Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information on the Watchdog Timer, High-Level Device Integration and Programming Diagnostics, refer to the individual sections of the "dsPIC33/PIC24F Family Reference Manual" provided below: - "Watchdog Timer (WDT)" (www.microchip.com/DS39697) - "Programming and Diagnostics" (www.microchip.com/DS39716) PIC24FXXXXX 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 - In-Circuit Serial Programming™ (ICSP™) - · In-Circuit Emulation #### 25.1 Configuration Bits The Configuration bits can be programmed (read as '0') or left unprogrammed (read as '1') to select various device configurations. These bits are mapped, starting at program memory location, F80000h. A complete list of Configuration register locations is provided in Table 25-1. A detailed explanation of the various bit functions is provided in Register 25-1 through Register 25-9. The address, F80000h, is beyond the user program memory space. In fact, it belongs to the configuration memory space (800000h-FFFFFFh), which can only be accessed using Table Reads and Table Writes. TABLE 25-1: CONFIGURATION REGISTERS LOCATIONS | Configuration<br>Register | Address | |---------------------------|---------| | FBS | F80000 | | FGS | F80004 | | FOSCSEL | F80006 | | FOSC | F80008 | | FWDT | F8000A | | FPOR | F8000C | | FICD | F8000E | #### REGISTER 25-1: FBS: BOOT SEGMENT CONFIGURATION REGISTER | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | |-------|-----|-----|-----|-------|-------|-------|-------| | _ | _ | _ | _ | BSS2 | BSS1 | BSS0 | BWRP | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 7-4 Unimplemented: Read as '0' bit 3-1 BSS[2:0]: Boot Segment Program Flash Code Protection bits 111 = No boot program Flash segment 011 = Reserved 110 = Standard security, boot program Flash segment starts at 200h, ends at 000AFEh 010 = High-security, boot program Flash segment starts at 200h, ends at 000AFEh 101 = Standard security, boot program Flash segment starts at 200h, ends at 0015FEh<sup>(1)</sup> 001 = High-security, boot program Flash segment starts at 200h, ends at 0015FEh<sup>(1)</sup> 100 = Reserved 000 = Reserved bit 0 BWRP: Boot Segment Program Flash Write Protection bit 1 = Boot Segment may be written 0 = Boot Segment is write-protected Note 1: This selection should not be used in PIC24FV08KMXXX devices. #### REGISTER 25-2: FGS: GENERAL SEGMENT CONFIGURATION REGISTER | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/C-1 | R/C-1 | |-------|-----|-----|-----|-----|-----|-------|-------| | _ | _ | _ | _ | _ | _ | GCP | GWRP | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit C = Clearable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7-2 **Unimplemented:** Read as '0' bit 1 GCP: General Segment Code Flash Code Protection bit 1 = No protection 0 = Standard security is enabled bit 0 GWRP: General Segment Code Flash Write Protection bit 1 = General Segment may be written0 = General Segment is write-protected #### REGISTER 25-3: FOSCSEL: OSCILLATOR SELECTION CONFIGURATION REGISTER | R/P-1 | R/P-1 | R/P-1 | U-0 | U-0 | R/P-1 | R/P-1 | R/P-1 | |-------|---------|---------|-----|-----|--------|--------|--------| | IESO | LPRCSEL | SOSCSRC | _ | _ | FNOSC2 | FNOSC1 | FNOSC0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7 IESO: Internal External Switchover bit 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) bit 6 LPRCSEL: Internal LPRC Oscillator Power Select bit 1 = High-Power/High-Accuracy mode0 = Low-Power/Low-Accuracy mode bit 5 SOSCSRC: Secondary Oscillator Clock Source Configuration bit 1 = SOSC analog crystal function is available on the SOSCI/SOSCO pins 0 = SOSC crystal is disabled; digital SCLKI function is selected on the SOSCO pin bit 4-3 **Unimplemented:** Read as '0' bit 2-0 **FNOSC[2:0]:** Oscillator Selection bits 000 = Fast RC Oscillator (FRC) 001 = Fast RC Oscillator with Divide-by-N with PLL module (FRCDIV+PLL) 010 = Primary Oscillator (XT, HS, EC) 011 = Primary Oscillator with PLL module (HS+PLL, EC+PLL) 100 = Secondary Oscillator (SOSC) 101 = Low-Power RC Oscillator (LPRC) 110 = 500 kHz Low-Power FRC Oscillator with Divide-by-N (LPFRCDIV) 111 = 8 MHz FRC Oscillator with Divide-by-N (FRCDIV) #### REGISTER 25-4: FOSC: OSCILLATOR CONFIGURATION REGISTER | R/P-1 |--------|--------|---------|-----------|-----------|----------|----------|----------| | FCKSM1 | FCKSM0 | SOSCSEL | POSCFREQ1 | POSCFREQ0 | OSCIOFNC | POSCMOD1 | POSCMOD0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7-6 FCKSM[1:0]: Clock Switching and Fail-Safe Clock Monitor Selection Configuration bits 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 5 SOSCSEL: Secondary Oscillator Power Selection Configuration bit 1 = Secondary Oscillator is configured for high-power operation0 = Secondary Oscillator is configured for low-power operation bit 4-3 **POSCFREQ[1:0]:** Primary Oscillator Frequency Range Configuration bits 11 = Primary Oscillator/External Clock input frequency is greater than 8 MHz 10 = Primary Oscillator/External Clock input frequency is between 100 kHz and 8 MHz 01 = Primary Oscillator/External Clock input frequency is less than 100 kHz 00 = Reserved; do not use bit 2 OSCIOFNC: CLKO Enable Configuration bit 1 = CLKO output signal is active on the OSCO pin; Primary Oscillator must be disabled or configured for the External Clock (EC) mode for the CLKO to be active (POSCMOD[1:0] = 11 or 00) 0 = CLKO output is disabled bit 1-0 **POSCMOD[1:0]:** Primary Oscillator Configuration bits 11 = Primary Oscillator mode is disabled 10 = HS Oscillator mode is selected 01 = XT Oscillator mode is selected 00 = External Clock mode is selected #### REGISTER 25-5: FWDT: WATCHDOG TIMER CONFIGURATION REGISTER | R/P-1 |-------------|--------|---------|-------|--------|--------|--------|--------| | FWDTEN1 | WINDIS | FWDTEN0 | FWPSA | WDTPS3 | WDTPS2 | WDTPS1 | WDTPS0 | | bit 7 bit 0 | | | | | | | | Legend: R = Readable bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7,5 **FWDTEN[1:0]:** Watchdog Timer Enable bits 11 = WDT is enabled in hardware 10 = WDT is controlled with the SWDTEN bit setting 01 = WDT is enabled only while the device is active, WDT is disabled in Sleep; SWDTEN bit is disabled 00 = WDT is disabled in hardware; SWDTEN bit is disabled bit 6 WINDIS: Windowed Watchdog Timer Disable bit 1 = Standard WDT is selected; windowed WDT is disabled 0 = Windowed WDT is enabled; note that executing a CLRWDT instruction while the WDT is disabled in hardware and software (FWDTEN[1:0] = 00 and SWDTEN (RCON[5]) = 0) will not cause a device Reset bit 4 **FWPSA:** WDT Prescaler bit 1 = WDT prescaler ratio of 1:128 0 = WDT prescaler ratio of 1:32 bit 3-0 WDTPS[3:0]: Watchdog Timer Postscale Select bits 1111 = 1:32,768 1110 = 1:16,384 1101 = 1:8,192 1100 = 1:4,096 1011 = 1:2,048 1010 = 1:1,024 1001 = 1:512 1000 = 1:256 0111 = 1:128 0110 = 1:64 0101 = 1:32 0100 = 1:16 0011 = 1:8 0010 = 1:4 0001 = 1:20000 = 1:1 #### REGISTER 25-6: FPOR: RESET CONFIGURATION REGISTER | R/P-1 |----------------------|----------------------|----------------------|------------------------|--------|-----------------------|--------|--------| | MCLRE <sup>(2)</sup> | BORV1 <sup>(3)</sup> | BORV0 <sup>(3)</sup> | I2C1SEL <sup>(1)</sup> | PWRTEN | RETCFG <sup>(1)</sup> | BOREN1 | BOREN0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7 MCLRE: MCLR Pin Enable bit<sup>(2)</sup> 1 = $\overline{\text{MCLR}}$ pin is enabled; RA5 input pin is disabled 0 = RA5 input pin is enabled; MCLR is disabled bit 6-5 BORV[1:0]: Brown-out Reset Voltage Level bits<sup>(3)</sup> 11 = Brown-out Reset is set to the lowest voltage 10 = Brown-out Reset is set to the middle voltage 01 = Brown-out Reset is set to the highest voltage 00 = Downside protection on POR is enabled - Low-Power BOR (LPBOR) is selected bit 4 I2C1SEL: Alternate I2C1 Pin Mapping bit (1) 1 = Default location for SCL1/SDA1 pins 0 = Alternate location for SCL1/SDA1 pins bit 3 **PWRTEN:** Power-up Timer Enable bit 1 = PWRT is enabled 0 = PWRT is disabled bit 2 **RETCFG:** Retention Regulator Configuration bit<sup>(1)</sup> 1 = Low-voltage regulator is not available 0 = Low-voltage regulator is available and controlled by the RETEN bit (RCON[12]) during Sleep bit 1-0 BOREN[1:0]: Brown-out Reset Enable bits 11 = Brown-out Reset is enabled in hardware; SBOREN bit is disabled 10 = Brown-out Reset is enabled only while device is active and disabled in Sleep; SBOREN bit is disabled 01 = Brown-out Reset is controlled with the SBOREN bit setting 00 = Brown-out Reset is disabled in hardware; SBOREN bit is disabled Note 1: This setting only applies to the "FV" devices. This bit is reserved and should be maintained as '1' on "F" devices - 2: The MCLRE fuse can only be changed when using the VPP-based ICSP™ mode entry. This prevents a user from accidentally locking out the device from the low-voltage test entry. - 3: Refer to Section 27.0 "Electrical Characteristics" for BOR voltages. #### REGISTER 25-7: FICD: IN-CIRCUIT DEBUGGER CONFIGURATION REGISTER | R/P-1 | U-0 | U-0 | U-0 | U-0 | U-0 | R/P-1 | R/P-1 | |-------|-----|-----|-----|-----|-----|-------|-------| | DEBUG | _ | _ | _ | _ | | FICD1 | FICD0 | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7 **DEBUG:** Background Debugger Enable bit 1 = Background debugger is disabled 0 = Background debugger functions are enabled bit 6-2 **Unimplemented:** Read as '0' bit 1-0 FICD[1:0:]: ICD Pin Select bits 11 = PGEC1/PGED1 are used for programming and debugging the device 10 = PGEC2/PGED2 are used for programming and debugging the device 01 = PGEC3/PGED3 are used for programming and debugging the device 00 = Reserved; do not use ### **REGISTER 25-8: DEVID: DEVICE ID REGISTER** | U-0 | | |---------------|-----|-----|-----|-----|-----|-----|-----|--|--| | _ | _ | _ | _ | _ | _ | _ | _ | | | | bit 23 bit 16 | | | | | | | | | | | R | R | R | R | R | R | R | R | | | |------------|---|---|---|---|---|---|-------|--|--| | FAMID[7:0] | | | | | | | | | | | bit 15 | | | | | | | bit 8 | | | | R | R | R | R | R | R | R | R | | | |----------|---|---|---|---|---|---|-------|--|--| | DEV[7:0] | | | | | | | | | | | bit 7 | | | | | | | bit 0 | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' bit 23-16 Unimplemented: Read as '0' bit 15-8 **FAMID[7:0]:** Device Family Identifier bits 01000101 = PIC24FV16KM204 family bit 7-0 **DEV[7:0]:** Individual Device Identifier bits 00011111 = PIC24FV16KM204 00011011 = PIC24FV16KM202 00010111 = PIC24FV08KM204 00010011 = PIC24FV08KM202 00001111 **= PIC24FV16KM104** 00001111 = PIC24FV16KM102 00000011 = PIC24FV08KM102 00000001 = PIC24FV08KM101 00011110 = PIC24F16KM204 00011010 = PIC24F16KM202 00010110 = PIC24F08KM204 00010010 = PIC24F08KM202 00001110 = PIC24F16KM104 00001010 = PIC24F16KM102 00000010 = PIC24F08KM102 00000000 = PIC24F08KM101 ### **REGISTER 25-9: DEVREV: DEVICE REVISION REGISTER** | U-0 | | |---------------|-----|-----|-----|-----|-----|-----|-----|--|--| | _ | _ | _ | _ | _ | _ | _ | _ | | | | bit 23 bit 16 | | | | | | | | | | | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | U-0 | R | R | R | R | | | |-------|-----|-----|-----|----------|---|---|-------|--|--| | _ | _ | _ | _ | REV[3:0] | | | | | | | bit 7 | | | | | | | bit 0 | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 23-4 Unimplemented: Read as '0' bit 3-0 **REV[3:0]:** Minor Revision Identifier bits #### 25.2 **On-Chip Voltage Regulator** All of the PIC24FXXXXX family devices power their core digital logic at a nominal 3.0V. This may create an issue for designs that are required to operate at a higher typical voltage, as high as 5.0V. To simplify system design, all devices in the "FV" family incorporate an on-chip regulator that allows the device core to run at 3.0V, while the I/O is powered by VDD at a higher voltage. The regulator is always enabled and provides power to the core from the other VDD pins. A low-ESR capacitor (such as ceramic) must be connected to the VCAP pin (Figure 25-1). This helps to maintain the stability of the regulator. The recommended value for the filter capacitor is provided in Section 27.1 "DC Characteristics" and discussed in detail in Section 2.0 "Guidelines for Getting Started with 16-Bit Microcontrollers". In all of the "F" family of devices, the regulator is disabled. Instead, the core logic is directly powered from VDD. "F" devices operate at a lower range of VDD voltage, from 1.8V-3.6V. #### 25.2.1 **VOLTAGE REGULATOR TRACKING** MODE AND LOW-VOLTAGE DETECTION For all PIC24FXXXXX devices, the on-chip regulator provides a constant voltage of 3.0V nominal to the digital core logic. The regulator can provide this level from a VDD of about 3.2V, all the way up to the device's VDDMAX. It does not have the capability to boost VDD levels below 3.2V. In order to prevent "brown out" conditions when the voltage drops too low for the regulator, the regulator enters Tracking mode. In Tracking mode, the regulator output follows VDD with a typical voltage drop of 150 mV. When the device enters Tracking mode, it is no longer possible to operate at full speed. To provide information about when the device enters Tracking mode, the on-chip High/Low-Voltage Detect (HLVD) module can be used. The HLVD trip point should be configured so that if VDD drops close to the minimum voltage for the operating frequency of the device, the HLVD Interrupt Flag, HLVDIF (IFS4[8]), will occur. This can be used to generate an interrupt and put the application into a low-power operational mode or trigger an orderly shutdown. Refer to Section 27.1 "DC Characteristics" for the specifications detailing the maximum operating speed based on the applied VDD voltage. #### **CONNECTIONS FOR THE FIGURE 25-1: ON-CHIP VOLTAGE REGULATOR** Section 27.0 "Electrical Characteristics" for the full operating ranges of VDD and VDDCORE. #### 25.2.2 **VOLTAGE REGULATOR START-UP** TIME For PIC24FXXXXX family devices, it takes a short time, designated as TPM, for the regulator to generate a stable output. During this time, code execution is disabled. TPM is applied every time the device resumes operation after any power-down, including Sleep mode. TPM is specified in Section 27.2 "AC Characteristics and Timing Parameters". #### Watchdog Timer (WDT) 25.3 For the PIC24FXXXXX family of devices, the WDT is driven by the LPRC Oscillator. When the WDT is enabled, the clock source is also enabled. The nominal WDT clock source from LPRC is 31 kHz. This feeds a prescaler that can be configured for either 5-bit (divide-by-32) or 7-bit (divide-by-128) operation. The prescaler is set by the FWPSA Configuration bit. With a 31 kHz input, the prescaler yields a nominal WDT Time-out period (TWDT) of 1 ms in 5-bit mode or 4 ms in 7-bit mode. A variable postscaler divides down the WDT prescaler output and allows for a wide range of time-out periods. The postscaler is controlled by the Configuration bits, WDTPS[3:0] (FWDT[3:0]), which allow the selection of a total of 16 settings, from 1:1 to 1:32,768. Using the prescaler and postscaler time-out periods, ranges from 1 ms to 131 seconds can be achieved. The WDT, prescaler and postscaler are reset: - · On any device Reset - On the completion of a clock switch, whether invoked by software (i.e., setting the OSWEN bit after changing the NOSCx bits) or by hardware (i.e., Fail-Safe Clock Monitor) - When a PWRSAV instruction is executed (i.e., Sleep or Idle mode is entered) - When the device exits Sleep or Idle mode to resume normal operation - By a CLRWDT instruction during normal execution If the WDT is enabled in hardware (FWDTEN[1:0] = 11), it will continue to run during Sleep or Idle modes. When the WDT time-out occurs, the device will wake and code execution will continue from where the PWRSAV instruction was executed. The corresponding SLEEP or IDLE bit (RCON[3:2]) will need to be cleared in software after the device wakes up. The WDT Flag bit, WDTO (RCON[4]), is not automatically cleared following a WDT time-out. To detect subsequent WDT events, the flag must be cleared in software. Note: The CLRWDT and PWRSAV instructions clear the prescaler and postscaler counts when executed. #### 25.3.1 WINDOWED OPERATION The Watchdog Timer has an optional Fixed Window mode of operation. In this Windowed mode, CLRWDT instructions can only reset the WDT during the last 1/4 of the programmed WDT period. A CLRWDT instruction executed before that window causes a WDT Reset, similar to a WDT time-out. Windowed WDT mode is enabled by programming the Configuration bit, WINDIS (FWDT[6]), to '0'. #### 25.3.2 CONTROL REGISTER The WDT is enabled or disabled by the FWDTEN[1:0] Configuration bits. When both of the FWDTEN[1:0] Configuration bits are set, the WDT is always enabled. The WDT can be optionally controlled in software when the FWDTEN[1:0] Configuration bits have been programmed to '10'. The WDT is enabled in software by setting the SWDTEN control bit (RCON[5]). The SWDTEN control bit is cleared on any device Reset. The software WDT option allows the user to enable the WDT for critical code segments, and disable the WDT during non-critical segments, for maximum power savings. When the FWDTEN[1:0] bits are set to '01', the WDT is only enabled in Run and Idle modes, and is disabled in Sleep. Software control of the SWDTEN bit (RCON[5]) is disabled with this setting. ### FIGURE 25-2: WDT BLOCK DIAGRAM # 25.4 Program Verification and Code Protection Note: Code-protect bits (BSS, BWRP, GSS, GWRP) are in a group that are subject to write restrictions. If any bit is cleared, the rest cannot be cleared on a subsequent operation. All bits must be cleared using one operation. For all devices in the PIC24FXXXXX family, code protection for the Boot Segment is controlled by the Configuration bit, BSS0, and the General Segment by the Configuration bit, GCP. These bits inhibit external reads and writes to the program memory space This has no direct effect in normal execution mode. Write protection is controlled by bit, BWRP, for the Boot Segment and bit, GWRP, for the General Segment in the Configuration Word. When these bits are programmed to '0', internal write and erase operations to program memory are blocked. ### 25.5 In-Circuit Serial Programming PIC24FXXXXX family microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock (PGECx) and data (PGEDx), and three other lines for power, ground and the programming voltage. This allows customers to manufacture boards with unprogrammed devices and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed. ### 25.6 In-Circuit Debugger When MPLAB® ICD 3, MPLAB REAL ICE™ or PICkit™ 3 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 PGECx and PGEDx pins. To use the in-circuit debugger function of the device, the design must implement ICSP connections to $\overline{\text{MCLR}}$ , VDD, VSS, PGECx, PGEDx and the 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 I/O pins. | PIC24F\ | PIC24FV16KM204 FAMILY | | | | | | | | | |---------|-----------------------|--|--|--|--|--|--|--|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 26.0 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 ds $PIC^{@}$ 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: https://www.microchip.com/development-tools/ | | PIC24FV16KM204 FAMILY | | | | | | | | | |--------|-----------------------|--|--|--|--|--|--|--|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 27.0 ELECTRICAL CHARACTERISTICS This section provides an overview of the PIC24FV16KM204 family electrical characteristics. Additional information will be provided in future revisions of this document as it becomes available. Absolute maximum ratings for the PIC24FV16KM204 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. ### Absolute Maximum Ratings(†) | Ambient temperature under bias | 40°C to +125°C | |--------------------------------------------------------------------|----------------------| | Storage temperature | 65°C to +150°C | | Voltage on VDD with respect to Vss (PIC24FXXKMXXX) | 0.3V to +4.5V | | Voltage on VDD with respect to Vss (PIC24FVXXKMXXX) | -0.3V to +6.5V | | Voltage on any combined analog and digital pin with respect to Vss | 0.3V to (VDD + 0.3V) | | Voltage on any digital only pin with respect to Vss | 0.3V to (VDD + 0.3V) | | Voltage on MCLR/VPP pin with respect to Vss | 0.3V to +9.0V | | Maximum current out of Vss pin | 300 mA | | Maximum current into VDD pin <sup>(1)</sup> | 250 mA | | Maximum output current sunk by any I/O pin | | | Maximum output current sourced by any I/O pin | 25 mA | | Maximum current sunk by all ports | 200 mA | | Maximum current sourced by all ports <sup>(1)</sup> | 200 mA | | | | Note 1: Maximum allowable current is a function of device maximum power dissipation (see Table 27-1). <sup>†</sup> Notice: 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. ### 27.1 DC Characteristics FIGURE 27-1: PIC24FV16KM204 FAMILY VOLTAGE-FREQUENCY GRAPH (INDUSTRIAL) FIGURE 27-2: PIC24F16KM204 FAMILY VOLTAGE-FREQUENCY GRAPH (INDUSTRIAL) **FIGURE 27-3:** PIC24FV16KM204 FAMILY VOLTAGE-FREQUENCY GRAPH (EXTENDED) **TABLE 27-1: THERMAL OPERATING CONDITIONS** | Rating | Symbol | Min | Тур | Max | Unit | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|-------------|------|------| | Operating Junction Temperature Range | TJ | -40 | _ | +140 | °C | | Operating Ambient Temperature Range | TA | -40 | | +125 | °C | | Power Dissipation<br>Internal Chip Power Dissipation: $PINT = VDD \ x \ (IDD - \Sigma \ IOH)$<br>I/O Pin Power Dissipation: $PI/O = \Sigma \ (\{VDD - VOH\} \ x \ IOH) + \Sigma \ (VOL \ x \ IOL)$ | Po | I | PINT + PI/C | ) | W | | Maximum Allowed Power Dissipation PDMAX (TJ – TA)/θJA | | | | Α | W | TABLE 27-2: THERMAL PACKAGING CHARACTERISTICS | Characteristic | Symbol | Тур | Max | Unit | Notes | |------------------------------------------|--------|------|-----|------|-------| | Package Thermal Resistance, 20-Pin PDIP | θЈА | 62.4 | _ | °C/W | 1 | | Package Thermal Resistance, 28-Pin SPDIP | θЈА | 60 | _ | °C/W | 1 | | Package Thermal Resistance, 20-Pin SSOP | θЈА | 108 | _ | °C/W | 1 | | Package Thermal Resistance, 28-Pin SSOP | θЈА | 71 | _ | °C/W | 1 | | Package Thermal Resistance, 20-Pin SOIC | θЈА | 75 | _ | °C/W | 1 | | Package Thermal Resistance, 28-Pin SOIC | θЈА | 80.2 | _ | °C/W | 1 | | Package Thermal Resistance, 28-Pin QFN | θЈА | 32 | _ | °C/W | 1 | | Package Thermal Resistance, 44-Pin QFN | θЈА | 29 | _ | °C/W | 1 | | Package Thermal Resistance, 44-Pin TQFP | θЈА | 40 | _ | °C/W | 1 | | Package Thermal Resistance, 48-Pin UQFN | θЈА | 41 | _ | °C/W | 1 | Note 1: Junction to ambient thermal resistance, Theta-JA (θJA) numbers are achieved by package simulations. TABLE 27-3: DC CHARACTERISTICS: TEMPERATURE AND VOLTAGE SPECIFICATIONS | DC CHARACTERISTICS | | | <b>Standard</b> Operating | - | | ndition | s: 1.8V to 3.6V (PIC24F16KMXXX)<br>2.0V to 5.5V (PIC24FV16KMXXX)<br>-40°C $\leq$ TA $\leq$ +85°C for Industrial<br>-40°C $\leq$ TA $\leq$ +125°C for Extended | |--------------------|--------|------------------------------------------------------------------|---------------------------|--------------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | Param<br>No. | Symbol | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | | DC10 | VDD | Supply Voltage | 1.8 | _ | 3.6 | V | For PIC24F devices | | | | | 2.0 | _ | 5.5 | V | For PIC24FV devices | | DC12 | VDR | RAM Data Retention | 1.6 | _ | _ | V | For PIC24F devices | | | | Voltage <sup>(2)</sup> | 1.8 | _ | _ | V | For PIC24FV devices | | DC16 | VPOR | VDD Start Voltage<br>to Ensure Internal<br>Power-on Reset Signal | Vss | _ | 0.7 | V | | | DC17 | SVDD | VDD Rise Rate<br>to Ensure Internal<br>Power-on Reset Signal | 0.05 | _ | _ | V/ms | 0-3.3V in 0.1s<br>0-2.5V in 60 ms | **Note 1:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. 2: This is the limit to which VDD can be lowered without losing RAM data. ### TABLE 27-4: HIGH/LOW-VOLTAGE DETECT CHARACTERISTICS Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | Param<br>No. | Symbol | Chara | cteristic | Min | Тур | Max | Units | Conditions | |--------------|--------|-----------------|----------------------------------|------|-----|------|-------------|------------| | DC18 | VHLVD | HLVD Voltage on | HLVDL[3:0] = 0000 <sup>(2)</sup> | | _ | 2 | V | | | | | VDD Transition | HLVDL[3:0] = 0001 | 1.84 | _ | 2.23 | ٧ | | | | | | HLVDL[3:0] = 0010 | 2.05 | _ | 2.45 | V | | | | | | HLVDL[3:0] = 0011 | 2.21 | _ | 2.63 | ٧ | | | | | | HLVDL[3:0] = 0100 | 2.31 | | 2.72 | > | | | | | | HLVDL[3:0] = 0101 | 2.51 | | 2.94 | > | | | | | | HLVDL[3:0] = 0110 | 2.76 | _ | 3.2 | ٧ | | | | | | HLVDL[3:0] = 0111 | 2.91 | | 3.35 | > | | | | | | HLVDL[3:0] = 1000 | 3.05 | | 3.51 | > | | | | | | HLVDL[3:0] = 1001 <sup>(1)</sup> | 3.23 | | 3.69 | > | | | | | | HLVDL[3:0] = 1010 <sup>(1)</sup> | 3.42 | | 3.89 | > | | | | | | HLVDL[3:0] = 1011 <sup>(1)</sup> | 3.58 | | 4.11 | > | | | | | | HLVDL[3:0] = 1100 <sup>(1)</sup> | 3.87 | _ | 4.36 | ٧ | | | | | | HLVDL[3:0] = 1101 <sup>(1)</sup> | 4.14 | | 4.65 | <b>&gt;</b> | | | | | | HLVDL[3:0] = 1110 <sup>(1)</sup> | 4.45 | _ | 4.97 | V | | Note 1: These trip points should not be used on PIC24FXXKMXXX devices. 2: This trip point should not be used on PIC24FVXXKMXXX devices. ### **TABLE 27-5: BOR TRIP POINTS** Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial -40°C $\leq$ TA $\leq$ +125°C for Extended | Param<br>No. | Sym | Characteristic | | Min | Тур | Max | Units | Conditions | |--------------|-----|--------------------|----------------|------|------|------|-------|--------------------------| | DC15 | | BOR Hysteresis | | _ | 5 | _ | mV | | | DC19 | | BOR Voltage on VDD | BORV[1:0] = 00 | - | _ | _ | _ | Valid for LPBOR (Note 1) | | | | Transition | BORV[1:0] = 01 | 2.90 | 3 | 3.38 | V | | | | | | BORV[1:0] = 10 | 2.53 | 2.7 | 3.07 | V | | | | | | BORV[1:0] = 11 | 1.75 | 1.85 | 2.05 | ٧ | Note 2 | | | | | BORV[1:0] = 11 | 1.95 | 2.05 | 2.16 | V | Note 3 | Note 1: LPBOR re-arms the POR circuit but does not cause a BOR. 2: This is valid for PIC24F (3.3V) devices. 3: This is valid for PIC24FV (5V) devices. TABLE 27-6: DC CHARACTERISTICS: OPERATING CURRENT (IDD) | DC CHARACTE | DC CHARACTERISTICS | | | <b>Conditions</b><br>re | <b>2.0V to</b><br>-40°C ≤ | : 1.8V to 3.6V (PIC24F16KMXXX)<br>2.0V to 5.5V (PIC24FV16KMXXX)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | |---------------|--------------------|---------|-------|-------------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Parameter No. | Device | Typical | Max | Units | Conditions | | | | | IDD Current | | | | | | | | | | D20 | PIC24FV16KMXXX | 269 | 450 | μΑ | 2.0V | | | | | | | 465 | 830 | μA | 5.0V | 0.5 MIPS, | | | | | PIC24F16KMXXX | 200 | 330 | μA | 1.8V | Fosc = 1 MHz <sup>(1)</sup> | | | | | | 410 | 750 | μΑ | 3.3V | | | | | DC22 | PIC24FV16KMXXX | 490 | | μA | 2.0V | | | | | | | 880 | I | μA | 5.0V | 1 MIPS, | | | | | PIC24F16KMXXX | 407 | _ | μA | 1.8V | Fosc = 2 MHz <sup>(1)</sup> | | | | | | 800 | | μA | 3.3V | | | | | DC24 | PIC24FV16KMXXX | 13.0 | 15.0 | mA | 5.0V | 16 MIPS, | | | | | PIC24F16KMXXX | 12.0 | 13.0 | mA | 3.3V | Fosc = 32 MHz <sup>(1)</sup> | | | | DC26 | PIC24FV16KMXXX | 2.0 | 1 | mA | 2.0V | | | | | | | 3.5 | _ | mA | 5.0V | FRC (4 MIPS), | | | | | PIC24F16KMXXX | 1.80 | | mA | 1.8V | Fosc = 8 MHz | | | | | | 3.40 | | mA | 3.3V | | | | | DC30 | PIC24FV16KMXXX | 48.0 | 250 | μΑ | 2.0V | | | | | | | 75.0 | 275 | μΑ | 5.0V | LPRC (15.5 KIPS), | | | | | PIC24F16KMXXX | 8.1 | 28.0 | μΑ | 1.8V | Fosc = 31 kHz | | | | | | 13.50 | 55.00 | μA | 3.3V | | | | Legend: Unshaded rows represent PIC24F16KMXXX devices and shaded rows represent PIC24FV16KMXXX devices. Note 1: The oscillator is in External Clock mode (FOSCSEL[2:0] = 010, FOSC[1:0] = 00). TABLE 27-7: DC CHARACTERISTICS: IDLE CURRENT (IIDLE) | DC CHARACTERISTICS | | | Operating Cotemperature | | 1.8V to 3.6V (PIC24F16KMXXX)<br>2.0V to 5.5V (PIC24FV16KMXXX)<br>- $40^{\circ}$ C $\leq$ TA $\leq$ +85 $^{\circ}$ C for Industrial<br>- $40^{\circ}$ C $\leq$ TA $\leq$ +125 $^{\circ}$ C for Extended | | | |--------------------|----------------|---------|-------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--| | Parameter No. | Device | Typical | Max | Units | | Conditions | | | Idle Current (III | DLE) | | | | | | | | DC40 | PIC24FV16KMXXX | 120 | 200 | μA | 2.0V | | | | | | 160 | 430 | μA | 5.0V | 0.5 MIPS, | | | | PIC24F16KMXXX | 50 | 100 | μΑ | 1.8V | Fosc = 1 MHz <sup>(1)</sup> | | | | | 90 | 370 | μΑ | 3.3V | | | | DC42 | PIC24FV16KMXXX | 165 | _ | μΑ | 2.0V | | | | | | 260 | _ | μΑ | 5.0V | 1 MIPS, | | | | PIC24F16KMXXX | 95 | 1 | μΑ | 1.8V | Fosc = 2 MHz <sup>(1)</sup> | | | | | 180 | _ | μΑ | 3.3V | | | | DC44 | PIC24FV16KMXXX | 3.1 | 6.5 | mA | 5.0V | 16 MIPS, | | | | PIC24F16KMXXX | 2.9 | 6.0 | mA | 3.3V | Fosc = 32 MHz <sup>(1)</sup> | | | DC46 | PIC24FV16KMXXX | 0.65 | _ | mA | 2.0V | | | | | | 1.0 | _ | mA | 5.0V | FRC (4 MIPS), | | | | PIC24F16KMXXX | 0.55 | _ | mA | 1.8V | Fosc = 8 MHz | | | | | 1.0 | _ | mA | 3.3V | | | | DC50 | PIC24FV16KMXXX | 42 | 200 | μΑ | 2.0V | | | | | PIC24F16KMXXX | 65 | 225 | μΑ | 5.0V | LPRC (15.5 KIPS), | | | | | 2.2 | 18 | μΑ | 1.8V | Fosc = 31 kHz | | | | | 4.0 | 40 | μΑ | 3.3V | | | **Legend:** Unshaded rows represent PIC24F16KMXXX devices and shaded rows represent PIC24FV16KMXXX devices. Note 1: The oscillator is in External Clock mode (FOSCSEL[2:0] = 010, FOSC[1:0] = 00). TABLE 27-8: DC CHARACTERISTICS: POWER-DOWN CURRENT (IPD) | | | Standard C | Operating | Conditions | | | F16KM204)<br>FV16KM204) | | | |---------------|-----------------|------------------------|------------|------------|----------------------------------|-------|---------------------------|--|--| | DC CHARA | CTERISTICS | Operating t | temperatui | re | | | for Industrial | | | | | | | • | | -40°C ≤ Ta ≤ +125°C for Extended | | | | | | Parameter No. | Device | Typical <sup>(1)</sup> | Max | Units | | C | onditions | | | | Power-Dow | n Current (IPD) | | | | | | | | | | DC60 | PIC24FV16KMXXX | | | | -40°C | | | | | | | | | 8.0 | | +25°C | | | | | | | | 6.0 | 8.5 | μA | +60°C | 2.0V | | | | | | | | 9.0 | | +85°C | | | | | | | | | 15.0 | | +125°C | | | | | | | | | 1 | | -40°C | | | | | | | | | 8.0 | | +25°C | | | | | | | | 6.0 | 9.0 | μA | +60°C | 5.0V | | | | | | | | 10.0 | | +85°C | | | | | | | | | 15.0 | | +125°C | | Sleep Mode <sup>(2)</sup> | | | | | PIC24F16KMXXX | | | | -40°C | | Olcep Wode. | | | | | | | 0.80 | | +25°C | | | | | | | | 0.025 | 1.5 | μA | +60°C | 1.8V | | | | | | | | 2.0 | | +85°C | | | | | | | | | 7.5 | | +125°C | | | | | | | | | _ | | -40°C | | | | | | | | | 1.0 | | +25°C | | | | | | | | 0.040 | 2.0 | μΑ | +60°C | 3.3V | | | | | | | | 3.0 | | +85°C | | | | | | | | | 7.5 | | +125°C | | | | | | DC61 | PIC24FV16KMXXX | 0.25 | _ | μA | +85°C | 2.0V | | | | | | | 0.20 | 7.5 | μΑ | +125°C | 2.0 V | Low-Voltage | | | | | | 0.35 | 3.0 | μA | +85°C | 5.0V | Sleep Mode <sup>(2)</sup> | | | | | | 0.55 | 7.5 | μΛ | +125°C | J.0 V | | | | Legend: Unshaded rows represent PIC24F16KMXXX devices and shaded rows represent PIC24FV16KMXXX devices. - **Note 1:** Data in the Typical column are at 3.3V, +25°C (PIC24F16KMXXX) or 5.0V, +25°C (PIC24FV16KMXXX) unless otherwise stated. Parameters are for design guidance only and are not tested. - **2:** Base IPD is measured with all peripherals and clocks shut down. All I/Os are configured as outputs and set low. PMSLP is set to '0' and WDT, etc., are all switched off. - 3: The $\Delta$ current is the additional current consumed when the module is enabled. This current should be added to the base IPD current. TABLE 27-8: DC CHARACTERISTICS: POWER-DOWN CURRENT (IPD) (CONTINUED) | DC CHARA | CTERISTICS | Standard C | | | : 1.8V to 3.6V (PIC24F16KM204)<br>2.0V to 5.5V (PIC24FV16KM204)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | | | | | |---------------------------------------------------|----------------|------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--|--|--|--| | Parameter<br>No. | Device | Typical <sup>(1)</sup> | Max | Units | Conditions | | | | | | | | Module Differential Current (△IPD) <sup>(3)</sup> | | | | | | | | | | | | | DC71 | PIC24FV16KMXXX | 0.50 | _ | μA | 2.0V | | | | | | | | | | 0.70 | 1.5 | μA | 5.0V | Watchdog Timer Current: | | | | | | | | PIC24F16KMXXX | 0.50 | _ | μA | 1.8V | ΔWDT | | | | | | | | | 0.70 | 1.5 | μA | 3.3V | | | | | | | | DC72 | PIC24FV16KMXXX | 0.80 | _ | μA | 2.0V | 32 kHz Crystal with RTCC, | | | | | | | | | 1.50 | 2.0 | μA | 5.0V | DSWDT or Timer1: | | | | | | | | PIC24F16KMXXX | 0.70 | _ | μA | 1.8V | ΔSOSC | | | | | | | | | 1.0 | 1.5 | μA | 3.3V | (SOSCSEL = 0) | | | | | | | DC75 | PIC24FV16KMXXX | 5.4 | _ | μA | 2.0V | | | | | | | | | | 8.1 | 14.0 | μA | 5.0V | ΔHLVD | | | | | | | | PIC24F16KMXXX | 4.9 | _ | μA | 1.8V | ΔΠΕΥΟ | | | | | | | | | 7.5 | 14.0 | μA | 3.3V | | | | | | | | DC76 | PIC24FV16KMXXX | 5.6 | _ | μA | 2.0V | | | | | | | | | | 6.5 | 11.2 | μA | 5.0V | ΔBOR | | | | | | | | PIC24F16KMXXX | 5.6 | _ | μA | 1.8V | ДВОК | | | | | | | | | 6.0 | 11.2 | μA | 3.3V | | | | | | | | DC78 | PIC24FV16KMXXX | 0.03 | _ | μA | 2.0V | | | | | | | | | | 0.05 | 0.3 | μA | 5.0V | Low-Power BOR: | | | | | | | | PIC24F16KMXXX | 0.03 | _ | μA | 1.8V | ΔLPBOR | | | | | | | | | 0.05 | 0.3 | μA | 3.3V | | | | | | | Legend: Unshaded rows represent PIC24F16KMXXX devices and shaded rows represent PIC24FV16KMXXX devices. - **Note 1:** Data in the Typical column are at 3.3V, +25°C (PIC24F16KMXXX) or 5.0V, +25°C (PIC24FV16KMXXX) unless otherwise stated. Parameters are for design guidance only and are not tested. - **2:** Base IPD is measured with all peripherals and clocks shut down. All I/Os are configured as outputs and set low. PMSLP is set to '0' and WDT, etc., are all switched off. - 3: The $\Delta$ current is the additional current consumed when the module is enabled. This current should be added to the base IPD current. TABLE 27-9: DC CHARACTERISTICS: I/O PIN INPUT SPECIFICATIONS | DC CHA | ARACTI | ERISTICS | Standard Operating te | | <b>)</b> | 1.8V to 3.6V (PIC24F16KM204)<br>2.0V to 5.5V (PIC24FV16KM204)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | |--------------|--------|--------------------------------------------------------------------------------------------------------|---------------------------|--------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--| | Param<br>No. | Sym | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | | | | VIL | Input Low Voltage <sup>(4)</sup> | | | | | | | | DI10 | | I/O Pins | Vss | _ | 0.2 VDD | V | | | | DI15 | | MCLR | Vss | _ | 0.2 VDD | V | | | | DI16 | | OSCI (XT mode) | Vss | _ | 0.2 VDD | V | | | | DI17 | | OSCI (HS mode) | Vss | _ | 0.2 VDD | V | | | | DI18 | | I/O Pins with I <sup>2</sup> C Buffer | Vss | _ | 0.3 VDD | V | SMBus disabled | | | DI19 | | I/O Pins with SMBus Buffer | Vss | | 8.0 | V | SMBus enabled | | | DI20 | ViH | Input High Voltage <sup>(4,5)</sup> I/O Pins: with Analog Functions Digital Only | 0.8 Vdd<br>0.8 Vdd | _<br>_ | VDD<br>VDD | V | | | | DI25 | | MCLR | 0.8 VDD | | VDD | V | | | | DI26 | | OSCI (XT mode) | 0.7 VDD | _ | VDD | V | | | | DI27 | | OSCI (HS mode) | 0.7 VDD | _ | VDD | V | | | | DI28 | | I/O Pins with I <sup>2</sup> C Buffer:<br>with Analog Functions<br>Digital Only<br>I/O Pins with SMBus | 0.7 VDD<br>0.7 VDD<br>2.1 | _<br>_<br>_ | VDD<br>VDD<br>VDD | V<br>V | 2.5V ≤ VPIN ≤ VDD | | | DI30 | ICNPU | CNx Pull-up Current | 50 | 250 | 500 | μA | VDD = 3.3V, VPIN = VSS | | | DI31 | IPU | Maximum Load Current for | _ | _ | 30 | μA | V <sub>DD</sub> = 2.0V | | | | | Digital High Detection<br>w/Internal Pull-up | _ | _ | 1000 | μA | VDD = 3.3V | | | | lıL | Input Leakage Current <sup>(2,3)</sup> | | | | | | | | DI50 | | I/O Ports | _ | 0.050 | ±0.100 | μA | Vss ≤ Vpin ≤ Vpd,<br>Pin at high-impedance | | | DI51 | | Pins with OAxOUT Functions (RB15 and RB3) | _ | 0.100 | ±0.200 | μA | Vss ≤ VPIN ≤ VDD,<br>Pin at high-impedance | | - **Note 1:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. - 2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. - 3: Negative current is defined as current sourced by the pin. - 4: Refer to Table 1-4 and Table 1-5 for I/O pin buffer types. - **5:** VIH requirements are met when the internal pull-ups are enabled. TABLE 27-10: DC CHARACTERISTICS: I/O PIN OUTPUT SPECIFICATIONS | DC CHARACTERISTICS | | | Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C} \text{ for Industrial} \\ -40^{\circ}\text{C} \leq \text{TA} \leq +125^{\circ}\text{C} \text{ for Extended}$ | | | | | | | |--------------------|-----|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------|---------------|------------|--| | Param<br>No. | Sym | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Cond | litions | | | | Vol | Output Low Voltage | | | | | | | | | DO10 | | All I/O Pins | _ | _ | 0.4 | V | IOL = 8.0 mA | VDD = 4.5V | | | | | | _ | _ | 0.4 | V | IOL = 4.0 mA | VDD = 3.6V | | | | | | _ | _ | 0.4 | V | IOL = 3.5 mA | VDD = 2.0V | | | DO16 | | OSC2/CLKO | _ | _ | 0.4 | V | IOL = 2.0 mA | VDD = 4.5V | | | | | | _ | _ | 0.4 | V | IOL = 1.2 mA | VDD = 3.6V | | | | | | _ | _ | 0.4 | V | IOL = 0.4 mA | VDD = 2.0V | | | | Vон | Output High Voltage | | | | | | | | | DO20 | | All I/O Pins | 3.8 | _ | _ | V | Iон = -3.5 mA | VDD = 4.5V | | | | | | 3 | _ | _ | V | Iон = -3.0 mA | VDD = 3.6V | | | | | | 1.6 | _ | _ | V | Iон = -1.0 mA | VDD = 2.0V | | | DO26 | | OSC2/CLKO | 3.8 | _ | _ | V | Iон = -2.0 mA | VDD = 4.5V | | | | | | 3 | _ | _ | V | Iон = -1.0 mA | VDD = 3.6V | | | | | | 1.6 | _ | _ | V | Iон = -0.5 mA | VDD = 2.0V | | **Note 1:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. TABLE 27-11: DC CHARACTERISTICS: PROGRAM MEMORY | DC CHA | ARACTE | ERISTICS | Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C for Industrial} \\ -40^{\circ}\text{C} \leq \text{TA} \leq +125^{\circ}\text{C for Extended}$ | | | | | | |--------------|--------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----|------|-----------------------------------------------|--| | Param<br>No. | Sym | Characteristic | Min | Min Typ <sup>(1)</sup> Max Units Cond | | | Conditions | | | | | Program Flash Memory | | | | | | | | D130 | EР | Cell Endurance | 10,000 <sup>(2)</sup> | _ | _ | E/W | | | | D131 | VPR | VDD for Read | VMIN | _ | 3.6 | V | Vміn = Minimum operating voltage | | | D133A | Tıw | Self-Timed Write Cycle<br>Time | _ | 2 | _ | ms | | | | D134 | TRETD | Characteristic Retention | 40 | _ | _ | Year | Provided no other specifications are violated | | | D135 | IDDP | Supply Current During<br>Programming | _ | 10 | _ | mA | | | Note 1: Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. 2: Self-write and block erase. TABLE 27-12: DC CHARACTERISTICS: DATA EEPROM MEMORY | DC CHARACTERISTICS | | | Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \leq \text{Ta} \leq +85^{\circ}\text{C for Industrial} \\ -40^{\circ}\text{C} \leq \text{Ta} \leq +125^{\circ}\text{C for Extended}$ | | | | | | | |--------------------|---------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|------------|-----------------------------------------------|--|--| | Param<br>No. | Sym Characteristic Min Ivn\'' Max Units | | | | | Conditions | | | | | | | Data EEPROM Memory | | | | | | | | | D140 | EPD | Cell Endurance | 100,000 | _ | _ | E/W | | | | | D141 | VPRD | VDD for Read | VMIN | _ | 3.6 | V | Vміn = Minimum operating<br>voltage | | | | D143A | TIWD | Self-Timed Write Cycle<br>Time | _ | 4 | _ | ms | | | | | D143B | TREF | Number of Total<br>Write/Erase Cycles Before<br>Refresh | _ | 10M | _ | E/W | | | | | D144 | TRETDD | Characteristic Retention | 40 | _ | _ | Year | Provided no other specifications are violated | | | | D145 | IDDPD | Supply Current During<br>Programming | _ | 7 | _ | mA | | | | **Note 1:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. ### **TABLE 27-13: DC CHARACTERISTICS: COMPARATOR** | DC CHA | RACTER | ISTICS | Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \leq \text{Ta} \leq +85^{\circ}\text{C} \text{ for Industrial} \\ -40^{\circ}\text{C} \leq \text{Ta} \leq +125^{\circ}\text{C} \text{ for Extended}$ | | | | | | |--------------|--------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|----|--|--| | Param<br>No. | Symbol | Characteristic | Min | Conditions | | | | | | D300 | VIOFF | Input Offset Voltage | _ | 20 | 40 | mV | | | | D301 | VICM | Input Common-Mode Voltage | 0 | _ | VDD | V | | | | D302 | CMRR | Common-Mode Rejection Ratio | 55 | _ | _ | dB | | | ### TABLE 27-14: DC CHARACTERISTICS: COMPARATOR VOLTAGE REFERENCE | DC CHARACTERISTICS | | | Standard (Operating | | re | : 1.8V to 3.6V (PIC24F16KM204)<br>2.0V to 5.5V (PIC24FV16KM204)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | |--------------------|--------|-------------------------|---------------------|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------|------------------|--| | Param<br>No. | Symbol | Characteristic | Min | Тур | Max | Units | Conditions | | | VRD310 | CVRES | Resolution | _ | _ | VDD/32 | LSb | | | | VRD311 | CVRAA | Absolute Accuracy | _ | | 1 | LSb | AVDD = 3.3V-5.5V | | | VRD312 | CVRur | Unit Resistor Value (R) | _ | 2k | | Ω | | | ### **TABLE 27-15: INTERNAL VOLTAGE REGULATOR SPECIFICATIONS** Operating Conditions: $-40^{\circ}\text{C} < \text{Ta} < +85^{\circ}\text{C}$ (unless otherwise stated) $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | -40 G S IA S 1 120 G Ioi Exterided | | | | | | | | | | | | |--------------|------------------------------------|-----------------------------------------|-------|-------|-------|-------|-------------------------------------------------------------|--|--|--|--|--| | Param<br>No. | Symbol | Characteristics | Min | Тур | Max | Units | Comments | | | | | | | | VBG | Band Gap Reference | 0.973 | 1.04 | 1.075 | V | For PIC24F devices <sup>(1)</sup> | | | | | | | | | Voltage | 0.973 | 1.024 | 1.075 | V | For PIC24FV devices <sup>(1)</sup> | | | | | | | | TBG | Band Gap Reference<br>Start-up Time | | 1 | _ | ms | | | | | | | | | VRGOUT | Regulator Output Voltage | 3.1 | 3.3 | 3.6 | V | | | | | | | | | CEFC | External Filter Capacitor<br>Value | 4.7 | 10 | _ | μF | Series resistance < 3 Ohm recommended; < 5 Ohm is required. | | | | | | | | VLVR | Low-Voltage Regulator<br>Output Voltage | | 2.6 | _ | V | | | | | | | Note 1: VDD > 4.5V for 4 \* VBG reference, VDD > 2.3V for 2 \* VBG reference. ### **TABLE 27-16: CTMU CURRENT SOURCE SPECIFICATIONS** | | | | Stand | ard One | rating | Condition | ons: 1.8V to 3.6V (PIC24F | 16KM204) | | |--------------|-------|--------------------------------------|---------------------------------------------------------|----------|--------|-----------|--------------------------------------------------------------------------------------------------------|-----------------------|--| | DC CH | ARACT | ERISTICS | | ting ten | | | 2.0V to 5.5V (PIC24FV16KM204)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | | Param<br>No. | Sym | Characteristic | haracteristic Min Typ <sup>(1)</sup> Max Units Comments | | | | Conditions | | | | | Iout1 | CTMU Current<br>Source, Base Range | _ | 550 | _ | nA | CTMUCON1L[1:0] = 01 | | | | | IOUT2 | CTMU Current<br>Source, 10x Range | _ | 5.5 | _ | μA | CTMUCON1L[1:0] = 10 | 2.5V < VDD < VDDMAX | | | | Іоит3 | CTMU Current<br>Source, 100x Range | _ | 55 | _ | μA | CTMUCON1L[1:0] = 11 | 2.3V \ VDD \ VDDINIAX | | | | Iout4 | CTMU Current<br>Source, 1000x Range | _ | 550 | _ | μA | CTMUCON1L[1:0] = 00<br>(Note 2) | | | | | VF | Temperature Diode<br>Forward Voltage | _ | .76 | _ | V | | | | | | VΔ | Voltage Change per<br>Degree Celsius | _ | 1.6 | _ | mV/°C | | | | **Note 1:** Nominal value at the center point of the current trim range (CTMUCON1L[7:2] = 000000). On PIC24F16KM parts, the current output is limited to the typical current value when IoUT4 is chosen. 2: Do not use this current range with a temperature sensing diode. **TABLE 27-17: OPERATIONAL AMPLIFIER SPECIFICATIONS** | DC CH | ARACTE | RISTICS | Standard Operating te | _ | ditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) -40°C ≤ TA ≤ +85°C for Industrial -40°C ≤ TA ≤ +125°C for Extended | | | | |--------------|--------|------------------------------------|-----------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------|--| | Param<br>No. | Sym | Characteristic | Min | Min Typ <sup>(2)</sup> | | Units | Comments | | | | GBWP | Gain Bandwidth | _ | 5 | _ | MHz | SPDSEL = 1 | | | | | Product | _ | 0.5 | | MHz | SPDSEL = 0 | | | | SR | Slew Rate | _ | 1.2 | _ | V/µs | SPDSEL = 1 | | | | | | _ | 0.3 | _ | V/µs | SPDSEL = 0 | | | | Aol | DC Open-Loop Gain | Loop Gain — 90 — | | _ | dB | | | | | VIOFF | Input Offset Voltage | _ | ±2 | ±50 | mV | | | | | VIBC | Input Bias Current | _ | - - | | nA | Note 1 | | | | VICM | Common-Mode<br>Input Voltage Range | AVss | _ | AVDD - 850 | mV | | | | | CMRR | Common-Mode<br>Rejection Ratio | _ | 60 | | db | | | | | PSRR | Power Supply<br>Rejection Ratio | _ | 60 | _ | dB | | | | | Vor | Output Voltage<br>Range | AVss + 200 | AVss + 5 to<br>AVDD - 5 | AVDD - 200 | mV | 0.5V input overdrive, no output loading | | | | Rout | Output Impedance | _ | 6.668 | _ | Ω | Low-Power mode, VIN = 0.2V <sup>(2)</sup> | | | | | | | 3.890 | _ | Ω | Low-Power mode, VIN = 1.8V(2) | | | | | | _ | 0.246 | _ | Ω | Low-Power mode, VIN = 0.2V <sup>(2)</sup> | | | | | | _ | 0.277 | _ | Ω | Low-Power mode, VIN = 1.8V <sup>(2)</sup> | | **Note 1:** 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. <sup>2:</sup> To receive the "Typ" values, AVDD = 2V was used. ### 27.2 AC Characteristics and Timing Parameters The information contained in this section defines the PIC24FV16KM204 family AC characteristics and timing parameters. TABLE 27-18: TEMPERATURE AND VOLTAGE SPECIFICATIONS - AC | | Standard Operating Conditions: | 1.8V to 3.6V | |--------------------|------------------------------------|-----------------------------------------------| | AC CHARACTERISTICS | Operating temperature | -40°C ≤ TA ≤ +85°C for Industrial | | AC CHARACTERISTICS | | $-40$ °C $\leq$ TA $\leq$ +125°C for Extended | | | Operating voltage VDD range as des | scribed in Section 27.1 "DC Characteristics". | ### FIGURE 27-5: LOAD CONDITIONS FOR DEVICE TIMING SPECIFICATIONS TABLE 27-19: CAPACITIVE LOADING REQUIREMENTS ON OUTPUT PINS | Param<br>No. | Symbol | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | |--------------|--------|-----------------------|-----|--------------------|-----|-------|--------------------------------------------------------------| | DO50 | Cosc2 | OSCO/CLKO Pin | _ | | 15 | pF | In XT and HS modes when External Clock is used to drive OSCI | | DO56 | Сю | All I/O Pins and OSCO | _ | _ | 50 | pF | EC mode | | DO58 | Св | SCLx, SDAx | _ | _ | 400 | рF | In I <sup>2</sup> C mode | **Note 1:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. FIGURE 27-6: EXTERNAL CLOCK TIMING **TABLE 27-20: EXTERNAL CLOCK TIMING REQUIREMENTS** | | | . EXTERNAL OLOGIC I | | | | : 1.8V to | 3.6V (PIC24F16KM204) | | |--------------|---------------|-------------------------------------------------------------------------|--------------------------|--------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--| | AC CH | ARACT | ERISTICS | Operating temperature | | | 2.0V to 5.5V (PIC24FV16KM204) $-40^{\circ}$ C $\leq$ TA $\leq$ +85 $^{\circ}$ C for Industrial $-40^{\circ}$ C $\leq$ TA $\leq$ +125 $^{\circ}$ C for Extended | | | | Param<br>No. | Sym | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | | | OS10 | Fosc | External CLKI Frequency<br>(External Clocks allowed<br>only in EC mode) | DC<br>4<br>DC<br>4 | <br> -<br> - | 32<br>8<br>24<br>6 | MHz<br>MHz<br>MHz<br>MHz | EC: -40°C < TA < +85°C<br>ECPLL: -40°C < TA < +85°C<br>EC: -40°C < TA < +125°C<br>ECPLL: -40°C < TA < +125°C | | | | | Oscillator Frequency | 0.2<br>4<br>4<br>4<br>31 | | 4<br>25<br>8<br>6<br>33 | MHz<br>MHz<br>MHz<br>MHz<br>kHz | XT<br>HS<br>XTPLL: -40°C < TA < +85°C<br>XTPLL: -40°C < TA < +125°C<br>SOSC | | | OS20 | Tosc | Tosc = 1/Fosc | _ | _ | _ | _ | See Parameter OS10 for Fosc value | | | OS25 | Tcy | Instruction Cycle Time <sup>(2)</sup> | 62.5 | _ | DC | ns | | | | OS30 | TosL,<br>TosH | External Clock in (OSCI)<br>High or Low Time | 0.45 x Tosc | _ | _ | ns | EC | | | OS31 | TosR,<br>TosF | External Clock in (OSCI)<br>Rise or Fall Time | _ | _ | 20 | ns | EC | | | OS40 | TckR | CLKO Rise Time <sup>(3)</sup> | _ | 6 | 10 | ns | | | | OS41 | TckF | CLKO Fall Time <sup>(3)</sup> | _ | 6 | 10 | ns | | | - **Note 1:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. - 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 "Min." values with an External Clock applied to the OSCI/CLKI pin. When an External Clock input is used, the "Max." 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. CLKO is low for the Q1-Q2 period (1/2 TcY) and high for the Q3-Q4 period (1/2 TcY). ### **TABLE 27-21: PLL CLOCK TIMING SPECIFICATIONS** | AC CHARACTERISTICS | | | | Operating temperatu | | <b>2.0V to</b><br>-40°C ≤ | 1.8V to 3.6V (PIC24F16KM204)<br>2.0V to 5.5V (PIC24FV16KM204)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | |--------------------|-------|----------------------------------|------------------------------|---------------------|----|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--| | Param<br>No. | Sym | Characteristic <sup>(1)</sup> | Min Typ <sup>(2)</sup> Max l | | | Units | Conditions | | | | OS50 | FPLLI | PLL Input Frequency<br>Range | 4 | _ | 8 | MHz | ECPLL, HSPLL modes,<br>-40°C ≤ Ta ≤ +85°C | | | | OS51 | Fsys | PLL Output Frequency<br>Range | 16 | _ | 32 | MHz | -40°C ≤ TA ≤ +85°C | | | | OS52 | TLOCK | PLL Start-up Time<br>(Lock Time) | _ | 1 | 2 | ms | | | | | OS53 | DCLK | CLKO Stability (Jitter) | -2 | 1 | 2 | % | Measured over 100 ms period | | | Note 1: These parameters are characterized but not tested in manufacturing. **2:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested. ### TABLE 27-22: INTERNAL RC OSCILLATOR ACCURACY<sup>(3)</sup> | AC CHA | ARACTERISTICS | Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) Operating temperature $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \leq \text{TA} \leq +125^{\circ}\text{C}$ for Extended | | | | | | | | |--------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------|---------------------|------------------------------------------------------------------------------------------|--|--| | Param<br>No. | Characteristic | Min | Тур | Max | Units | Conditions | | | | | F20 | FRC @ 8 MHz <sup>(1)</sup> | -2 | _ | +2 | % | +25°C | $3.0$ V $\leq$ VDD $\leq$ $3.6$ V, F device $3.2$ V $\leq$ VDD $\leq$ $5.5$ V, FV device | | | | | | -5 | _ | +5 | % | -40°C ≤ TA ≤ +125°C | $1.8V \le VDD \le 3.6V$ , F device $2.0V \le VDD \le 5.5V$ , FV device | | | | F21 | LPRC @ 31 kHz <sup>(2)</sup> | -15 | _ | +15 | % | -40°C ≤ TA ≤ +125°C | $1.8V \le VDD \le 3.6V$ , F device $2.0V \le VDD \le 5.5V$ , FV device | | | **Note 1:** The frequency is calibrated at +25°C and 3.3V. The OSCTUN bits can be used to compensate for temperature drift. 2: The change of LPRC frequency as VDD changes. 3: In High-Power/High-Accuracy mode, the Configuration bit, LPRCSEL = 1. ### **TABLE 27-23: INTERNAL RC OSCILLATOR SPECIFICATIONS** | AC CHARACTERISTICS | | | Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM200) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | | |--------------------------|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|-------|------------|--| | Param<br>No. | Sym | Characteristic | Min Typ Max | | | Units | Conditions | | | | TFRC | FRC Start-up Time | _ | 5 | _ | μs | | | | TLPRC LPRC Start-up Time | | | _ | 70 | _ | μs | | | ### FIGURE 27-7: CLKO AND I/O TIMING CHARACTERISTICS TABLE 27-24: CLKO AND I/O TIMING REQUIREMENTS | AC CHA | ARACTI | ERISTICS | | <b>Operating</b> temperatu | | <b>2.0V to</b><br>-40°C ≤ | 1.8V to 3.6V (PIC24F16KM204)<br>2.0V to 5.5V (PIC24FV16KM204)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | |--------------|--------|------------------------------------|-----|----------------------------|-----|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--| | Param<br>No. | Sym | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | | | | DO31 | TioR | Port Output Rise Time | _ | 10 | 25 | ns | | | | | DO32 | TioF | Port Output Fall Time | _ | 10 | 25 | ns | | | | | DI35 | TINP | INTx Pin High or Low Time (output) | 20 | _ | _ | ns | | | | | DI40 | TRBP | CNx High or Low Time (input) | 2 | _ | _ | Tcy | | | | Note 1: Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. FIGURE 27-8: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING CHARACTERISTICS FIGURE 27-9: BROWN-OUT RESET CHARACTERISTICS TABLE 27-25: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER AND BROWN-OUT RESET TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: Operating temperature | | | | 1.8V to 3.6V (PIC24F16KM204)<br>2.0V to 5.5V (PIC24FV16KM204)<br>-40°C ≤ TA ≤ +85°C for Industrial<br>-40°C ≤ TA ≤ +125°C for Extended | | | |--------------------|--------|----------------------------------------------------------------|------------------------------------------------------|--------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------|--|--| | Param<br>No. | Symbol | Characteristic | Min. | Typ <sup>(1)</sup> | Max. | Units | Conditions | | | | SY10 | TmcL | MCLR Pulse Width (low) | 2 | _ | | μs | | | | | SY11 | TPWRT | Power-up Timer Period | 50 | 64 | 90 | ms | | | | | SY12 | TPOR | Power-on Reset Delay | 1 | 5 | 10 | μs | | | | | SY13 | Tioz | I/O High-Impedance from<br>MCLR Low or Watchdog<br>Timer Reset | _ | _ | 100 | ns | | | | | SY20 | TWDT | Watchdog Timer Time-out | 0.85 | 1.0 | 1.15 | ms | 1.32 prescaler | | | | | | Period | 3.4 | 4.0 | 4.6 | ms | 1:128 prescaler | | | | SY25 | TBOR | Brown-out Reset Pulse<br>Width | 1 | _ | _ | μs | | | | | SY35 | TFSCM | Fail-Safe Clock Monitor<br>Delay | _ | 2.0 | 2.3 | μs | | | | | SY45 | TRST | Internal State Reset Time | _ | 5 | _ | μs | | | | | SY50 | TVREG | On-Chip Voltage Regulator<br>Output Delay | _ | 10 | _ | μs | Note 2 | | | | SY55 | TLOCK | PLL Start-up Time | _ | 100 | _ | μs | | | | | SY65 | Tost | Oscillator Start-up Time | _ | 1024 | _ | Tosc | | | | | SY71 | ТРМ | Program Memory Wake-up<br>Time | _ | 1 | _ | μs | Sleep wake-up with PMSLP = 0 | | | | SY72 | TLVR | Low-Voltage Regulator<br>Wake-up Time | _ | 250 | _ | μs | | | | **Note 1:** Data in "Typ" column are at 3.3V, +25°C unless otherwise stated. 2: This applies to PIC24FV16KMXXX devices only. ### **TABLE 27-26: COMPARATOR TIMING REQUIREMENTS** | Param<br>No. | Symbol | Characteristic | Min | Тур | Max | Units | Comments | |--------------|--------|-----------------------------------------|-----|-----|-----|-------|----------| | 300 | TRESP | Response Time*(1) | _ | 150 | 400 | ns | | | 301 | Тмс2о∨ | Comparator Mode Change to Output Valid* | _ | _ | 10 | μs | | <sup>\*</sup> Parameters are characterized but not tested. Note 1: Response time is measured with one comparator input at (VDD – 1.5)/2, while the other input transitions from Vss to VDD. TABLE 27-27: COMPARATOR VOLTAGE REFERENCE SETTLING TIME SPECIFICATIONS | Param<br>No. | Symbol | Characteristic | Min | Тур | Max | Units | Comments | |--------------|--------|------------------------------|-----|-----|-----|-------|----------| | VR310 | TSET | Settling Time <sup>(1)</sup> | _ | | 10 | μs | | Note 1: Settling time is measured while CVRSS = 1 and the CVR[3:0] bits transition from '0000' to '1111'. ### FIGURE 27-10: CAPTURE/COMPARE/PWM TIMINGS (MCCPx, SCCPx MODULES) ### TABLE 27-28: CAPTURE/COMPARE/PWM REQUIREMENTS (MCCPx, SCCPx MODULES) | Param<br>No. | Symbol | Characteristic | Min Max | | Units | Conditions | |--------------|--------|----------------------------------------|------------|---|-------|------------------------------------| | 50 | TCLKL | CCPx Time Base Clock Source Low Time | Tcy/2 | _ | ns | | | 51 | TCLKH | CCPx Time Base Clock Source High Time | Tcy/2 | _ | ns | | | 52 | TCLK | CCPx Time Base Clock Source Period | Tcy | _ | ns | | | 53 | TccL | CCPx Capture or Gating Input Low Time | TCLK | _ | ns | | | 54 | TccH | CCPx Capture or Gating Input High Time | TCLK | _ | ns | | | 55 | TccP | CCPx Capture or Gating Input Period | 2 * Tclk/N | _ | ns | N = Prescale<br>Value (1, 4 or 16) | FIGURE 27-11: EXAMPLE SPI MASTER MODE TIMING (CKE = 0) TABLE 27-29: EXAMPLE SPI MODE REQUIREMENTS (MASTER MODE, CKE = 0) | Param<br>No. | Symbol | Characteristic | Min Max | | Units | Conditions | |--------------|-----------------------|--------------------------------------------|---------|----|-------|------------| | 73 | TDIV2scH,<br>TDIV2scL | Setup Time of SDIx Data Input to SCKx Edge | 20 | _ | ns | | | 74 | TscH2DIL,<br>TscL2DIL | Hold Time of SDIx Data Input to SCKx Edge | 40 | _ | ns | | | 75 | TDOR | SDOx Data Output Rise Time | _ | 25 | ns | | | 76 | TDOF | SDOx Data Output Fall Time | _ | 25 | ns | | | 78 | TscR | SCKx Output Rise Time (Master mode) | _ | 25 | ns | | | 79 | TscF | SCKx Output Fall Time (Master mode) | _ | 25 | ns | | | | Fsck | SCKx Frequency | _ | 10 | MHz | | FIGURE 27-12: EXAMPLE SPI MASTER MODE TIMING (CKE = 1) TABLE 27-30: EXAMPLE SPI MODE REQUIREMENTS (MASTER MODE, CKE = 1) | Param.<br>No. | Symbol | Characteristic | Min | Max | Units | Conditions | |---------------|-----------------------|--------------------------------------------|-----|-----|-------|------------| | 73 | TDIV2scH,<br>TDIV2scL | Setup Time of SDIx Data Input to SCKx Edge | 35 | _ | ns | | | 74 | TscH2DIL,<br>TscL2DIL | Hold Time of SDIx Data Input to SCKx Edge | 40 | _ | ns | | | 75 | TDOR | SDOx Data Output Rise Time | _ | 25 | ns | | | 76 | TDOF | SDOx Data Output Fall Time | _ | 25 | ns | | | 78 | TscR | SCKx Output Rise Time (Master mode) | _ | 25 | ns | | | 79 | TscF | SCKx Output Fall Time (Master mode) | _ | 25 | ns | | | 81 | TDOV2scH,<br>TDOV2scL | SDOx Data Output Setup to SCKx Edge | Tcy | _ | ns | | | | Fsck | SCKx Frequency | _ | 10 | MHz | | FIGURE 27-13: EXAMPLE SPI SLAVE MODE TIMING (CKE = 0) TABLE 27-31: EXAMPLE SPI MODE REQUIREMENTS (SLAVE MODE TIMING, CKE = 0) | Param<br>No. | Symbol | Characteristic | Characteristic | | Max | Units | Conditions | |--------------|-----------------------|--------------------------------------------|-------------------|---------------|-----|-------|------------| | 70 | TssL2scH,<br>TssL2scL | SSx ↓ to SCKx ↓ or SCKx ↑ Input | | 3 TcY | | ns | | | 70A | TssL2WB | SSx to Write to SSPxBUF | | 3 Tcy | _ | ns | | | 71 | TscH | SCKx Input High Time | Continuous | 1.25 Tcy + 30 | _ | ns | | | 71A | | (Slave mode) | Single Byte | 40 | _ | ns | Note 1 | | 72 | TscL | SCKx Input Low Time | Continuous | 1.25 Tcy + 30 | _ | ns | | | 72A | | (Slave mode) | Single Byte | 40 | _ | ns | Note 1 | | 73 | TDIV2scH,<br>TDIV2scL | Setup Time of SDIx Data Input to SCKx | 20 | | ns | | | | 73A | Тв2в | Last Clock Edge of Byte 1 to the First Clo | ck Edge of Byte 2 | 1.5 Tcy + 40 | _ | ns | Note 2 | | 74 | TscH2DIL,<br>TscL2DIL | Hold Time of SDIx Data Input to SCKx I | Edge | 40 | _ | ns | | | 75 | TDOR | SDOx Data Output Rise Time | | _ | 25 | ns | | | 76 | TDOF | SDOx Data Output Fall Time | | _ | 25 | ns | | | 77 | TssH2DoZ | SSx ↑ to SDOx Output High-Impedance | <del></del> | 10 | 50 | ns | | | 80 | TSCH2DOV,<br>TSCL2DOV | SDOx Data Output Valid After SCKx Edge | | _ | 50 | ns | | | 83 | TscH2ssH,<br>TscL2ssH | SSx ↑ After SCKx Edge | x Edge | | _ | ns | | | | Fsck | SCKx Frequency | | _ | 10 | MHz | | **Note 1:** Requires the use of Parameter 73A. 2: Only if Parameters 71A and 72A are used. SSx SCKx(CKP = 0) SCKx (CKP = 1)LSb MSb bit 6 SDOx 75, 76 SDIx bit 6 LSb In Note: Refer to Figure 27-5 for load conditions. FIGURE 27-14: **EXAMPLE SPI SLAVE MODE TIMING (CKE = 1)** TABLE 27-32: EXAMPLE SPI SLAVE MODE REQUIREMENTS (CKE = 1) | Param<br>No. | Symbol | Characteristic | | Min | Max | Units | Conditions | |--------------|-----------------------|----------------------------------------------------|--------------|---------------|-----|--------|------------| | 70 | TssL2scH,<br>TssL2scL | SSx ↓ to SCKx ↓ or SCKx ↑ Input | | 3 Tcy | 1 | ns | | | 70A | TssL2WB | SSx to Write to SSPxBUF | | 3 Tcy | _ | ns | | | 71 | TscH | SCKx Input High Time | Continuous | 1.25 Tcy + 30 | _ | ns | | | 71A | | (Slave mode) | Single Byte | 40 | _ | ns | Note 1 | | 72 | TscL | SCKx Input Low Time | Continuous | 1.25 Tcy + 30 | _ | ns | | | 72A | | (Slave mode) | Single Byte | 40 | _ | ns | Note 1 | | 73A | Тв2в | Last Clock Edge of Byte 1 to the First | 1.5 Tcy + 40 | _ | ns | Note 2 | | | 74 | TscH2DIL,<br>TscL2DIL | Hold Time of SDIx Data Input to SCI | Kx Edge | 40 | | ns | | | 75 | TDOR | SDOx Data Output Rise Time | | _ | 25 | ns | | | 76 | TDOF | SDOx Data Output Fall Time | | _ | 25 | ns | | | 77 | TssH2DoZ | SSx ↑ to SDOx Output High-Impeda | ince | 10 | 50 | ns | | | 80 | TscH2DoV,<br>TscL2DoV | | | _ | 50 | ns | | | 82 | TssL2DoV | SDOx Data Output Valid After <del>SSx</del> ↓ Edge | | _ | 50 | ns | | | 83 | TscH2ssH,<br>TscL2ssH | SSx ↑ After SCKx Edge | | 1.5 Tcy + 40 | | ns | | | | Fsck | SCKx Frequency | | | 10 | MHz | | Note 1: Requires the use of Parameter 73A. 2: Only if Parameters 71A and 72A are used. FIGURE 27-15: I<sup>2</sup>C BUS START/STOP BITS TIMING TABLE 27-33: I<sup>2</sup>C BUS START/STOP BITS REQUIREMENTS (SLAVE MODE) | Param.<br>No. | Symbol | Characte | ristic | Min | Max | Units | Conditions | |---------------|---------|-----------------|--------------|------|-----|-------|------------------------------| | 90 | Tsu:sta | Start Condition | 100 kHz mode | 4700 | _ | ns | Only relevant for Repeated | | | | Setup Time | 400 kHz mode | 600 | _ | | Start condition | | 91 | THD:STA | Start Condition | 100 kHz mode | 4000 | _ | ns | After this period, the first | | | | Hold Time | 400 kHz mode | 600 | _ | | clock pulse is generated | | 92 | Tsu:sto | Stop Condition | 100 kHz mode | 4700 | _ | ns | | | | | Setup Time | 400 kHz mode | 600 | _ | | | | 93 | THD:STO | Stop Condition | 100 kHz mode | 4000 | _ | ns | | | | | Hold Time | 400 kHz mode | 600 | _ | | | FIGURE 27-16: I<sup>2</sup>C BUS DATA TIMING ## TABLE 27-34: I<sup>2</sup>C BUS DATA REQUIREMENTS (SLAVE MODE) | Param.<br>No. | Symbol | Characteris | tic | Min | Max | Units | Conditions | |---------------|---------|----------------------------|--------------|-------------|------|-------|-----------------------------------------| | 100 | THIGH | Clock High Time | 100 kHz mode | 4.0 | _ | μs | Must operate at a minimum of 1.5 MHz | | | | | 400 kHz mode | 0.6 | _ | μs | Must operate at a minimum of 10 MHz | | | | | MSSPx module | 1.5 TcY | _ | _ | | | 101 | TLOW | Clock Low Time | 100 kHz mode | 4.7 | _ | μs | Must operate at a minimum of 1.5 MHz | | | | | 400 kHz mode | 1.3 | _ | μs | Must operate at a minimum of 10 MHz | | | | | MSSPx module | 1.5 Tcy | _ | _ | | | 102 | TR | SDAx and SCLx Rise Time | 100 kHz mode | _ | 1000 | ns | | | | | | 400 kHz mode | 20 + 0.1 CB | 300 | ns | CB is specified to be from 10 to 400 pF | | 103 | TF | SDAx and SCLx Fall Time | 100 kHz mode | _ | 300 | ns | | | | | | 400 kHz mode | 20 + 0.1 CB | 300 | ns | CB is specified to be from 10 to 400 pF | | 90 | Tsu:sta | Start Condition Setup Time | 100 kHz mode | 4.7 | _ | μs | Only relevant for Repeated | | | | | 400 kHz mode | 0.6 | _ | μs | Start condition | | 91 | THD:STA | Start Condition Hold Time | 100 kHz mode | 4.0 | _ | μs | After this period, the first clock | | | | | 400 kHz mode | 0.6 | _ | μs | pulse is generated | | 106 | THD:DAT | Data Input Hold Time | 100 kHz mode | 0 | _ | ns | | | | | | 400 kHz mode | 0 | 0.9 | μs | | | 107 | TSU:DAT | Data Input Setup Time | 100 kHz mode | 250 | _ | ns | Note 2 | | | | | 400 kHz mode | 100 | _ | ns | | | 92 | Tsu:sto | Stop Condition Setup Time | 100 kHz mode | 4.7 | _ | μs | | | | | | 400 kHz mode | 0.6 | _ | μs | | | 109 | TAA | Output Valid from Clock | 100 kHz mode | _ | 3500 | ns | Note 1 | | | | | 400 kHz mode | _ | | ns | | | 110 | TBUF | Bus Free Time | 100 kHz mode | 4.7 | _ | μs | Time the bus must be free before | | | | | 400 kHz mode | 1.3 | _ | μs | a new transmission can start | | D102 | Св | Bus Capacitive Loading | | _ | 400 | pF | | Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCLx to avoid unintended generation of Start or Stop conditions. <sup>2:</sup> A Fast mode I²C bus device can be used in a Standard mode I²C bus system, but the requirement, TSU:DAT ≥ 250 ns, must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCLx signal. If such a device does stretch the LOW period of the SCLx signal, it must output the next data bit to the SDAx line, TR max. + TSU:DAT = 1000 + 250 = 1250 ns (according to the Standard mode I²C bus specification), before the SCLx line is released. ## FIGURE 27-17: MSSPx I<sup>2</sup>C BUS START/STOP BITS TIMING WAVEFORMS ## TABLE 27-35: I<sup>2</sup>C BUS START/STOP BITS REQUIREMENTS (MASTER MODE) | Param.<br>No. | Symbol | Characteristic | | Min | Max | Units | Conditions | | |---------------|---------|-----------------|--------------|------------------|-----|-------|--------------------------------|--| | 90 | Tsu:sta | Start Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | ns | Only relevant for | | | | | Setup Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | | Repeated Start condition | | | 91 | THD:STA | Start Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | ns | After this period, the | | | | | Hold Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | | first clock pulse is generated | | | 92 | Tsu:sto | Stop Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | ns | | | | | | Setup Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | | | | | 93 | THD:STO | Stop Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | ns | | | | | | Hold Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | | | | ## FIGURE 27-18: MSSPx I<sup>2</sup>C BUS DATA TIMING ## TABLE 27-36: I<sup>2</sup>C BUS DATA REQUIREMENTS (MASTER MODE) | Param.<br>No. | Symbol | Charac | teristic | Min | Max | Units | Conditions | | |---------------|---------|------------------|--------------|------------------|------|-------|-------------------------------------|--| | 100 | THIGH | Clock High Time | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | | | | | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | | | | | 101 | TLOW | Clock Low Time | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | | | | | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | | 102 | Tr | SDAx and SCLx | 100 kHz mode | _ | 1000 | ns | CB is specified to be from | | | | | Rise Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | 10 to 400 pF | | | 103 | TF | SDAx and SCLx | 100 kHz mode | _ | 300 | ns | CB is specified to be from | | | | | Fall Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | 10 to 400 pF | | | 90 | Tsu:sta | Start Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | Only relevant for Repeated | | | | | Setup Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | Start condition | | | 91 | THD:STA | Start Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | After this period, the first | | | | | Hold Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | clock pulse is generated | | | 106 | THD:DAT | Data Input | 100 kHz mode | 0 | _ | ns | | | | | | Hold Time | 400 kHz mode | 0 | 0.9 | μs | | | | 107 | TSU:DAT | Data Input | 100 kHz mode | 250 | _ | ns | Note 1 | | | | | Setup Time | 400 kHz mode | 100 | _ | ns | | | | 92 | Tsu:sto | Stop Condition | 100 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | | | | Setup Time | 400 kHz mode | 2(Tosc)(BRG + 1) | _ | _ | | | | 109 | TAA | Output Valid | 100 kHz mode | _ | 3500 | ns | | | | | | from Clock | 400 kHz mode | _ | 1000 | ns | | | | 110 | TBUF | Bus Free Time | 100 kHz mode | 4.7 | | μs | Time the bus must be free | | | | | | 400 kHz mode | 1.3 | _ | μs | before a new transmission can start | | | D102 | Св | Bus Capacitive L | oading | | 400 | pF | | | Note 1: A Fast mode I²C bus device can be used in a Standard mode I²C bus system, but Parameter 107 ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCLx signal. If such a device does stretch the LOW period of the SCLx signal, it must output the next data bit to the SDAx line, Parameter 102 + Parameter 107 = 1000 + 250 = 1250 ns (for 100 kHz mode), before the SCLx line is released. #### TABLE 27-37: A/D MODULE SPECIFICATIONS | | | | Standard Opera | ting Co | onditions: 1.8V to | 3.6V ( | PIC24F16KM204) | | |--------------|--------------|------------------------------------------------------|---------------------------------|---------|--------------------------------|----------|------------------------------------------------|--| | AC CHA | ARACTERI | ISTICS | 2.0V to 5.5V (PIC24FV16KM204) | | | | | | | AC CITA | AINAO I LINI | 01100 | Operating tempe | erature | | | +85°C for Industrial | | | | 1 | <u> </u> | | | -40°C : | ≤ IA ≤ · | +125°C for Extended | | | Param<br>No. | Symbol | Characteristic | Min. | Тур | Max. | Units | Conditions | | | | | | Device S | upply | | | | | | AD01 | AVDD | Module VDD Supply | Greater of:<br>VDD – 0.3 or 1.8 | | Lesser of:<br>VDD + 0.3 or 3.6 | > | PIC24FXXKMXXX devices | | | | | | Greater of:<br>VDD – 0.3 or 2.0 | _ | Lesser of:<br>VDD + 0.3 or 5.5 | ٧ | PIC24FVXXKMXXX devices | | | AD02 | AVss | Module Vss Supply | Vss - 0.3 | _ | Vss + 0.3 | V | | | | | | | Reference | Input | S | | | | | AD05 | VREFH | Reference Voltage High | AVss + 1.7 | _ | AVDD | V | | | | AD06 | VREFL | Reference Voltage Low | AVss | _ | AVDD - 1.7 | V | | | | AD07 | VREF | Absolute Reference<br>Voltage | AVss - 0.3 | _ | AVDD + 0.3 | V | | | | AD08 | IVREF | Reference Voltage Input<br>Current | _ | 1.25 | _ | mA | | | | AD09 | ZVREF | Reference Input<br>Impedance | _ | 10k | _ | Ω | | | | | • | | Analog | Input | | | | | | AD10 | VINH-VINL | Full-Scale Input Span | VREFL | _ | VREFH | V | Note 2 | | | AD11 | VIN | Absolute Input Voltage | AVss - 0.3 | _ | AVDD + 0.3 | V | | | | AD12 | VINL | Absolute VINL Input<br>Voltage | AVss - 0.3 | | AVDD/2 | V | | | | AD17 | Rin | Recommended<br>Impedance of Analog<br>Voltage Source | _ | _ | 1k | Ω | 12-bit | | | | | | A/D Acc | uracy | | | | | | AD20b | NR | Resolution | _ | 12 | _ | bits | | | | AD21b | INL | Integral Nonlinearity | _ | ±1 | ±9 | LSb | VINL = AVSS = VREFL = 0V,<br>AVDD = VREFH = 5V | | | AD22b | DNL | Differential Nonlinearity | _ | ±1 | ±5 | LSb | VINL = AVSS = VREFL = 0V,<br>AVDD = VREFH = 5V | | | AD23b | GERR | Gain Error | _ | ±1 | ±9 | LSb | VINL = AVSS = VREFL = 0V,<br>AVDD = VREFH = 5V | | | AD24b | EOFF | Offset Error | _ | ±1 | ±5 | LSb | VINL = AVSS = VREFL = 0V,<br>AVDD = VREFH = 5V | | | AD25b | | Monotonicity <sup>(1)</sup> | _ | _ | _ | _ | Guaranteed | | **Note 1:** The A/D conversion result never decreases with an increase in the input voltage. <sup>2:</sup> Measurements are taken with external VREF+ and VREF- used as the A/D voltage reference. ### FIGURE 27-19: A/D CONVERSION TIMING ## TABLE 27-38: A/D CONVERSION TIMING REQUIREMENTS<sup>(1)</sup> | | | | Standard Operating Conditions: 1.8V to 3.6V (PIC24F16KM204) | | | | | | | |--------------|------------------|------------------------------------------------------|-------------------------------------------------------------|----------|--------|------------|---------------------------------------------------------------------------------------------------------------------|--|--| | AC CHA | ARACTI | ERISTICS | Operating temperature -40°C | | | | to 5.5V (PIC24FV16KM204)<br>$C \le TA \le +85^{\circ}C$ for Industrial<br>$C \le TA \le +125^{\circ}C$ for Extended | | | | Param<br>No. | Sym | Characteristic | Min. Typ Max. Units Conditions | | | | | | | | | Clock Parameters | | | | | | | | | | AD50 | TAD | A/D Clock Period | 600 | _ | _ | ns | Tcy = 75 ns, AD1CON3 in Default state | | | | AD51 | Trc | A/D Internal RC Oscillator Period | _ | 1.67 | _ | μs | | | | | | | | Conver | sion Rat | е | | | | | | AD55 | TCONV | Conversion Time | _ | 12<br>14 | _<br>_ | Tad<br>Tad | 10-bit results<br>12-bit results | | | | AD56 | FCNV | Throughput Rate | _ | _ | 100 | ksps | | | | | AD57 | TSAMP | Sample Time | | 1 | _ | TAD | | | | | AD58 | TACQ | Acquisition Time | 750 | _ | _ | ns | Note 2 | | | | AD59 | Tswc | Switching Time from Convert to Sample | _ | _ | Note 3 | | | | | | AD60 | TDIS | Discharge Time | 12 | _ | | TAD | | | | | | - | | Clock P | arametei | 's | | | | | | AD61 | TPSS | Sample Start Delay from<br>Setting Sample bit (SAMP) | 2 | _ | 3 | TAD | | | | - **Note 1:** Because the sample caps will eventually lose charge, clock rates below 10 kHz can affect linearity performance, especially at elevated temperatures. - 2: The time for the holding capacitor to acquire the "New" input voltage when the voltage changes full scale after the conversion (VDD to VSS or VSS to VDD). - 3: On the following cycle of the device clock. TABLE 27-39: 8-BIT DIGITAL-TO-ANALOG CONVERTER SPECIFICATIONS | AC CHARACTERISTICS | | | | perating Co | nditions: 1.8V to 3.6V (PIC24F16KM204) 2.0V to 5.5V (PIC24FV16KM204) $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \leq \text{TA} \leq +125^{\circ}\text{C}$ for Extended | | | | |--------------------|-----|------------------------------------|------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------|--| | Param<br>No. | Sym | Characteristic | Min. | Min. Typ | | Units | Comments | | | | | Resolution | 8 | _ | _ | bits | | | | | | DACREF[1:0] Input Voltage<br>Range | AVss + 1.8 | | AVDD | V | | | | | | Differential Linearity Error (DNL) | _ | _ | ±0.5 | LSb | | | | | | Integral Linearity Error (INL) | _ | _ | ±1.5 | LSb | | | | | | Offset Error | _ | | ±0.5 | LSb | | | | | | Gain Error | _ | _ | ±3.0 | LSb | | | | | | Monotonicity | _ | _ | _ | _ | Note 1 | | | | | Output Voltage Range | AVss + 50 | AVss + 5 to<br>AVDD - 5 | AVDD - 50 | mV | 0.5V input overdrive, no output loading | | | | | Slew Rate | | 5 | _ | V/µs | | | | | | Settling Time | _ | 10 | _ | μs | | | | | | Unit Resistor Resistance | _ | 410 | _ | Ω | | | **Note 1:** DAC output voltage never decreases with an increase in the data code. #### 28.0 PACKAGING INFORMATION ### 28.1 Package Marking Information 20-Lead PDIP (300 mil) 20-Lead SSOP (5.30 mm) 20-Lead SOIC (7.50 mm) 28-Lead SPDIP (.300") 28-Lead SSOP (5.30 mm) #### Example #### Example #### Example #### Example #### Example Legend: XX...X Product-specific information Y Year code (last digit of calendar year) YY Year code (last 2 digits of calendar year) WW Week code (week of January 1 is week '01') NNN Alphanumeric traceability code B-free JEDEC designator for Matte Tin (Sn) This package is Pb-free. The Pb-free JEDEC designator (e3) can be found on the outer packaging for this package. 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. Note: 28-Lead SOIC (7.50 mm) 28-Lead QFN (6x6 mm) 44-Lead TQFP (10x10x1 mm) 44-Lead QFN (8x8x0.9 mm) 48-Lead UQFN (6x6x0.5 mm) Example Example Example Example Example ## 28.2 Package Details The following sections give the technical details of the packages. ## 20-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | INCHES | | |----------------------------|------------------|------|----------|-------| | С | Dimension Limits | MIN | NOM | MAX | | Number of Pins | N | | 20 | | | Pitch | е | | .100 BSC | | | Top to Seating Plane | Α | _ | _ | .210 | | Molded Package Thickness | A2 | .115 | .130 | .195 | | Base to Seating Plane | A1 | .015 | _ | _ | | Shoulder to Shoulder Width | E | .300 | .310 | .325 | | Molded Package Width | E1 | .240 | .250 | .280 | | Overall Length | D | .980 | 1.030 | 1.060 | | Tip to Seating Plane | L | .115 | .130 | .150 | | Lead Thickness | С | .008 | .010 | .015 | | Upper Lead Width | b1 | .045 | .060 | .070 | | Lower Lead Width | b | .014 | .018 | .022 | | Overall Row Spacing § | eB | _ | _ | .430 | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic. - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-019B ### 20-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | MILLIMETERS | | | | |--------------------------|------------|-------------|----------|------|--| | Dimens | ion Limits | MIN | NOM | MAX | | | Number of Pins | N | | 20 | | | | Pitch | е | | 0.65 BSC | | | | Overall Height | Α | ı | - | 2.00 | | | Molded Package Thickness | A2 | 1.65 | 1.75 | 1.85 | | | Standoff | A1 | 0.05 | _ | _ | | | Overall Width | Е | 7.40 | 7.80 | 8.20 | | | Molded Package Width | E1 | 5.00 | 5.30 | 5.60 | | | Overall Length | D | 6.90 | 7.20 | 7.50 | | | Foot Length | L | 0.55 | 0.75 | 0.95 | | | Footprint | L1 | 1.25 REF | | | | | Lead Thickness | С | 0.09 | - | 0.25 | | | Foot Angle | ф | 0° | 4° | 8° | | | Lead Width | b | 0.22 | _ | 0.38 | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.20 mm per side. - 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-072B ### 20-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **e:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | ٨ | ILLIMETER. | S | | |--------------------------|-----|------------|----------|------| | Dimension | MIN | NOM | MAX | | | Contact Pitch | E | | 0.65 BSC | | | Contact Pad Spacing | С | | 7.20 | | | Contact Pad Width (X20) | X1 | | | 0.45 | | Contact Pad Length (X20) | Y1 | | | 1.75 | | 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-2072A ## 20-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-094C Sheet 1 of 2 ## 20-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | MILLIMETERS | | | | |--------------------------|-------------|-------------|-----------|------| | D <b>i</b> mension L | imits. | MIN | NOM | MAX | | Number of Pins | N | | 20 | | | Pitch | е | | 1.27 BSC | | | Overall Height | Α | - | _ | 2.65 | | Molded Package Thickness | A2 | 2.05 | - | - | | Standoff § | A1 | 0.10 | - | 0.30 | | Overall Width | E | 10.30 BSC | | | | Molded Package Width | E1 | 7.50 BSC | | | | Overall Length | D | | 12.80 BSC | | | Chamfer (Optional) | h | 0.25 | - | 0.75 | | Foot Length | L | 0.40 | _ | 1.27 | | Footprint | L1 | | 1.40 REF | | | Lead Angle | Θ | 0° | - | - | | Foot Angle | φ | 0° | - | 8° | | Lead Thickness | С | 0.20 - 0.33 | | | | Lead Width | b | 0.31 | | 0.51 | | Mold Draft Angle Top | α | 5° - 15° | | | | Mold Draft Angle Bottom | β | 5° | _ | 15° | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic - Dimension D does not include mold flash, protrusions or gate burrs, which shall not exceed 0.15 mm per end. Dimension E1 does not include interlead flash or protrusion, which 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. 5. Datums A & B to be determined at Datum H. Microchip Technology Drawing No. C04-094C Sheet 2 of 2 20-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **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 | Е | 1.27 BSC | | | | Contact Pad Spacing | С | | 9.40 | | | Contact Pad Width (X20) | Х | | | 0.60 | | Contact Pad Length (X20) | Υ | | | 1.95 | | Distance Between Pads | Gx | 0.67 | | | | Distance Between Pads | G | 7.45 | | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2094A ## 28-Lead Skinny Plastic Dual In-Line (SP) - 300 mil Body [SPDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | INCHES | | |----------------------------|----------|-------|----------|-------| | Dimensio | n Limits | MIN | NOM | MAX | | Number of Pins | N | | 28 | | | Pitch | е | | .100 BSC | | | Top to Seating Plane | Α | _ | - | .200 | | Molded Package Thickness | A2 | .120 | .135 | .150 | | Base to Seating Plane | A1 | .015 | - | _ | | Shoulder to Shoulder Width | Е | .290 | .310 | .335 | | Molded Package Width | E1 | .240 | .285 | .295 | | Overall Length | D | 1.345 | 1.365 | 1.400 | | Tip to Seating Plane | L | .110 | .130 | .150 | | Lead Thickness | С | .008 | .010 | .015 | | Upper Lead Width | b1 | .040 | .050 | .070 | | Lower Lead Width | b | .014 | .018 | .022 | | Overall Row Spacing § | eB | _ | _ | .430 | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic. - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-070B ## 28-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-073 Rev C Sheet 1 of 2 ## 28-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **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 Pins | N | | 28 | | | | Pitch | е | | 0.65 BSC | | | | Overall Height | Α | ı | 1 | 2.00 | | | Molded Package Thickness | A2 | 1.65 | 1.75 | 1.85 | | | Standoff | A1 | 0.05 | - | - | | | Overall Width | Е | 7.40 | 7.80 | 8.20 | | | Molded Package Width | E1 | 5.00 | 5.30 | 5.60 | | | Overall Length | D | 9.90 | 10.20 | 10.50 | | | Foot Length | L | 0.55 | 0.75 | 0.95 | | | Footprint | L1 | 1.25 REF | | | | | Lead Thickness | С | 0.09 | - | 0.25 | | | Foot Angle | $\varphi$ | 0° | 4° | 8° | | | Lead Width | b | 0.22 | _ | 0.38 | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.20mm per side. - 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-073 Rev C Sheet 2 of 2 ## 28-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging #### RECOMMENDED LAND PATTERN | Units | | MILLIMETERS | | | |---------------------------------|----|-------------|------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | Е | 0.65 BSC | | | | Contact Pad Spacing | С | | 7.00 | | | Contact Pad Width (X28) | X1 | | | 0.45 | | Contact Pad Length (X28) | Y1 | | | 1.85 | | Contact Pad to Center Pad (X26) | G1 | 0.20 | | | #### Notes: - Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. - 2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during reflow process Microchip Technology Drawing C04-2073 Rev B ### 28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-052C Sheet 1 of 2 ### 28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **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 Pins | N | | 28 | | | Pitch | е | | 1.27 BSC | | | Overall Height | Α | - | - | 2.65 | | Molded Package Thickness | A2 | 2.05 | - | - | | Standoff § | A1 | 0.10 | - | 0.30 | | Overall Width | E | 10.30 BSC | | | | Molded Package Width | E1 | 7.50 BSC | | | | Overall Length | О | 17.90 BSC | | | | Chamfer (Optional) | h | 0.25 | - | 0.75 | | Foot Length | L | 0.40 | - | 1.27 | | Footprint | L1 | | 1.40 REF | | | Lead Angle | Θ | 0° | - | - | | Foot Angle | $\varphi$ | 0° | - | 8° | | Lead Thickness | С | 0.18 | - | 0.33 | | Lead Width | b | 0.31 | - | 0.51 | | Mold Draft Angle Top | α | 5° | - | 15° | | Mold Draft Angle Bottom | β | 5° | - | 15° | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic - Dimension D does not include mold flash, protrusions or gate burrs, which shall not exceed 0.15 mm per end. Dimension E1 does not include interlead flash or protrusion, which 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. 5. Datums A & B to be determined at Datum H. Microchip Technology Drawing C04-052C Sheet 2 of 2 ## 28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging ### **RECOMMENDED LAND PATTERN** | | Units | | MILLIMETERS | | | |--------------------------|-------|----------|-------------|------|--| | Dimension Limits | | MIN | NOM | MAX | | | Contact Pitch | Е | 1.27 BSC | | | | | Contact Pad Spacing | С | | 9.40 | | | | Contact Pad Width (X28) | Х | | | 0.60 | | | Contact Pad Length (X28) | Υ | | | 2.00 | | | Distance Between Pads | Gx | 0.67 | | | | | Distance Between Pads | G | 7.40 | | | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2052A # 28-Lead Plastic Quad Flat, No Lead Package (ML) - 6x6 mm Body [QFN] With 0.55 mm Terminal Length **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-105C Sheet 1 of 2 # 28-Lead Plastic Quad Flat, No Lead Package (ML) - 6x6 mm Body [QFN] With 0.55 mm Terminal Length **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 Pins | Ν | | 28 | | | Pitch | е | | 0.65 BSC | | | Overall Height | Α | 0.80 | 0.90 | 1.00 | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | Terminal Thickness | A3 | 0.20 REF | | | | Overall Width | Е | 6.00 BSC | | | | Exposed Pad Width | E2 | 3.65 | 3.70 | 4.20 | | Overall Length | D | | 6.00 BSC | | | Exposed Pad Length | D2 | 3.65 | 3.70 | 4.20 | | Terminal Width | b | 0.23 | 0.30 | 0.35 | | Terminal Length | L | 0.50 | 0.55 | 0.70 | | Terminal-to-Exposed Pad | K | 0.20 | - | - | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated - 3. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-105C Sheet 2 of 2 # 28-Lead Plastic Quad Flat, No Lead Package (ML) – 6x6 mm Body [QFN] with 0.55 mm Contact Length **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging **MILLIMETERS** Units **Dimension Limits** MIN MOM MAX Contact Pitch 0.65 BSC Ε W2 Optional Center Pad Width 4.25 Optional Center Pad Length T2 4.25 C1 Contact Pad Spacing 5.70 Contact Pad Spacing C2 5.70 0.37 Contact Pad Width (X28) X1 Contact Pad Length (X28) Y1 1.00 Distance Between Pads G 0.20 #### Notes: BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2105A <sup>1.</sup> Dimensioning and tolerancing per ASME Y14.5M ### 44-Lead Plastic Thin Quad Flatpack (PT) - 10x10x1.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-076C Sheet 1 of 2 ## 44-Lead Plastic Thin Quad Flatpack (PT) - 10x10x1.0 mm Body [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 | | 44 | | | Lead Pitch | е | | 0.80 BSC | | | Overall Height | Α | ı | - | 1.20 | | Standoff | A1 | 0.05 | - | 0.15 | | Molded Package Thickness | A2 | 0.95 | 1.00 | 1.05 | | Overall Width | E | 12.00 BSC | | | | Molded Package Width | E1 | 10.00 BSC | | | | Overall Length | D | | 12.00 BSC | | | Molded Package Length | D1 | | 10.00 BSC | | | Lead Width | b | 0.30 | 0.37 | 0.45 | | Lead Thickness | С | 0.09 | - | 0.20 | | Lead Length | Ĺ | 0.45 | 0.60 | 0.75 | | Footprint | L1 | 1.00 REF | | | | Foot Angle | θ | 0° | 3.5° | 7° | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Exact shape of each corner is optional. - 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-076C Sheet 2 of 2 ## 44-Lead Plastic Thin Quad Flatpack (PT) - 10X10X1 mm Body, 2.00 mm Footprint [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | Units | | MILLIMETERS | | | | |--------------------------|----|-------------|-------|------|--| | Dimension Limits | | MIN | NOM | MAX | | | Contact Pitch | Е | 0.80 BSC | | | | | Contact Pad Spacing | C1 | 11.40 | | | | | Contact Pad Spacing | C2 | | 11.40 | | | | Contact Pad Width (X44) | X1 | | | 0.55 | | | Contact Pad Length (X44) | Y1 | | | 1.50 | | | Distance Between Pads | G | 0.25 | | | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2076B ### 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN or VQFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-103D Sheet 1 of 2 ### 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN or VQFN] **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 Pins | N | | 44 | | | | Pitch | е | | 0.65 BSC | | | | Overall Height | Α | 0.80 | 0.90 | 1.00 | | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | | Terminal Thickness | A3 | 0.20 REF | | | | | Overall Width | Е | 8.00 BSC | | | | | Exposed Pad Width | E2 | 6.25 | 6.45 | 6.60 | | | Overall Length | D | | 8.00 BSC | | | | Exposed Pad Length | D2 | 6.25 | 6.45 | 6.60 | | | Terminal Width | b | 0.20 | 0.30 | 0.35 | | | Terminal Length | Ĺ | 0.30 | 0.40 | 0.50 | | | Terminal-to-Exposed-Pad | K | 0.20 | - | - | | ### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated - 3. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-103D Sheet 2 of 2 ## 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | Units | | MILLIMETERS | | | |----------------------------|------------|-------------|------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | E 0.65 BSC | | | | | Optional Center Pad Width | W2 | | | 6.60 | | Optional Center Pad Length | T2 | | | 6.60 | | Contact Pad Spacing | C1 | | 8.00 | | | Contact Pad Spacing | C2 | | 8.00 | | | Contact Pad Width (X44) | X1 | | | 0.35 | | Contact Pad Length (X44) | Y1 | | | 0.85 | | Distance Between Pads | G | 0.25 | | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2103B ## 48-Lead Plastic Ultra Thin Quad Flat, No Lead Package (MV) – 6x6x0.5 mm Body [UQFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-153A Sheet 1 of 2 ### 48-Lead Plastic Ultra Thin Quad Flat, No Lead Package (MV) - 6x6x0.5 mm Body [UQFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | MILLIMETERS | | | |------------------------|------------------|----------------|-------------|------|--| | Dimension | Dimension Limits | | NOM | MAX | | | Number of Pins | N | | 48 | | | | Pitch | е | | 0.40 BSC | | | | Overall Height | Α | 0.45 | 0.50 | 0.55 | | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | | Contact Thickness | A3 | 0.127 REF | | | | | Overall Width | Е | 6.00 BSC | | | | | Exposed Pad Width | E2 | 4.45 4.60 4.79 | | | | | Overall Length | D | | 6.00 BSC | | | | Exposed Pad Length | D2 | 4.45 | 4.60 | 4.75 | | | Contact Width | b | 0.15 | 0.20 | 0.25 | | | Contact Length | L | 0.30 0.40 0.50 | | | | | Contact-to-Exposed Pad | K | 0.20 | - | - | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated. - 3. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-153A Sheet 2 of 2 48-Lead Ultra Thin Plastic Quad Flat, No Lead Package (MV) - 6x6 mm Body [UQFN] With 0.40 mm Contact Length **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 | | Contact Pitch | Е | 0.40 BSC | | | | Optional Center Pad Width | W2 | | | 4.45 | | Optional Center Pad Length | T2 | | | 4.45 | | Contact Pad Spacing | C1 | | 6.00 | | | Contact Pad Spacing | C2 | | 6.00 | | | Contact Pad Width (X28) | X1 | | | 0.20 | | Contact Pad Length (X28) | Y1 | | | 0.80 | | 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-2153A NOTES: #### APPENDIX A: REVISION HISTORY #### **Revision A (February 2013)** Original data sheet for the PIC24FV16KM204 family of devices. ### Revision B (July 2013) Updates all references to PGCx and PGDx pin functions throughout the document to PGECx and PGEDx. Updates **Section 4.0 "Memory Organization"** to change bit 12 in the following registers to reserved ("r" designation): - CCP1CON1L (Table 4-8) - CCP2CON1L (Table 4-9) - CCP3CON1L (Table 4-10) - CCP4CON1L (Table 4-11) - CCP5CON1L (Table 4-12) Updates Section 13.0 "Capture/Compare/PWM/ Timer Modules (MCCP and SCCP)": - Replaces bit 12 of CCPxCON1L (CCPSLP) and its description with a reserved bit - Removes references to asynchronous operation in Sleep mode (and in other occurrences throughout the document) - Modifies Section 13.1 "Time Base Generator" to add synchronous operation limitations; adds Table 13-1 to list valid clock options for all operating modes - Removes the system clock as a time base input option - Removes external input sources, comparators and CTMU as synchronization sources in Table 13-6; clarifies that other selected sources must be synchronous Removes the input buffer from the band gap reference input in Figure 20-1. Adds BUFCON0 register description (Register 20-2) to Section 20.0 "8-Bit Digital-to-Analog Converter (DAC)". Changes references to internal band gap voltages (VBG, VBG/2 and BGBUF0) in Section 20.0 "8-Bit Digital-to-Analog Converter (DAC)" and Section 22.0 "Comparator Module" to BGBUF1. Adds minimum VDD conditions for VBG specification in Table 27-15 (Internal Voltage Regulator Specifications). Other minor typographical corrections throughout the document. #### Revision C (March 2020) Updates the device name in the 20-Pin PDIP/SSOP/SOIC pin diagram to PIC24FV08KM101. Removes all 20-Pin QFN information from the data sheet Adds AVDD and AVSS pin information to the 28-pin QFN pin diagram. Updates the note references in Table 4-25. Updates Table 8-2 with all new content. Updates Example 6-2. Changes all instances of POSCMD to POSCMOD. Adds a third note to **Section 9.4.2 "Oscillator Switching Sequence"**. Removes RTC content from the first paragraph in **Section 12.0 "Timer1"**. Updates Section 13.0 "Capture/Compare/PWM/ Timer Modules (MCCP and SCCP)": - Adds additional MCCP/SCCP FRM information to the first note. - Adds a note to Table 13-3. - Updates the CLKSEL bit in Register 13-1. - Updates multiple rows in Table 13-6. - Changes the OCAEN bit in Register 13-4 from R/W-0 to R/W-1. Adds additional MSSP FRM information to the first note in Section 14.0 "Master Synchronous Serial Port (MSSP)". Adds CLC FRM information to the beginning of Section 17.0 "Configurable Logic Cell (CLC)". Updates Register 17-4 with corrected inverted signal information. Updates Capture/Compare Event or Timer information for SSRC bit in Register 19-1. Corrects CHH, CSS and CTMEN bit locations in Register 19-6, Register 19-8 and Register 19-10. Updates Section 20.0 "8-Bit Digital-to-Analog Converter (DAC)": Removes the first note and removes the buffered output voltage bullet. Changes the CREF bit range from CREF[4-3] to CREF[5-4] and increases the unimplemented bit range to 3-2 in Register 22-1. Adds a note to Section Register 25-4: "FOSC: Oscillator Configuration Register". Updates the following tables in Section 27.0 "Electrical Characteristics": Table 27-2, Table 27-4, Table 27-15, Table 27-17, Table 27-22 and Table 27-39. Other minor typographical corrections throughout the document. NOTES: ## **INDEX** | A | | | MSSPx (I <sup>2</sup> C Mode) | 161 | |--------------------|-------------------------------------|-----|-------------------------------------------------------------------------------------|-----| | A/D | | | MSSPx (SPI Mode) | 160 | | | ormats | 225 | On-Chip Voltage Regulator Connections | | | | ters | | Output Compare x Module | | | • | TH/L | | PIC24F CPU Core | 34 | | | S | | PIC24FXXXXX Family (General) | 17 | | | V1 | | PSV Operation | 64 | | | V2 | | Recommended Minimum Connections | 27 | | | V2<br>V3 | | Reset System | 77 | | | V5 | | RTCC Module | 181 | | | 6H/L | | Series Resistor | 130 | | | /ENH/L | | Shared I/O Port Structure | 135 | | | quirements | | Simplified Single DACx Module | 229 | | | tion | | Single Operational Amplifier | 233 | | AC Characteristics | | 224 | SPI Master/Slave Connection | | | | | 204 | Suggested Oscillator Circuit Placement | 31 | | • | ecifications | | System Clock | | | | on Requirements | | Table Register Addressing | | | | specifications | 292 | Timer Clock Generator | | | | ading Requirements on | 077 | Watchdog Timer (WDT) | | | | Pins | | Brown-out Reset | | | | Requirements | | Trip Points | 267 | | | k Requirements | | • | | | | ccuracy | | C | | | | scillator Specifications | | Capture/Compare/PWM/Timer | | | | ons and Requirements | | Auxiliary Output | 148 | | | ecification | | General Purpose Timer | | | | dog Timer. Oscillator Start-up Time | er, | Input Capture Mode | | | | p Timer, Brown-out | | Output Compare Mode | 145 | | | equirements | | Synchronization Sources | | | I emperature | and Voltage Specifications | 277 | Time Base Generator | | | В | | | Capture/Compare/PWM/Timer (MCCP, SCCP) | 141 | | | | | Charge Time Measurement Unit. See CTMU. | | | Block Diagrams | | 040 | CLC | | | | nverter Madal | | Control Registers | 198 | | | nverter Analog Input Model | | Code Examples | | | | | | Assembly Code Sequence for Clock Switching | 126 | | | Mode | 144 | C Code Power-Saving Entry | | | | ogram Memory with | 00 | C Code Sequence for Clock Switching | | | | structions | | Data EEPROM Bulk Erase | | | | Frame | | Data EEPROM Unlock Sequence | | | | ource Selection | | Erasing a Program Memory Row, | | | • | unction Combinatorial Options | | Assembly Language | 68 | | | | | Erasing a Program Memory Row, C Language | | | | oltage Reference | | I/O Port Write/Read | | | • | Module | | Initiating a Programming Sequence, | 100 | | | ICCPx/SCCPx Modules | | Assembly Language | 70 | | | nmer's Model | 35 | Initiating a Programming Sequence, C Language . | | | | ctions, Internal Configuration for | | Loading the Write Buffers, Assembly Language | | | • | ince Measurement | 242 | Loading the Write Buffers, Assembly Language Loading the Write Buffers, C Language | | | | ctions, Internal Configuration for | | Reading Data EEPROM Using | 03 | | | elay Generation | 243 | TBLRD Command | 76 | | | ctions, Internal Configuration for | | Setting the RTCWREN Bit in 'C' | | | Time Me | asurement | 242 | | | | Data Access t | from Program Space | | Setting the RTCWREN Bit in Assembly | | | Address | Generation | 62 | Single-Word Erase | | | Data EEPROI | M Addressing with TBLPAG and | | Single-Word Write to Data EEPROM | | | NVM Re | gisters | 73 | Ultra Low-Power Wake-up Initialization | | | | mer Mode | | Code Protection | | | High/Low-Vol | tage Detect (HLVD) | 207 | Comparator Waltana Reference | | | | nparator Configurations | | Comparator Voltage Reference | | | | x Module | | Configurable Logic Coll (CLC) | | | | nnections Example | | Configurable Logic Cell (CLC) | | | | Aaster Mode) | | Configuration Bits | 249 | | CPU | | Equations | | | |----------------------------------------|-----|-----------------------------------------------------------------|-----|--| | ALU37 | | A/D Conversion Clock Period | | | | Control Registers | | Errata | | | | Core Registers | | Examples | | | | Programmer's Model33 | | Baud Rate Error Calculation (BRGH = 0) | 174 | | | CTMU | | | | | | Measuring Capacitance | 241 | F | | | | Measuring Time | 242 | Flash Program Memory | | | | Pulse Generation and Delay | | Control Registers | 66 | | | Customer Change Notification Service | 330 | Enhanced ICSP Operation | 66 | | | Customer Notification Service | | Programming Algorithm | 68 | | | Customer Support | 330 | Programming Operations | 66 | | | _ | | RTSP Operation | 66 | | | D | | Table Instructions | 65 | | | Data EEPROM Memory | 71 | C | | | | Erasing | 74 | G | | | | Operations | 73 | Getting Started Guidelines | 27 | | | Programming | | External Oscillator Pins | | | | Bulk Erase | 75 | ICSP Pins | | | | Reading Data EEPROM | 76 | Master Clear (MCLR) Pin | | | | Single-Word Write | 75 | Power Supply Pins | | | | Programming Control Registers | | Unused I/Os | | | | NVMADR(U) | 73 | Voltage Regulator Pin (VCAP) | 29 | | | NVMCON | 71 | н | | | | NVMKEY | 71 | | | | | Data Memory | | High/Low-Voltage Detect (HLVD) | 207 | | | Address Space | 41 | 1 | | | | Width | 41 | | | | | Near Data Space | 42 | I/O Ports | | | | Organization, Alignment | 42 | Analog Port Pins Configuration | | | | SFR Space | 42 | Analog Selection Registers | | | | Software Stack | 61 | Input Change Notification | | | | Data Space | | Open-Drain Configuration | | | | Memory Map | 41 | Parallel (PIO) | | | | DC Characteristics | | In-Circuit Debugger | | | | BOR Trip Points | 267 | In-Circuit Serial Programming (ICSP) | 259 | | | Comparator | 274 | Inter-Integrated Circuit. See I <sup>2</sup> C. | | | | CTMU Current Source | 275 | Internet Address | 330 | | | Data EEPROM Memory | 274 | Interrupts | | | | High/Low-Voltage Detect | 267 | Alternate Interrupt Vector Table (AIVT) | | | | I/O Pin Input Specifications | 272 | Control and Status Registers | | | | I/O Pin Output Specifications | 273 | Implemented Vectors | | | | Idle Current (IIDLE) | 269 | Interrupt Vector Table (IVT) | | | | Internal Voltage Regulator | 275 | Reset Sequence | | | | Operating Current (IDD) | 268 | Setup Procedures | | | | Operational Amplifier | 276 | Trap Vectors | | | | Power-Down Current (IPD) | 270 | Vector Table | 84 | | | Program Memory | 273 | M | | | | Temperature and Voltage Specifications | 266 | | 450 | | | Development Support | 261 | Master Synchronous Serial Port (MSSP) | | | | Device Features | | Microchip Internet Web Site | 330 | | | PIC24F16KM104 Family | 14 | N | | | | PIC24F16KM204 Family | 13 | Near Data Space | 11 | | | PIC24FV16KM104 Family | 16 | Near Data Space | 42 | | | PIC24FV16KM204 Family | 15 | 0 | | | | Device Overview | 11 | On-Chip Voltage Regulator | 257 | | | Core Features | 11 | Oscillator Configuration | 201 | | | Other Special Features | 12 | Clock Switching | 125 | | | Pinout Description | 18 | Sequence | | | | Dual Operational Amplifier | | | | | | _ | | Configuration Bit Values for Clock Selection Control Registers | | | | E | | | | | | Electrical Characteristics | | CPU Clocking Scheme | | | | Absolute Maximum Ratings | 263 | Initial Configuration on POR | | | | Thermal Operating Conditions | | Reference Clock Output | 120 | | | Thermal Packaging | 266 | | | | | P | | Registers | | |--------------------------------------------------------------|-----|-------------------------------------------------------------------------|-------| | Packaging | | AD1CHITH (A/D Scan Compare Hit, High Word) | | | Details | 297 | AD1CHITL (A/D Scan Compare Hit, Low Word) | | | Marking | 295 | AD1CHS (A/D Sample Select) | | | Power-Saving | 133 | AD1CON1 (A/D Control 1) | | | Power-Saving Features | | AD1CON2 (A/D Control 2) | | | Clock Frequency, Clock Switching | 129 | AD1CON3 (A/D Control 3) | | | Coincident Interrupts | 130 | AD1CON5 (A/D Control 5) | | | Instruction-Based Modes | 129 | AD1CSSH (A/D Input Scan Select, High Word) | | | Idle | 130 | AD1CSSL (A/D Input Scan Select, Low Word) | | | Sleep | 129 | AD1CTMENH (CTMU Enable, High Word)<br>AD1CTMENL (CTMU Enable, Low Word) | | | Retention Regulator (RETREG) | | ALCFGRPT (Alarm Configuration) | | | Selective Peripheral Control | | ALMINSEC (Alarm Minutes and Seconds Value) | | | Ultra Low-Power Wake-up (ULPWU) | | ALMTHDY (Alarm Month and Day Value) | | | Voltage Regulator-Based | | ALWDHR (Alarm Weekday and Hours Value) | | | Retention Sleep Mode | | AMPxCON (Op Amp x Control) | | | Run Mode | | ANSA (PORTA Analog Selection) | | | Sleep Mode | | ANSB (PORTB Analog Selection) | | | Product Identification System | 332 | ANSC (PORTC Analog Selection) | | | Program and Data Memory | 00 | BUFCON0 (Internal Voltage Reference | | | Access Using Table Instructions | | Control 0) | . 232 | | Program Space Visibility | 64 | CCPxCON1H (CCPx Control 1 High) | | | Program and Data Memory Spaces | 04 | CCPxCON1L (CCPx Control 1 Low) | | | Interfacing, Addressing | 01 | CCPxCON2H (CCPx Control 2 High) | | | Program Memory Address Space | 20 | CCPxCON2L (CCPx Control 2 Low) | | | | | CCPxCON3H (CCPx Control 3 High) | | | Configuration Word Addresses<br>Program Space | 40 | CCPxCON3L (CCPx Control 3 Low) | | | Memory Map | 30 | CCPxSTATL (CCPx Status) | . 157 | | Program Verification | | CLCxCONH (CLCx Control High) | . 199 | | 1 Togram Vermoation | 200 | CLCxCONL (CLCx Control Low) | . 198 | | R | | CLCxGLSH (CLCx Gate Logic Input | | | Real-Time Clock and Calendar (RTCC) | 181 | Select High) | | | Register Maps | | CLCxGLSL (CLCx Gate Logic Input Select Low) | | | A/D | 57 | CLCxSEL (CLCx Input MUX Select) | | | ANSEL | 58 | CLKDIV (Clock Divider) | | | Band Gap Buffer Control | 59 | CMSTAT (Comparator Status) | | | CLC1-2 | 46 | CMxCON (Comparator x Control) | | | Clock Control | 60 | CORCON (CPU Control) | | | Comparator | 59 | CTMUCON1H (CTMU Control 1 High) | | | CPU Core | | CTMUCON1L (CTMU Control 1 Low) | | | CTMU | | CTMUCON2L (CTMU Control 2 Low) | . 241 | | DAC1 | | CVRCON (Comparator Voltage Reference Control) | 240 | | DAC2 | | DACxCON (DACx Control) | | | ICN | | DEVID (Device ID) | | | Interrupt Controller | | DEVREV (Device Revision) | | | MCCP1 | | FBS (Boot Segment Configuration) | | | MCCP2 | | FGS (General Segment Configuration) | | | MCCP3 | | FICD (In-Circuit Debugger Configuration) | | | MSSP1 (I <sup>2</sup> C/SPI)<br>MSSP2 (I <sup>2</sup> C/SPI) | | FOSC (Oscillator Configuration) | . 251 | | , | | FOSCSEL (Oscillator Selection Configuration) | | | NVM<br>Op Amp 1 | | FPOR (Reset Configuration) | | | Op Amp 2 | | FWDT (Watchdog Timer Configuration) | | | Pad Configuration | | HLVDCON (High/Low-Voltage Detect Control) | | | PMD | | IEC0 (Interrupt Enable Control 0) | | | PORTA | | IEC1 (Interrupt Enable Control 1) | 97 | | PORTB | | IEC2 (Interrupt Enable Control 2) | | | PORTC | | IEC3 (Interrupt Enable Control 3) | 98 | | Real-Time Clock and Calendar | | IEC4 (Interrupt Enable Control 4) | 99 | | SCCP4 | | IEC5 (Interrupt Enable Control 5) | . 100 | | SCCP5 | | IEC6 (Interrupt Enable Control 6) | . 100 | | Timer1 | | IFS0 (Interrupt Flag Status 0) | | | UART1 | | IFS1 (Interrupt Flag Status 1) | | | UART2 | | IFS2 (Interrupt Flag Status 2) | | | Ultra Low-Power Wake-up | 60 | IFS3 (Interrupt Flag Status 3) | 93 | | IFS4 (Interrupt Flag Status 4) | 94 | RTCC | | |---------------------------------------------------|--------|------------------------------------------------------|-----| | IFS5 (Interrupt Flag Status 5) | | Alarm Configuration | 192 | | IFS6 (Interrupt Flag Status 6) | | Alarm Mask Settings (figure) | 193 | | INTCON1 (Interrupt Control 1) | | ALRMVAL Register Mappings | | | INTCON2 (Interrupt Control 2) | | Calibration | | | INTTREG (Interrupt Control and Status) | | Module Registers | | | IPC0 (Interrupt Priority Control 0) | | Mapping | | | IPC1 (Interrupt Priority Control 1) | | Clock Source Selection | | | IPC10 (Interrupt Priority Control 10) | | Write Lock | | | IPC12 (Interrupt Priority Control 12) | | Power Control | | | IPC15 (Interrupt Priority Control 15) | | RTCVAL Register Mappings | | | IPC16 (Interrupt Priority Control 16) | | Source Clock | | | IPC18 (Interrupt Priority Control 18) | | Cource Glock | 101 | | • • • • | | S | | | IPC19 (Interrupt Priority Control 19) | | Serial Peripheral Interface. See SPI Mode. | | | IPC2 (Interrupt Priority Control 2) | | SFR Space | 42 | | IPC20 (Interrupt Priority Control 20) | | Software Stack | | | IPC24 (Interrupt Priority Control 24) | | SPI Mode | 01 | | IPC3 (Interrupt Priority Control 3) | | | 450 | | IPC4 (Interrupt Priority Control 4) | | I/O Pin Configuration | 158 | | IPC5 (Interrupt Priority Control 5) | | Т | | | IPC6 (Interrupt Priority Control 6) | | Time and | 400 | | IPC7 (Interrupt Priority Control 7) | | Timer1 | 138 | | MINSEC (RTCC Minutes and Seconds Value) | | Timing Diagrams | 000 | | MTHDY (RTCC Month and Day Value) | 187 | A/D Conversion | | | NVMCON (Flash Memory Control) | 67 | Brown-out Reset Characteristics | | | NVMCON (Nonvolatile Memory Control) | 72 | Capture/Compare/PWM (MCCPx, SCCPx) | | | OSCCON (Oscillator Control) | 121 | CLKO and I/O Timing | | | OSCTUN (FRC Oscillator Tune) | 124 | Example SPI Master Mode (CKE = 0) | | | PADCFG1 (Pad Configuration Control) | 171 | Example SPI Master Mode (CKE = 1) | | | RCFGCAL (RTCC Calibration and | | Example SPI Slave Mode (CKE = 0) | | | Configuration) | 183 | Example SPI Slave Mode (CKE = 1) | 287 | | RCON (Reset Control) | | External Clock | | | REFOCON (Reference Oscillator Control) | | I <sup>2</sup> C Bus Data | 288 | | RTCCSWT (RTCC Control/Sample | | I <sup>2</sup> C Bus Start/Stop Bits | 288 | | Window Timer) | 191 | MSSPx I <sup>2</sup> C Bus Data | 291 | | RTCPWC (RTCC Configuration 2) | | MSSPx I <sup>2</sup> C Bus Start/Stop Bits | | | SR (ALU STATUS) | | Reset, Watchdog Timer. Oscillator Start-up Timer, | | | SSPxADD (MSSPx Slave Address/Baud Rate | 50, 07 | Power-up Timer Characteristics | | | Generator) | 170 | Timing Requirements | | | SSPxCON1 (MSSPx Control 1, I <sup>2</sup> C Mode) | | Capture/Compare/PWM (MCCPx, SCCPx) | 283 | | SSPxCON1 (MSSPx Control 1, SPI Mode) | | Comparator | | | SSPxCON1 (MSSPx Control 2, I <sup>2</sup> C Mode) | | Comparator Voltage Reference Settling Time | | | | | I <sup>2</sup> C Bus Data (Slave Mode) | | | SSPxCON3 (MSSPx Control 3, I <sup>2</sup> C Mode) | | I <sup>2</sup> C Bus Data Requirements (Master Mode) | | | SSPxCON3 (MSSPx Control 3, SPI Mode) | | I <sup>2</sup> C Bus Start/Stop Bits (Master Mode) | | | SSPxMSK (I <sup>2</sup> C Slave Address Mask) | | I <sup>2</sup> C Bus Start/Stop Bits (Slave Mode) | | | SSPxSTAT (MSSPx Status, I <sup>2</sup> C Mode) | | | | | SSPxSTAT (MSSPx Status, SPI Mode) | | SPI Mode (Master Mode, CKE = 0) | | | T1CON (Timer1 Control) | | SPI Mode (Master Mode, CKE = 1) | 285 | | ULPWCON (ULPWU Control) | | SPI Mode (Slave Mode, CKE = 0) | | | UxMODE (UARTx Mode) | 176 | SPI Slave Mode (CKE = 1) | 287 | | UxRXREG (UARTx Receive) | 180 | U | | | UxSTA (UARTx Status and Control) | 178 | | | | UxTXREG (UARTx Transmit) | 180 | UART | | | WKDYHR (RTCC Weekday and Hours Value) | 188 | Break and Sync Transmit Sequence | | | YEAR (RTCC Year Value) | | IrDA Support | | | Resets | | Operation of UxCTS and UxRTS Control Pins | | | Brown-out Reset (BOR) | 81 | Receiving in 8-Bit or 9-Bit Data Mode | | | Clock Source Selection | | Transmitting in 8-Bit Data Mode | | | Delay Times | | Transmitting in 9-Bit Data Mode | 175 | | Device Times | | Universal Asynchronous Receiver | | | Low-Power BOR (LPBOR) | | Transmitter (UART) | 173 | | RCON Flag Operation | | • | | | SFR States | | | | | Retention Regulator (RETREG) | | | | | | | | | | Revision History | ა∠ა | | | # V Voltage Regulator (VREG) 132 Voltage-Frequency Graph 265 (PIC24F16KM204 Extended) 265 Voltage-Frequency Graph 264 Voltage-Frequency Graph 265 (PIC24FV16KM204 Extended) 265 Voltage-Frequency Graph 265 (PIC24FV16KM204 Industrial) 264 ## W | Watchdog Timer (WDT) | 257 | |----------------------|-----| | Windowed Operation | | | WWW Address | 330 | | WWW, On-Line Support | 10 | NOTES: ## THE MICROCHIP WEBSITE Microchip provides online support via our WWW site at www.microchip.com. This website is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the website contains the following information: - Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software - General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing - Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives # CUSTOMER CHANGE NOTIFICATION SERVICE Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest. To register, access the Microchip website at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions. ## CUSTOMER SUPPORT Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - Field Application Engineer (FAE) - · Technical Support Customers should contact their distributor, representative or Field Application Engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document. Technical support is available through the website at: http://microchip.com/support NOTES: ## PRODUCT IDENTIFICATION SYSTEM To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office. Architecture 24 = 16-bit modified Harvard without DSP Flash Memory Family F = Standard voltage range Flash program memory FV = Wide voltage range Flash program memory Product Group KM2 = General Purpose PIC24F Lite Microcontroller KM1 = General Purpose PIC24F Lite Microcontroller with Reduced Feature Set = 20-pin Pin Count = -40°C to +85°C (Industrial) Temperature Range = -40°C to +125°C (Extended) Package = SPDIP = SOIC = SSOP ML = QFN P = PDIP PT = TQFP = UQFN Three-digit QTP, SQTP, Code or Special Requirements (blank otherwise) Pattern ES = Engineering Sample ## Examples: - PIC24FV16KM204-I/ML: Wide Voltage Range, General Purpose, 16-Kbyte Program Memory, 44-Pin, Industrial Temp., QFN Package - PIC24F08KM102-I/SS: Standard Voltage Range, General Purpose with Reduced Feature Set, 8-Kbyte Program Memory, 28-Pin, Industrial Temp., SSOP Package | NOTES: | | | | |--------|--|--|--| | | | | | ## Note the following details of the code protection feature on Microchip devices: - Microchip products meet the specification contained in their particular Microchip Data Sheet. - Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions. - There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property. - Microchip is willing to work with the customer who is concerned about the integrity of their code. - Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable." Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act. Information contained in this publication 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. 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 ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. 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, TempTrackr, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. 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, Vite, 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, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, INICnet, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, SAM-ICE, Serial Quad I/O, SMART-I.S., SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, 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. 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. © 2013-2020, Microchip Technology Incorporated, All Rights Reserved. ISBN: 978-1-5224-5856-2 For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality. ## **Worldwide Sales and Service** ## **AMERICAS** Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://www.microchip.com/ support Web Address: www.microchip.com **Atlanta** Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455 **Austin, TX** Tel: 512-257-3370 Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088 Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075 **Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924 **Detroit** Novi, MI Tel: 248-848-4000 Houston, TX Tel: 281-894-5983 Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453 Tel: 317-536-2380 Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Tel: 951-273-7800 **Raleigh, NC** Tel: 919-844-7510 New York, NY Tel: 631-435-6000 **San Jose, CA** Tel: 408-735-9110 Tel: 408-436-4270 **Canada - Toronto** Tel: 905-695-1980 Fax: 905-695-2078 ## ASIA/PACIFIC Australia - Sydney Tel: 61-2-9868-6733 China - Beijing Tel: 86-10-8569-7000 China - Chengdu Tel: 86-28-8665-5511 **China - Chongqing** Tel: 86-23-8980-9588 **China - Dongguan** Tel: 86-769-8702-9880 **China - Guangzhou** Tel: 86-20-8755-8029 China - Hangzhou Tel: 86-571-8792-8115 China - Hong Kong SAR Tel: 852-2943-5100 China - Nanjing Tel: 86-25-8473-2460 China - Qingdao Tel: 86-532-8502-7355 **China - Shanghai** Tel: 86-21-3326-8000 **China - Shenyang** Tel: 86-24-2334-2829 **China - Shenzhen** Tel: 86-755-8864-2200 China - Suzhou Tel: 86-186-6233-1526 China - Wuhan Tel: 86-27-5980-5300 China - Xian Tel: 86-29-8833-7252 **China - Xiamen** Tel: 86-592-2388138 **China - Zhuhai** Tel: 86-756-3210040 #### ASIA/PACIFIC India - Bangalore Tel: 91-80-3090-4444 India - New Delhi Tel: 91-11-4160-8631 **India - Pune** Tel: 91-20-4121-0141 Japan - Osaka Tel: 81-6-6152-7160 Japan - Tokyo Tel: 81-3-6880- 3770 Korea - Daegu Tel: 82-53-744-4301 Korea - Seoul Tel: 82-2-554-7200 Malaysia - Kuala Lumpur Tel: 60-3-7651-7906 Malaysia - Penang Tel: 60-4-227-8870 Philippines - Manila Tel: 63-2-634-9065 **Singapore** Tel: 65-6334-8870 **Taiwan - Hsin Chu** Tel: 886-3-577-8366 Taiwan - Kaohsiung Tel: 886-7-213-7830 **Taiwan - Taipei** Tel: 886-2-2508-8600 Thailand - Bangkok Tel: 66-2-694-1351 Vietnam - Ho Chi Minh Tel: 84-28-5448-2100 #### **EUROPE** **Austria - Wels** Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 Denmark - Copenhagen Tel: 45-4485-5910 Fax: 45-4485-2829 Finland - Espoo Tel: 358-9-4520-820 France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 Germany - Garching Tel: 49-8931-9700 **Germany - Haan** Tel: 49-2129-3766400 Germany - Heilbronn Tel: 49-7131-72400 **Germany - Karlsruhe** Tel: 49-721-625370 **Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44 Germany - Rosenheim Tel: 49-8031-354-560 Israel - Ra'anana Tel: 972-9-744-7705 Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781 Italy - Padova Tel: 39-049-7625286 **Netherlands - Drunen** Tel: 31-416-690399 Fax: 31-416-690340 Norway - Trondheim Tel: 47-7288-4388 Poland - Warsaw Tel: 48-22-3325737 Romania - Bucharest Tel: 40-21-407-87-50 **Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91 Sweden - Gothenberg Tel: 46-31-704-60-40 Sweden - Stockholm Tel: 46-8-5090-4654 **UK - Wokingham** Tel: 44-118-921-5800 Fax: 44-118-921-5820 | 1.0 | Device Overview | | |------------|-------------------------------------------------------------|-----| | 2.0 | Guidelines for Getting Started with 16-Bit Microcontrollers | | | 3.0 | CPU | | | 4.0 | Memory Organization | | | 5.0 | Flash Program Memory | | | 6.0<br>7.0 | Data EEPROM Memory | | | 7.0<br>3.0 | Resets Interrupt Controller | | | 9.0<br>9.0 | Oscillator Configuration | | | | Power-Saving Features | | | | I/O Ports | | | | Timer1 | | | | Capture/Compare/PWM/ | 100 | | | Timer Modules (MCCP and SCCP)141 | | | | Master Synchronous Serial Port (MSSP) | 159 | | | Universal Asynchronous Receiver Transmitter (UART) | | | | Real-Time Clock and Calendar (RTCC) | | | | Configurable Logic Cell (CLC) | | | | High/Low-Voltage Detect (HLVD) | | | 19.0 | 12-Bit A/D Converter with Threshold Detect | 209 | | | 8-Bit Digital-to-Analog Converter (DAC) | | | 21.0 | Dual Operational Amplifier Module | 233 | | 22.0 | Comparator Module | 235 | | 23.0 | Comparator Voltage Reference | 239 | | 24.0 | Charge Time Measurement Unit (CTMU) | 241 | | 25.0 | Special Features | 249 | | 26.0 | Development Support | 261 | | 27.0 | Electrical Characteristics | 263 | | | Packaging Information | | | | endix A: Revision History | | | | X | | | | Microchip Website | | | | omer Change Notification Service | | | | omer Support | | | ₽rod | uct Identification System | 333 |