Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | Details | | |----------------------------|-------------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 16-Bit | | Speed | 32MHz | | Connectivity | I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, HLVD, POR, PWM, WDT | | Number of I/O | 18 | | Program Memory Size | 8KB (2.75K x 24) | | Program Memory Type | FLASH | | EEPROM Size | 256 x 8 | | RAM Size | 1K x 8 | | Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V | | Data Converters | - | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-SSOP (0.209", 5.30mm Width) | | Supplier Device Package | 20-SSOP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic24f08kl301t-i-ss | #### TO OUR VALUED CUSTOMERS It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced. If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com**. We welcome your feedback. #### **Most Current Data Sheet** To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at: #### http://www.microchip.com You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000000A is version A of document DS30000000). #### **Errata** An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies. To determine if an errata sheet exists for a particular device, please check with one of the following: - Microchip's Worldwide Web site; http://www.microchip.com - · Your local Microchip sales office (see last page) When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using. #### **Customer Notification System** Register on our web site at www.microchip.com to receive the most current information on all of our products. #### 1.0 DEVICE OVERVIEW This document contains device-specific information for the following devices: - PIC24F04KL100 - PIC24F04KL101 - PIC24F08KL200 - PIC24F08KL201 - PIC24F08KL301 - PIC24F08KL302 - PIC24F08KL401 - PIC24F06KL302 PIC24F16KL401 - PIC24F08KL402 - PIC24F16KL402 The PIC24F16KL402 family adds an entire range of economical, low pin count and low-power devices to Microchip's portfolio of 16-bit microcontrollers. Aimed at applications that require low-power consumption but more computational ability than an 8-bit platform can provide, these devices offer a range of tailored peripheral sets that allow the designer to optimize both price point and features with no sacrifice of functionality. #### 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. 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 12 Mbytes (program space) and 64 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 PIC24F16KL402 family incorporate a range of features that can significantly reduce power consumption during operation. Key features include: On-the-Fly Clock Switching: The device clock can be changed under software control to the Timer1 source, or the internal, Low-Power RC (LPRC) oscillator during operation, allowing the user 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: The microcontroller can 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 PIC24F16KL402 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 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 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, or even jumping 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. 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 | #### TABLE 4-13: A/D 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 | |--------------|------|--------------|--------|--------|-----------------------|-----------------------|--------|--------|--------|---------|-------|-------|----------------------|----------------------|----------------------|--------|--------|---------------| | ADC1BUF0 | 0300 | | | | | | | | A/D Bu | uffer 0 | | | | | | | | xxxx | | ADC1BUF1 | 0302 | A/D Buffer 1 | | | | | | | | | | xxxx | | | | | | | | AD1CON1 | 0320 | ADON | _ | ADSIDL | _ | _ | ı | FORM1 | FORM0 | SSRC2 | SSRC1 | SSRC0 | _ | _ | ASAM | SAMP | DONE | 0000 | | AD1CON2 | 0322 | VCFG2 | VCFG1 | VCFG0 | OFFCAL | _ | CSCNA | I | ı | r | - | SMPI3 | SMPI2 | SMPI1 | SMPI0 | r | ALTS | 0000 | | AD1CON3 | 0324 | ADRC | EXTSAM | PUMPEN | SAMC4 | SAMC3 | SAMC2 | SAMC1 | SAMC0 | - | - | ADCS5 | ADCS4 | ADCS3 | ADCS2 | ADCS1 | ADCS0 | 0000 | | AD1CHS | 0328 | CH0NB | _ | _ | _ | CH0SB3 | CH0SB2 | CH0SB1 | CH0SB0 | CH0NA | - | _ | _ | CH0SA3 | CH0SA2 | CH0SA1 | CH0SA0 | 0000 | | AD1CSSL | 0330 | CSSL15 | CSSL14 | CSSL13 | CSSL12 <sup>(1)</sup> | CSSL11 <sup>(1)</sup> | CSSL10 | CSSL9 | CSSL8 | CSSL7 | CSSL6 | _ | CSSL4 <sup>(1)</sup> | CSSL3 <sup>(1)</sup> | CSSL2 <sup>(1)</sup> | CSSL1 | CSSL0 | 0000 | PIC24F16KL402 FAMILY **Legend:** — = unimplemented, read as '0', r = reserved bit. Reset values are shown in hexadecimal. Note 1: These bits are unimplemented in 14-pin devices; read as '0'. #### TABLE 4-14: ANALOG SELECT 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 | |-----------|------|--------|--------|--------|-----------------------|--------|--------|-------|-------|-------|-------|-------|-------|----------------------|----------------------|----------------------|----------------------|---------------| | ANCFG | 04DE | 1 | 1 | _ | _ | 1 | _ | - | _ | - | _ | _ | - | _ | - | _ | VBGEN | 0000 | | ANSA | 04E0 | _ | 1 | _ | _ | 1 | _ | _ | _ | _ | _ | _ | _ | ANSA3 | ANSA2 | ANSA1 | ANSA0 | 000F | | ANSB | 04E2 | ANSB15 | ANSB14 | ANSB13 | ANSB12 <sup>(1)</sup> | _ | _ | _ | _ | _ | _ | _ | ANSB4 | ANSB3 <sup>(2)</sup> | ANSB2 <sup>(1)</sup> | ANSB1 <sup>(1)</sup> | ANSB0 <sup>(1)</sup> | F01F(3) | **Legend:** — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: These bits are unimplemented in 14-pin devices; read as '0'. 2: These bits are unimplemented in 14-pin and 20-pin devices; read as '0' 3: Reset value for 28-pin devices is shown. #### TABLE 4-15: COMPARATOR 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 | |-----------------------|------|--------|--------|--------|--------|--------|--------|----------------------|-------|--------|--------|-------|-------|-------|-------|-------|-------|---------------| | CMSTAT | 0630 | CMIDL | 1 | _ | _ | _ | _ | C2EVT <sup>(1)</sup> | C1EVT | _ | _ | - | 1 | _ | _ | C2OUT | C1OUT | xxxx | | CVRCON | 0632 | - | - | _ | _ | _ | _ | _ | _ | CVREN | CVROE | CVRSS | CVR4 | CVR3 | CVR2 | CVR1 | CVR0 | 0000 | | CM1CON | 0634 | CON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPOL1 | EVPOL0 | _ | CREF | _ | _ | CCH1 | CCH0 | xxxx | | CM2CON <sup>(1)</sup> | 0636 | CON | COE | CPOL | CLPWR | _ | _ | CEVT | COUT | EVPOL1 | EVPOL0 | _ | CREF | _ | _ | CCH1 | CCH0 | 0000 | **Legend:** — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: These bits and/or registers are unimplemented in PIC24FXXKL10X/20X devices; read as '0'. #### REGISTER 8-12: IEC1: INTERRUPT ENABLE CONTROL REGISTER 1 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | U-0 | R/W-0 | U-0 | |-----------------------|-----------------------|--------|-----|---------------------|-----|-----------------------|-------| | U2TXIE <sup>(1)</sup> | U2RXIE <sup>(1)</sup> | INT2IE | _ | T4IE <sup>(1)</sup> | _ | CCP3IE <sup>(1)</sup> | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|--------|-------|-------|--------|--------| | _ | _ | _ | INT1IE | CNIE | CMIE | BCL1IE | SSP1IE | | 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 **U2TXIE:** UART2 Transmitter Interrupt Enable bit<sup>(1)</sup> 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 14 **U2RXIE:** UART2 Receiver Interrupt Enable bit<sup>(1)</sup> 1 = Interrupt request is enabled0 = 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 **Unimplemented:** Read as '0' bit 11 **T4IE:** Timer4 Interrupt Enable bit<sup>(1)</sup> 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 10 **Unimplemented:** Read as '0' bit 9 **CCP3IE**: Capture/Compare/PWM3 Interrupt Enable bit<sup>(1)</sup> 1 = Interrupt request is enabled 0 = Interrupt request is not enabled bit 8-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 Note 1: These bits are unimplemented on PIC24FXXKL10X and PIC24FXXKL20X devices. #### 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 | d 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 bit 14-12 DOZE<2:0>: CPU-to-Peripheral Clock Ratio Select bits 111 = 1:128 110 = 1:64 101 = 1:32 100 = 1:16 011 = 1:8 010 = 1:4 001 = 1:2 000 = 1:1 bit 11 **DOZEN:** DOZE Enable bit<sup>(1)</sup> 1 = DOZE<2:0> bits specify the CPU-to-peripheral clock ratio 0 = CPU and the 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 or 001: 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. #### 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 any active module has selected the LPRC as its source, including the WDT, Timer1 and Timer3. - 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 (ICN) 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. #### 10.2.2 IDLE MODE Idle mode has 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.5 "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 re-applied to the CPU. 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. #### 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 | _ | _ | _ | T1ECS1 <sup>(1)</sup> | T1ECS0 <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 T1ECS <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 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 T1ECS<1:0> 0 = Internal clock (Fosc/2) bit 0 **Unimplemented:** Read as '0' **Note 1:** The T1ECSx bits are valid only when TCS = 1. #### REGISTER 16-1: CCPxCON: CCPx CONTROL REGISTER (STANDARD CCP MODULES) | 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 | |-------|-----|-------|-------|-----------------------|-----------------------|-----------------------|-----------------------| | _ | _ | DCxB1 | DCxB0 | CCPxM3 <sup>(1)</sup> | CCPxM2 <sup>(1)</sup> | CCPxM1 <sup>(1)</sup> | CCPxM0 <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-4 DCxB<1:0>: PWM Duty Cycle Bit 1 and Bit 0 for CCPx Module bits Capture and Compare modes: Unused. PWM mode: These bits are the two Least Significant bits (bit 1 and bit 0) of the 10-bit PWM duty cycle. The eight Most Significant bits (DCxB<9:2>) of the duty cycle are found in CCPRxL. bit 3-0 CCPxM<3:0>: CCPx Module Mode Select bits<sup>(1)</sup> 1111 = Reserved 1110 = Reserved 1101 = Reserved 1100 = PWM mode 1011 = Compare mode: Special Event Trigger; resets timer on CCPx match (CCPxIF bit is set) 1010 = Compare mode: Generates software interrupt on compare match (CCPxIF bit is set, CCPx pin reflects I/O state) 1001 = Compare mode: Initializes CCPx pin high; on compare match, forces CCPx pin low (CCPxIF bit is set) 1000 = Compare mode: Initializes CCPx pin low; on compare match, forces CCPx pin high (CCPxIF bit is set) 0111 = Capture mode: Every 16th rising edge 0110 = Capture mode: Every 4th rising edge 0101 = Capture mode: Every rising edge 0100 = Capture mode: Every falling edge 0011 = Reserved 0010 = Compare mode: Toggles output on match (CCPxIF bit is set) 0001 = Reserved 0000 = Capture/Compare/PWM is disabled (resets CCPx module) Note 1: CCPxM<3:0> = 1011 will only reset the timer and not start the A/D conversion on a CCPx match. ## REGISTER 17-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. #### 18.1 UART Baud Rate Generator (BRG) The UART module includes a dedicated 16-bit Baud Rate Generator (BRG). The UxBRG register controls the period of a free-running, 16-bit timer. Equation 18-1 provides the formula for computation of the baud rate with BRGH = 0. # EQUATION 18-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 18-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 18-2 shows the formula for computation of the baud rate with BRGH = 1. # EQUATION 18-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 18-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) - 1 UxBRG = ((4000000/9600)/16) - 1 UxBRG = 25 Calculated Baud Rate = 4000000/(16(25+1)) = 9615 Error = (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. #### REGISTER 18-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 bits0 = One Stop bit **Note 1:** This feature is is only available for the 16x BRG mode (BRGH = 0). 2: Bit availability depends on pin availability. # 22.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 the "dsPIC33/PIC24 Family Reference Manual", "High-Level Integration with Programmable High/Low-Voltage Detect (HLVD)" (DS39725). 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 22-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 22-1: HIGH/LOW-VOLTAGE DETECT (HLVD) MODULE BLOCK DIAGRAM #### REGISTER 23-7: FICD: IN-CIRCUIT DEBUGGER CONFIGURATION REGISTER | R/P-1 | U-1 | U-1 | U-0 | U-0 | U-0 | R/P-1 | R/P-1 | |-------------|-----|-----|-----|-----|-----|-------|-------| | DEBUG | _ | _ | _ | _ | _ | ICS1 | ICS0 | | 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-5 **Unimplemented:** Read as '1' bit 4-2 **Unimplemented:** Read as '0' bit 1-0 ICS<1:0:> ICD Pin Select bits 11 = PGEC1/PGED1 are used for programming and debugging the device<sup>(1)</sup> 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 Note 1: PGEC1/PGED1 are not available on PIC24F04KL100 (14-pin) devices. #### 24.2 MPLAB XC Compilers The MPLAB XC Compilers are complete ANSI C compilers for all of Microchip's 8, 16 and 32-bit MCU and DSC devices. These compilers provide powerful integration capabilities, superior code optimization and ease of use. MPLAB XC Compilers run on Windows, Linux or MAC OS X. For easy source level debugging, the compilers provide debug information that is optimized to the MPLAB X IDE. The free MPLAB XC Compiler editions support all devices and commands, with no time or memory restrictions, and offer sufficient code optimization for most applications. MPLAB XC Compilers include an assembler, linker and utilities. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. MPLAB XC Compiler uses the assembler to produce its object file. Notable features of the assembler include: - · Support for the entire device instruction set - · Support for fixed-point and floating-point data - · Command-line interface - · Rich directive set - · Flexible macro language - · MPLAB X IDE compatibility #### 24.3 MPASM Assembler The MPASM Assembler is a full-featured, universal macro assembler for PIC10/12/16/18 MCUs. The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel® standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code, and COFF files for debugging. The MPASM Assembler features include: - Integration into MPLAB X IDE projects - User-defined macros to streamline assembly code - Conditional assembly for multipurpose source files - Directives that allow complete control over the assembly process #### 24.4 MPLINK Object Linker/ MPLIB Object Librarian The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler. It can link relocatable objects from precompiled libraries, using directives from a linker script. The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications. The object linker/library features include: - Efficient linking of single libraries instead of many smaller files - Enhanced code maintainability by grouping related modules together - Flexible creation of libraries with easy module listing, replacement, deletion and extraction # 24.5 MPLAB Assembler, Linker and Librarian for Various Device Families MPLAB Assembler produces relocatable machine code from symbolic assembly language for PIC24, PIC32 and dsPIC DSC devices. MPLAB XC Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include: - · Support for the entire device instruction set - · Support for fixed-point and floating-point data - · Command-line interface - · Rich directive set - · Flexible macro language - · MPLAB X IDE compatibility #### 24.6 MPLAB X SIM Software Simulator The MPLAB X SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers. The MPLAB X SIM Software Simulator fully supports symbolic debugging using the MPLAB XC Compilers, and the MPASM and MPLAB Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool. #### 24.7 MPLAB REAL ICE In-Circuit Emulator System The MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs all 8, 16 and 32-bit MCU, and DSC devices with the easy-to-use, powerful graphical user interface of the MPLAB X IDE. The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with in-circuit debugger systems (RJ-11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5). The emulator is field upgradable through future firmware downloads in MPLAB X IDE. MPLAB REAL ICE offers significant advantages over competitive emulators including full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, logic probes, a ruggedized probe interface and long (up to three meters) interconnection cables. # 24.8 MPLAB ICD 3 In-Circuit Debugger System The MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost-effective, high-speed hardware debugger/programmer for Microchip Flash DSC and MCU devices. It debugs and programs PIC Flash microcontrollers and dsPIC DSCs with the powerful, yet easy-to-use graphical user interface of the MPLAB IDE. The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers. #### 24.9 PICkit 3 In-Circuit Debugger/ Programmer The MPLAB PICkit 3 allows debugging and programming of PIC and dsPIC Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB IDE. The MPLAB PICkit 3 is connected to the design engineer's PC using a full-speed USB interface and can be connected to the target via a Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the Reset line to implement in-circuit debugging and In-Circuit Serial Programming™ (ICSP™). #### 24.10 MPLAB PM3 Device Programmer The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features a large LCD display (128 x 64) for menus and error messages, and a modular, detachable socket assembly to support various package types. The ICSP cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in this mode. The MPLAB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized algorithms for quick programming of large memory devices, and incorporates an MMC card for file storage and data applications. #### 24.11 Demonstration/Development Boards, Evaluation Kits and Starter Kits A wide variety of demonstration, development and evaluation boards for various PIC MCUs and dsPIC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification. The boards support a variety of features, including LEDs, temperature sensors, switches, speakers, RS-232 interfaces, LCD displays, potentiometers and additional EEPROM memory. The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications. In addition to the PICDEM™ and dsPICDEM™ demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for analog filter design, KEELoQ® security ICs, CAN, IrDA®, PowerSmart battery management, SEEVAL® evaluation system, Sigma-Delta ADC, flow rate sensing, plus many more. Also available are starter kits that contain everything needed to experience the specified device. This usually includes a single application and debug capability, all on one board. Check the Microchip web page (www.microchip.com) for the complete list of demonstration, development and evaluation kits. #### 24.12 Third-Party Development Tools Microchip also offers a great collection of tools from third-party vendors. These tools are carefully selected to offer good value and unique functionality. - Device Programmers and Gang Programmers from companies, such as SoftLog and CCS - Software Tools from companies, such as Gimpel and Trace Systems - Protocol Analyzers from companies, such as Saleae and Total Phase - Demonstration Boards from companies, such as MikroElektronika, Digilent<sup>®</sup> and Olimex - Embedded Ethernet Solutions from companies, such as EZ Web Lynx, WIZnet and IPLogika<sup>®</sup> ### TABLE 25-2: INSTRUCTION SET OVERVIEW (CONTINUED) | Assembly<br>Mnemonic | | Assembly Syntax | Description | # of<br>Words | # of<br>Cycles | Status Flags<br>Affected | |----------------------|--------|------------------|----------------------------------------------|---------------|----------------|--------------------------| | GOTO | GOTO | Expr | Go to Address | 2 | 2 | None | | | GOTO | Wn | Go to Indirect | 1 | 2 | None | | INC | INC | f | f = f + 1 | 1 | 1 | C, DC, N, OV, Z | | | INC | f,WREG | WREG = f + 1 | 1 | 1 | C, DC, N, OV, Z | | | INC | Ws,Wd | Wd = Ws + 1 | 1 | 1 | C, DC, N, OV, Z | | INC2 | INC2 | f | f = f + 2 | 1 | 1 | C, DC, N, OV, Z | | | INC2 | f,WREG | WREG = f + 2 | 1 | 1 | C, DC, N, OV, Z | | | INC2 | Ws,Wd | Wd = Ws + 2 | 1 | 1 | C, DC, N, OV, Z | | IOR | IOR | f | f = f .IOR. WREG | 1 | 1 | N, Z | | | IOR | f,WREG | WREG = f.IOR. WREG | 1 | 1 | N, Z | | | IOR | #lit10,Wn | Wd = lit10 .IOR. Wd | 1 | 1 | N, Z | | | IOR | Wb,Ws,Wd | Wd = Wb .IOR. Ws | 1 | 1 | N, Z | | | IOR | Wb,#lit5,Wd | Wd = Wb .IOR. lit5 | 1 | 1 | N, Z | | LNK | LNK | #lit14 | Link Frame Pointer | 1 | 1 | None | | LSR | LSR | f | f = Logical Right Shift f | 1 | 1 | C, N, OV, Z | | | LSR | f,WREG | WREG = Logical Right Shift f | 1 | 1 | C, N, OV, Z | | | LSR | Ws,Wd | Wd = Logical Right Shift Ws | 1 | 1 | C, N, OV, Z | | | LSR | Wb, Wns, Wnd | Wnd = Logical Right Shift Wb by Wns | 1 | 1 | N, Z | | | LSR | Wb,#lit5,Wnd | Wnd = Logical Right Shift Wb by lit5 | 1 | 1 | N, Z | | MOV | MOV | f,Wn | Move f to Wn | 1 | 1 | None | | | MOV | [Wns+Slit10],Wnd | Move [Wns+Slit10] to Wnd | 1 | 1 | None | | | MOV | f | Move f to f | 1 | 1 | N, Z | | | MOV | f,WREG | Move f to WREG | 1 | 1 | None | | | MOV | #lit16,Wn | Move 16-bit Literal to Wn | 1 | 1 | None | | | MOV.b | #lit8,Wn | Move 8-bit Literal to Wn | 1 | 1 | None | | | MOV | Wn,f | Move Wn to f | 1 | 1 | None | | | MOV | Wns,[Wns+Slit10] | Move Wns to [Wns+Slit10] | 1 | 1 | None | | | MOV | Wso, Wdo | Move Ws to Wd | 1 | 1 | None | | | MOV | WREG, f | Move WREG to f | 1 | 1 | None | | | MOV.D | Wns, Wd | Move Double from W(ns):W(ns+1) to Wd | 1 | 2 | None | | | MOV.D | Ws, Wnd | Move Double from Ws to W(nd+1):W(nd) | 1 | 2 | None | | MUL | MUL.SS | Wb, Ws, Wnd | {Wnd+1, Wnd} = Signed(Wb) * Signed(Ws) | 1 | 1 | None | | | MUL.SU | Wb, Ws, Wnd | {Wnd+1, Wnd} = Signed(Wb) * Unsigned(Ws) | 1 | 1 | None | | | MUL.US | Wb, Ws, Wnd | {Wnd+1, Wnd} = Unsigned(Wb) * Signed(Ws) | 1 | 1 | None | | | MUL.UU | Wb, Ws, Wnd | {Wnd+1, Wnd} = Unsigned(Wb) * Unsigned(Ws) | 1 | 1 | None | | | MUL.SU | Wb,#lit5,Wnd | {Wnd+1, Wnd} = Signed(Wb) * Unsigned(lit5) | 1 | 1 | None | | | MUL.UU | Wb,#lit5,Wnd | {Wnd+1, Wnd} = Unsigned(Wb) * Unsigned(lit5) | 1 | 1 | None | | | MUL | f | W3:W2 = f * WREG | 1 | 1 | None | | NEG | NEG | £ | $f = \overline{f} + 1$ | 1 | 1 | C, DC, N, OV, Z | | 1120 | NEG | f,WREG | WREG = <del>1</del> + 1 | 1 | 1 | C, DC, N, OV, Z | | | | | | | | | | 110 D | NEG | Ws,Wd | Wd = Ws + 1 | 1 | 1 | C, DC, N, OV, Z | | NOP | NOP | | No Operation | 1 | 1 | None | | DOD | NOPR | r. | No Operation | 1 | 1 | None | | POP | POP | f | Pop f from Top-of-Stack (TOS) | 1 | 1 | None | | | POP | Wdo | Pop from Top-of-Stack (TOS) to Wdo | 1 | 1 | None | | | POP.D | Wnd | Pop from Top-of-Stack (TOS) to W(nd):W(nd+1) | 1 | 2 | None | | | POP.S | | Pop Shadow Registers | 1 | 1 | All | | PUSH | PUSH | f | Push f to Top-of-Stack (TOS) | 1 | 1 | None | | | PUSH | Wso | Push Wso to Top-of-Stack (TOS) | 1 | 1 | None | | | PUSH.D | Wns | Push W(ns):W(ns+1) to Top-of-Stack (TOS) | 1 | 2 | None | | | PUSH.S | | Push Shadow Registers | 1 | 1 | None | #### 27.2 Package Details The following sections give the technical details of the packages. #### 14-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 | | | |----------------------------|-----------|------|----------|------|--| | Dimensi | on Limits | MIN | NOM | MAX | | | Number of Pins | N | 14 | | | | | 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 | Е | .290 | .310 | .325 | | | Molded Package Width | E1 | .240 | .250 | .280 | | | Overall Length | D | .735 | .750 | .775 | | | 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 with 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-005B | DC Characteristics | | Inter-Integrated Circuit. See I <sup>2</sup> C. | | |--------------------------------------------|----------|-------------------------------------------------|-----| | BOR Trip Points | 202 | Internet Address | 257 | | Comparator | 208 | Interrupt Sources | | | Comparator Voltage Reference | 208 | TMR3 Overflow | 119 | | Data EEPROM Memory | 208 | TMR4 to PR4 Match (PWM) | 123 | | High/Low-Voltage Detect | 202 | Interrupts | | | I/O Pin Input Specifications | 206 | Alternate Interrupt Vector Table (AIVT) | 65 | | I/O Pin Output Specifications | 207 | Control and Status Registers | 68 | | Idle Current (IDLE) | 203 | Implemented Vectors | 67 | | Operating Current (IDD) | | Interrupt Vector Table (IVT) | 65 | | Power-Down Current (IPD) | 204, 205 | Reset Sequence | 65 | | Program Memory | 207 | Setup Procedures | | | Temperature and Voltage Specifications | | Trap Vectors | | | Demo/Development Boards, Evaluation and | | Vector Table | 66 | | Starter Kits | 190 | | | | Development Support | | M | | | Third-Party Tools | | Master Synchronous Serial Port (MSSP) | 135 | | Device Features for PIC24F16KL20X/10X | | I/O Pin Configuration for SPI | 135 | | Devices (Summary) | 12 | Microchip Internet Web Site | | | Device Features for PIC24F16KL40X/30X | | MPLAB Assembler, Linker, Librarian | | | Devices (Summary) | 11 | MPLAB ICD 3 In-Circuit Debugger | | | Devices (Gariniary) | | MPLAB PM3 Device Programmer | | | E | | MPLAB REAL ICE In-Circuit Emulator System | | | Electrical Characteristics | | MPLAB X Integrated Development | | | Absolute Maximum Ratings | 199 | Environment Software | 187 | | Thermal Operating Conditions | | MPLAB X SIM Software Simulator | | | Thermal Packaging Characteristics | | MPLIB Object Librarian | | | V/F Graph, Extended | | MPLINK Object Linker | | | V/F Graph, Industrial | | WI LINK Object Linker | 100 | | Enhanced CCP | | N | | | Equations | 125 | Near Data Space | 34 | | A/D Conversion Clock Period | 164 | Near Bata Opace | | | UARTx Baud Rate with BRGH = 0 | | 0 | | | UARTX Baud Rate with BRGH = 0 | | Oscillator Configuration | | | | | Clock Switching | 101 | | Errata | / | Sequence | | | Examples | 450 | Configuration Bit Values for Clock Selection | | | Baud Rate Error Calculation (BRGH = 0) | 150 | CPU Clocking Scheme | | | F | | Initial Configuration on POR | | | Floob December Manager | | Reference Clock Output | | | Flash Program Memory | 40 | Oscillator, Timer3 | | | Control Registers | | Oscillator, Timers | 118 | | Enhanced ICSP Operation | | Р | | | Programming Algorithm | | Packaging | | | Programming Operations | | Details | 229 | | RTSP Operation | | Marking | | | Table Instructions | 47 | | | | G | | PICkit 3 In-Circuit Debugger/Programmer | 109 | | | 0.4 | Pinout Descriptions | 4.0 | | Getting Started Guidelines for 16-Bit MCUs | 21 | PIC24F16KL20X/10X Devices | | | Н | | PIC24F16KL40X/30X Devices | | | | | Power-Saving | | | High/Low-Voltage Detect (HLVD) | 1/3 | Power-Saving Features | | | 1 | | Clock Frequency, Clock Switching | | | 10.5 | | Coincident Interrupts | | | I/O Ports | | Instruction-Based Modes | | | Analog Port Configuration | | Idle | | | Analog Selection Registers | | Sleep | | | Input Change Notification | | Selective Peripheral Control | | | Open-Drain Configuration | | Ultra Low-Power Wake-up (ULPWU) | | | Parallel (PIO) | | Product Identification System | 259 | | In-Circuit Debugger | | Program and Data Memory | | | In-Circuit Serial Programming (ICSP) | 185 | Access Using Table Instructions | 45 | | Instruction Set | | Program Space Visibility | | | Opcode Symbols | 192 | Program and Data Memory Spaces | | | Overview | | Addressing | 43 | | Summary | | Interfacing | | | | | <u>~</u> | |