Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs. With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas. We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry! # Contact us Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China # 16-bit Microcontrollers (up to 256 KB Flash and 16 KB SRAM) with Advanced Analog ## **Operating Conditions** - 3.0V to 3.6V, -40°C to +150°C, DC to 20 MIPS - 3.0V to 3.6V, -40°C to +125°C, DC to 40 MIPS #### Core: 16-bit PIC24H CPU - · Code-efficient (C and Assembly) architecture - · Single-cycle mixed-sign MUL plus hardware divide ## **Clock Management** - · ±2% internal oscillator - · Programmable PLLs and oscillator clock sources - Fail-Safe Clock Monitor (FSCM) - Independent Watchdog Timer (WDT) - · Fast wake-up and start-up ## **Power Management** - Low-power management modes (Sleep, Idle, Doze) - · Integrated Power-on Reset and Brown-out Reset - 1.35 mA/MHz dynamic current (typical) - 55 μA IPD current (typical) #### **Advanced Analog Features** - · Two ADC modules: - Configurable as 10-bit, 1.1 Msps with four S&H or 12-bit, 500 ksps with one S&H - 18 analog inputs on 64-pin devices and up to 32 analog inputs on 100-pin devices - Flexible and independent ADC trigger sources ## **Timers/Output Compare/Input Capture** - Up to nine 16-bit timers/counters. Can pair up to make four 32-bit timers. - Eight Output Compare modules configurable as timers/counters - · Eight Input Capture modules #### **Communication Interfaces** - Two UART modules (10 Mbps) - With support for LIN 2.0 protocols and IrDA<sup>®</sup> - Two 4-wire SPI modules (15 Mbps) - Up to two I<sup>2</sup>C<sup>™</sup> modules (up to 1 Mbaud) with SMBus support - Up to two Enhanced CAN (ECAN) modules (1 Mbaud) with 2.0B support - Data Converter Interface (DCI) module with I<sup>2</sup>S codec support ## Input/Output - Sink/Source up to 10 mA (pin specific) for standard VOH/VOL, up to 16 mA (pin specific) for nonstandard VOH1 - · 5V-tolerant pins - · Selectable open drain, pull-ups, and pull-downs - · Up to 5 mA overvoltage clamp current - · External interrupts on all I/O pins ## **Qualification and Class B Support** - AEC-Q100 REVG (Grade 1 -40°C to +125°C) - AEC-Q100 REVG (Grade 0 -40°C to +150°C) - · Class B Safety Library, IEC 60730 #### **Debugger Development Support** - · In-circuit and in-application programming - Two program and two complex data breakpoints - IEEE 1149.2-compatible (JTAG) boundary scan - · Trace and run-time watch #### **Packages** | Туре | QFN | TQFP | TQFP | TQFP | |--------------------|---------|---------|---------|---------| | Pin Count | 64 | 64 | 100 | 100 | | Contact Lead/Pitch | 0.50 | 0.50 | 0.50 | 0.40 | | I/O Pins | 53 | 53 | 85 | 85 | | Dimensions | 9x9x0.9 | 10x10x1 | 12x12x1 | 14x14x1 | Note: All dimensions are in millimeters (mm) unless specified. ## **PIC24H PRODUCT FAMILIES** The PIC24H Family of devices is ideal for a wide variety of 16-bit MCU embedded applications. The device names, pin counts, memory sizes and peripheral availability of each device are listed below, followed by their pinout diagrams. ## **PIC24H Family Controllers** | Device | Pins | Program<br>Flash<br>Memory (KB) | RAM <sup>(1)</sup> (KB) | DMA Channels | Timer 16-bit | Input Capture | Output Compare<br>Std. PWM | Codec<br>Interface | ADC | UART | SPI | I <sup>2</sup> Стм | CAN | I/O Pins (Max) <sup>(2)</sup> | Packages | |------------------|------|---------------------------------|-------------------------|--------------|--------------|---------------|----------------------------|--------------------|-----------------|------|-----|--------------------|-----|-------------------------------|----------| | PIC24HJ64GP206A | 64 | 64 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>18 ch | 2 | 2 | 1 | 0 | 53 | PT, MR | | PIC24HJ64GP210A | 100 | 64 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>32 ch | 2 | 2 | 2 | 0 | 85 | PF, PT | | PIC24HJ64GP506A | 64 | 64 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>18 ch | 2 | 2 | 2 | 1 | 53 | PT, MR | | PIC24HJ64GP510A | 100 | 64 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>32 ch | 2 | 2 | 2 | 1 | 85 | PF, PT | | PIC24HJ128GP206A | 64 | 128 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>18 ch | 2 | 2 | 2 | 0 | 53 | PT, MR | | PIC24HJ128GP210A | 100 | 128 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>32 ch | 2 | 2 | 2 | 0 | 85 | PF, PT | | PIC24HJ128GP506A | 64 | 128 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>18 ch | 2 | 2 | 2 | 1 | 53 | PT, MR | | PIC24HJ128GP510A | 100 | 128 | 8 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>32 ch | 2 | 2 | 2 | 1 | 85 | PF, PT | | PIC24HJ128GP306A | 64 | 128 | 16 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>18 ch | 2 | 2 | 2 | 0 | 53 | PT, MR | | PIC24HJ128GP310A | 100 | 128 | 16 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>32 ch | 2 | 2 | 2 | 0 | 85 | PF, PT | | PIC24HJ256GP206A | 64 | 256 | 16 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>18 ch | 2 | 2 | 2 | 0 | 53 | PT, MR | | PIC24HJ256GP210A | 100 | 256 | 16 | 8 | 9 | 8 | 8 | 0 | 1 ADC,<br>32 ch | 2 | 2 | 2 | 0 | 85 | PF, PT | | PIC24HJ256GP610A | 100 | 256 | 16 | 8 | 9 | 8 | 8 | 0 | 2 ADC,<br>32 ch | 2 | 2 | 2 | 2 | 85 | PF, PT | Note 1: RAM size is inclusive of 2 Kbytes DMA RAM. 2: Maximum I/O pin count includes pins shared by the peripheral functions. ## **Pin Diagrams** ## **Table of Contents** | PIC24H Product Families | | | | | | | |--------------------------------------------------------------------------------------------------|-------|--|--|--|--|--| | 1.0 Device Overview | | | | | | | | 2.0 Guidelines for Getting Started with 16-Bit Microcontrollers | 19 | | | | | | | 3.0 CPU | 23 | | | | | | | 4.0 Memory Organization | 29 | | | | | | | 5.0 Flash Program Memory | 59 | | | | | | | 6.0 Reset | 65 | | | | | | | 7.0 Interrupt Controller | | | | | | | | 8.0 Direct Memory Access (DMA) | . 113 | | | | | | | 9.0 Oscillator Configuration | . 123 | | | | | | | 10.0 Power-Saving Features | . 133 | | | | | | | 11.0 I/O Ports | . 141 | | | | | | | 12.0 Timer1 | | | | | | | | 13.0 Timer2/3, Timer4/5, Timer6/7 and Timer8/9 | . 147 | | | | | | | 14.0 Input Capture | . 153 | | | | | | | 15.0 Output Compare | . 155 | | | | | | | 16.0 Serial Peripheral Interface (SPI) | | | | | | | | 17.0 Inter-Integrated Circuit™ (I <sup>2</sup> C™) | | | | | | | | 18.0 Universal Asynchronous Receiver Transmitter (UART) | . 173 | | | | | | | 19.0 Enhanced CAN (ECAN™) Module | . 179 | | | | | | | 20.0 10-bit/12-bit Analog-to-Digital Converter (ADC) | . 207 | | | | | | | 21.0 Special Features | | | | | | | | 22.0 Instruction Set Summary | . 229 | | | | | | | 23.0 Development Support | . 237 | | | | | | | 24.0 Electrical Characteristics | . 241 | | | | | | | 25.0 High Temperature Electrical Characteristics | . 287 | | | | | | | 26.0 DC and AC Device Characteristics Graphs | . 297 | | | | | | | 27.0 Packaging Information | . 301 | | | | | | | Appendix A: Migrating from PIC24HJXXXGPX06/X08/X10 Devices to PIC24HJXXXGPX06A/X08A/X10A Devices | . 311 | | | | | | | Appendix B: Revision History | . 312 | | | | | | | Index | 317 | | | | | | | e Microchip Web Site | | | | | | | | ustomer Change Notification Service | | | | | | | | Customer Support | | | | | | | | Reader Response | | | | | | | | Product Identification System323 | | | | | | | ## 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** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. 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., DS30000A is version A of document DS30000). #### Errata An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies. To determine if an errata sheet exists for a particular device, please check with one of the following: - Microchip's Worldwide Web site; http://www.microchip.com - · Your local Microchip sales office (see last page) When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using. #### **Customer Notification System** Register on our web site at www.microchip.com to receive the most current information on all of our products. #### **Referenced Sources** This device data sheet is based on the following individual chapters of the "dsPIC33F/PIC24H Family Reference Manual". These documents should be considered as the general reference for the operation of a particular module or device feature. Note: To access the documents listed below, browse to the documentation section of the PIC24HJ256GP610A product page on the Microchip web site (www.microchip.com) or by selecting a family reference manual section from the following list. In addition to parameters, features, and other documentation, the resulting page provides links to the related family reference manual sections. - Section 1. "Introduction" (DS70197) - Section 2. "CPU" (DS70204) - Section 3. "Data Memory" (DS70202) - Section 4. "Program Memory" (DS70203) - Section 5. "Flash Programming" (DS70191) - Section 6. "Interrupts" (DS70184) - Section 7. "Oscillator" (DS70186) - Section 8. "Reset" (DS70192) - Section 9. "Watchdog Timer and Power-Saving Modes" (DS70196) - Section 10. "I/O Ports" (DS70193) - Section 11. "Timers" (DS70205) - Section 12. "Input Capture" (DS70198) - Section 13. "Output Compare" (DS70209) - Section 16. "Analog-to-Digital Converter (ADC)" (DS70183) - Section 17. "UART" (DS70188) - Section 18. "Serial Peripheral Interface (SPI)" (DS70206) - Section 19. "Inter-Integrated Circuit™ (I2C™)" (DS70195) - Section 20. "Data Converter Interface (DCI)" (DS70288) - Section 21. "Enhanced Controller Area Network (ECAN™)" (DS70185) - Section 22. "Direct Memory Access (DMA)" (DS70182) - Section 23. "CodeGuard™ Security" (DS70199) - Section 24. "Programming and Diagnostics" (DS70207) - Section 25. "Device Configuration" (DS70194) #### 1.0 DEVICE OVERVIEW Note: This data sheet summarizes the features of the PIC24HJXXXGPX06A/X08A/X10A family of devices. However, it is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the latest family reference sections of the "dsPIC33F/PIC24H Family Reference Manual", which is available from the Microchip web site (www.microchip.com). This document contains device specific information for the following devices: - PIC24HJ64GP206A - PIC24HJ64GP210A - PIC24HJ64GP506A - PIC24HJ64GP510A - PIC24HJ128GP206A - PIC24HJ128GP210A - PIC24HJ128GP506A - PIC24HJ128GP510A - PIC24HJ128GP306A - PIC24HJ128GP310A - PIC24HJ256GP206A - PIC24HJ256GP210A - PIC24HJ256GP610A The PIC24HJXXXGPX06A/X08A/X10A device family includes devices with different pin counts (64 and 100 pins), different program memory sizes (64 Kbytes, 128 Kbytes and 256 Kbytes) and different RAM sizes (8 Kbytes and 16 Kbytes). This makes these families suitable for a wide variety of high-performance digital signal control applications. The devices are pin compatible with the dsPIC33F family of devices, and also share a very high degree of compatibility with the dsPIC30F family devices. This allows easy migration between device families as may be necessitated by the specific functionality, computational resource and system cost requirements of the application. The PIC24HJXXXGPX06A/X08A/X10A device family employs a powerful 16-bit architecture, ideal for applications that rely on high-speed, repetitive computations, as well as control. The 17 x 17 multiplier, hardware support for division operations, multi-bit data shifter, a large array of 16-bit working registers and a wide variety of data addressing modes. together provide the PIC24HJXXXGPX06A/X08A/X10A Central Processing Unit (CPU) with extensive mathematical processing capability. Flexible and deterministic interrupt handling, coupled with a powerful array of peripherals, renders the PIC24HJXXXGPX06A/X08A/X10A devices suitable for control applications. Further, Direct Memory Access (DMA) enables overhead-free transfer of data between several peripherals and a dedicated DMA RAM. Reliable, field programmable Flash program memory ensures scalability of applications that use PIC24HJXXXGPX06A/X08A/X10A devices. Figure 1-1 shows a general block diagram of the various core and peripheral modules in the PIC24HJXXXGPX06A/X08A/X10A family of devices, while Table 1-1 lists the functions of the various pins shown in the pinout diagrams. TABLE 1-1: PINOUT I/O DESCRIPTIONS | Pin Name | Pin<br>Type | Buffer<br>Type | Description | |----------------------------------------------------|-----------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AN0-AN31 | I | Analog | Analog input channels. | | AVDD | Р | Р | Positive supply for analog modules. This pin must be connected at all times. | | AVss | Р | Р | Ground reference for analog modules. | | CLKI<br>CLKO | 0 | ST/CMOS | External clock source input. Always associated with OSC1 pin function. Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. Optionally functions as CLKO in RC and EC modes. Always associated with OSC2 pin function. | | CN0-CN23 | I | ST | Input change notification inputs. Can be software programmed for internal weak pull-ups on all inputs. | | C1RX<br>C1TX<br>C2RX<br>C2TX | | ST<br>—<br>ST<br>— | ECAN1 bus receive pin. ECAN1 bus transmit pin. ECAN2 bus receive pin. ECAN2 bus transmit pin. | | PGED1<br>PGEC1<br>PGED2<br>PGEC2<br>PGED3<br>PGEC3 | I/O<br>I<br>I/O<br>I<br>I/O | ST<br>ST<br>ST<br>ST<br>ST<br>ST | Data I/O pin for programming/debugging communication channel 1. Clock input pin for programming/debugging communication channel 1. Data I/O pin for programming/debugging communication channel 2. Clock input pin for programming/debugging communication channel 2. Data I/O pin for programming/debugging communication channel 3. Clock input pin for programming/debugging communication channel 3. | | IC1-IC8 | I | ST | Capture inputs 1 through 8. | | INTO<br>INT1<br>INT2<br>INT3<br>INT4 | | ST<br>ST<br>ST<br>ST<br>ST | External interrupt 0. External interrupt 1. External interrupt 2. External interrupt 3. External interrupt 4. | | MCLR | I/P | ST | Master Clear (Reset) input. This pin is an active-low Reset to the device. | | OCFA<br>OCFB<br>OC1-OC8 | <br> | ST<br>ST<br>— | Compare Fault A input (for Compare Channels 1, 2, 3 and 4). Compare Fault B input (for Compare Channels 5, 6, 7 and 8). Compare outputs 1 through 8. | | OSC1<br>OSC2 | I<br>I/O | ST/CMOS | Oscillator crystal input. ST buffer when configured in RC mode; CMOS otherwise. Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. Optionally functions as CLKO in RC and EC modes. | | RA0-RA7<br>RA9-RA10<br>RA12-RA15 | I/O<br>I/O<br>I/O | ST<br>ST<br>ST | PORTA is a bidirectional I/O port. | | RB0-RB15 | I/O | ST | PORTB is a bidirectional I/O port. | | RC1-RC4<br>RC12-RC15 | I/O<br>I/O | ST<br>ST | PORTC is a bidirectional I/O port. | | RD0-RD15 | I/O | ST | PORTD is a bidirectional I/O port. | | RE0-RE7 | I/O | ST | PORTE is a bidirectional I/O port. | | RF0-RF8<br>RF12-RF13 | I/O | ST | PORTF is a bidirectional I/O port. | | RG0-RG3<br>RG6-RG9<br>RG12-RG15 | I/O<br>I/O<br>I/O | ST<br>ST<br>ST | PORTG is a bidirectional I/O port. | **Legend:** CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power I = Input **TABLE 1-1:** PINOUT I/O DESCRIPTIONS (CONTINUED) | SDI1 | IADLE I-I. | | FINOUT I/O DESCRIPTIONS (CONTINUED) | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|-------------------------------------|-------------------------------------------------|--|--|--| | SDI1 | Pin Name | | | Description | | | | | SDI1 | SCK1 | I/O | ST | Synchronous serial clock input/output for SPI1. | | | | | SD01 | SDI1 | | | | | | | | SST | SDO1 | 0 | _ | SPI1 data out. | | | | | SCK2 | SS1 | | ST | | | | | | SDI2 | SCK2 | | | | | | | | SDO2 | SDI2 | | | | | | | | SS2 | SDO2 | | | | | | | | SDA1 | SS2 | | ST | | | | | | SDA1 | SCL1 | I/O | | Synchronous serial clock input/output for I2C1. | | | | | SCL2 | SDA1 | I/O | ST | | | | | | SDA2 | SCL2 | _ | | | | | | | SOSCI ST/CMOS 32.768 kHz low-power oscillator crystal input; CMOS otherwise. SOSCO O | SDA2 | | | | | | | | SOSCO | SOSCI | I | ST/CMOS | | | | | | TCK | sosco | 0 | _ | | | | | | TDI | TMS | l | | | | | | | TDO | TCK | - | | | | | | | T1CK | TDI | | ST | · | | | | | T2CK | TDO | 0 | _ | JTAG test data output pin. | | | | | T3CK I ST Timer3 external clock input. T4CK I ST Timer4 external clock input. T5CK I ST Timer5 external clock input. T6CK I ST Timer6 external clock input. T7CK I ST Timer7 external clock input. T8CK I ST Timer8 external clock input. T9CK I ST UART1 clear to send. U1CTS I ST UART1 clear to send. U1RTS O — UART1 ready to send. U1RX I ST UART1 transmit. U2CTS I ST UART2 clear to send. U2RTS O — UART2 ready to send. U2RX I ST UART2 ready to send. U2RX I ST UART2 ready to send. U2RX I ST UART2 ready to send. U2RX I ST UART2 ready to send. U2RX O — UART3 ready to send. | T1CK | l I | | · · | | | | | T4CK I ST Timer4 external clock input. T5CK I ST Timer5 external clock input. T6CK I ST Timer6 external clock input. T7CK I ST Timer7 external clock input. T8CK I ST Timer8 external clock input. T9CK I ST UART1 clear to send. U1CTS I ST UART1 ready to send. U1RX I ST UART1 receive. U1RX I ST UART1 transmit. U2CTS I ST UART2 clear to send. U2RTS I ST UART2 ready to send. U2RX I ST UART2 receive. U2TX O — UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. VRS P — Ground reference for logic and I/O pins. VREF+ I Analog <td>T2CK</td> <td> I</td> <td>_</td> <td></td> | T2CK | I | _ | | | | | | T5CK | T3CK | | | · | | | | | T6CK I ST Timer6 external clock input. T7CK I ST Timer7 external clock input. T8CK I ST Timer8 external clock input. T9CK I ST Timer9 external clock input. U1CTS I ST UART1 clear to send. U1RX I ST UART1 receive. U1RX I ST UART1 receive. U1TX O — UART1 transmit. U2CTS I ST UART2 clear to send. U2RTS O — UART2 ready to send. U2RX I ST UART2 receive. U2RX I ST UART2 receive. U2TX O — UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. VRSF+ I Analog Analog voltage reference (high) input. | T4CK | l I | | · · | | | | | T7CK I ST Timer7 external clock input. T8CK I ST Timer8 external clock input. T9CK I ST Timer9 external clock input. U1CTS I ST UART1 clear to send. U1RTS O — UART1 ready to send. U1RX I ST UART1 transmit. U1TX O — UART1 transmit. U2CTS I ST UART2 clear to send. U2RTS O — UART2 receive. U2RX I ST UART2 receive. U2TX O — UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. VSS P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | T5CK | l I | | | | | | | T8CK | T6CK | l I | | | | | | | TIME TIME TIME TIME TIME TO ST TIME ST UART1 clear to send. U1CTS | T7CK | l I | - | · · | | | | | U1CTS U1RTS O UART1 clear to send. UART1 ready to send. U1RX U1TX O UART1 transmit. U2CTS I ST UART2 clear to send. U2RTS O UART2 ready to send. U2RX I ST UART2 ready to send. U2RX I U2TX O UART2 receive. U2TX O UART2 transmit. VDD P Positive supply for peripheral logic and I/O pins. VCAP P Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | T8CK | | | | | | | | U1RTS U1RTS U1RX U1RX U1TX U2CTS U2RTS U2RTS U2RX U2TX U2TX U2TX U2TX U2TX U2TX U2TX U2T | T9CK | l | ST | Timer9 external clock input. | | | | | U1RX I ST UART1 receive. U1TX O — UART1 transmit. U2CTS I ST UART2 clear to send. U2RTS O — UART2 ready to send. U2RX I ST UART2 receive. U2TX O — UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. Vss P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | U1CTS | - | ST | | | | | | U1TX O — UART1 transmit. U2CTS I ST UART2 clear to send. U2RTS O — UART2 ready to send. U2RX I ST UART2 receive. U2TX O — UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. Vss P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | U1RTS | | _ | · · | | | | | UZCTS | U1RX | - | ST | | | | | | U2RTS U2RX U2RX U2TX O — UART2 ready to send. UART2 receive. UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. VSS P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | U1TX | _ | _ | | | | | | U2RX I ST UART2 receive. U2TX O — UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. Vss P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | U2CTS | | ST | | | | | | U2TX O — UART2 transmit. VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. VSS P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | U2RTS | | _ | | | | | | VDD P — Positive supply for peripheral logic and I/O pins. VCAP P — CPU logic filter capacitor connection. Vss P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | U2RX | | ST | | | | | | VCAP P — CPU logic filter capacitor connection. Vss P — Ground reference for logic and I/O pins. VREF+ I Analog Analog voltage reference (high) input. | U2TX | | _ | | | | | | Vss P — Ground reference for logic and I/O pins. VREF+ I Analog Voltage reference (high) input. | VDD | | _ | | | | | | VREF+ I Analog Analog voltage reference (high) input. | VCAP | • | | • | | | | | | Vss | Р | _ | · · · · · · · · · · · · · · · · · · · | | | | | VREF- I Analog Analog voltage reference (low) input. | VREF+ | | Analog | | | | | | | VREF- | I | Analog | Analog voltage reference (low) input. | | | | **Legend:** CMOS = CMOS compatible input or output Analog = Analog input P = Power I = Input ST = Schmitt Trigger input with CMOS levels O = Output ## 2.0 GUIDELINES FOR GETTING STARTED WITH 16-BIT MICROCONTROLLERS Note 1: This data sheet summarizes the features of the PIC24HJXXXGPX06A/X08A/X10A family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the "dsPIC33F/PIC24H Family Reference Manual". Please see the Microchip web site (www.microchip.com) for the latest dsPIC33F/PIC24H Family Reference Manual sections. 2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information. ## 2.1 Basic Connection Requirements Getting started with the PIC24HJXXXGPX06A/X08A/X10A family of 16-bit Microcontrollers (MCUs) requires attention to a minimal set of device pin connections before proceeding with development. The following is a list of pin names, which must always be connected: - All VDD and Vss pins (see Section 2.2 "Decoupling Capacitors") - All AVDD and AVss pins (regardless if ADC module is not used) (see Section 2.2 "Decoupling Capacitors") - VCAP (see Section 2.3 "CPU Logic Filter Capacitor Connection (VCAP)") - MCLR pin (see Section 2.4 "Master Clear (MCLR) Pin") - PGECx/PGEDx pins used for In-Circuit Serial Programming™ (ICSP™) and debugging purposes (see Section 2.5 "ICSP Pins") - OSC1 and OSC2 pins when external oscillator source is used (see Section 2.6 "External Oscillator Pins") Additionally, the following pins may be required: VREF+/VREF- pins used when external voltage reference for ADC module is implemented **Note:** The AVDD and AVSS pins must be connected independent of the ADC voltage reference source. #### 2.2 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: Recommendation of 0.1 μF (100 nF), 10-20V. This capacitor should be a low-ESR and have resonance frequency in the range of 20 MHz and higher. It is recommended that ceramic capacitors be used. - Placement on the printed circuit board: The decoupling capacitors should be placed as close to the pins as possible. It is recommended to place the capacitors on the same side of the board as the device. If space is constricted, the capacitor can be placed on another layer on the PCB using a via; however, ensure that the trace length from the pin to the capacitor is within one-quarter inch (6 mm) in length. - Handling high frequency noise: If the board is experiencing high frequency noise, upward of tens of MHz, add a second ceramic-type capacitor in parallel to the above described decoupling capacitor. The value of the second capacitor can be in the range of 0.01 μF to 0.001 μF. Place this second capacitor next to the primary decoupling capacitor. In high-speed circuit designs, consider implementing a decade pair of capacitances as close to the power and ground pins as possible. For example, 0.1 μF in parallel with 0.001 μF. - Maximizing performance: On the board layout from the power supply circuit, run the power and return traces to the decoupling capacitors first, and then to the device pins. This ensures that the decoupling capacitors are first in the power chain. Equally important is to keep the trace length between the capacitor and the power pins to a minimum thereby reducing PCB track inductance. # FIGURE 2-1: RECOMMENDED MINIMUM CONNECTION Note 1: As an option, instead of a hard-wired connection, an inductor (L1) can be substituted between VDD and AVDD to improve ADC noise rejection. The inductor impedance should be less than $1\Omega$ and the inductor capacity greater than 10 mA. Where: $$f = \frac{FCNV}{2} \qquad \text{(i.e., ADC conversion rate/2)}$$ $$f = \frac{1}{(2\pi\sqrt{LC})}$$ $$L = \left(\frac{1}{(2\pi f\sqrt{C})}\right)^2$$ #### 2.2.1 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 MCUs 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 CPU Logic Filter Capacitor Connection (VCAP) A low-ESR (< 5 Ohms) capacitor is required on the VCAP pin, which is used to stabilize the voltage regulator output voltage. The VCAP pin must not be connected to VDD, and must have a capacitor between 4.7 $\mu$ F and 10 $\mu$ F, 16V connected to ground. The type can be ceramic or tantalum. Refer to Section 24.0 "Electrical Characteristics" for additional information. The placement of this capacitor should be close to the VCAP. It is recommended that the trace length not exceed one-quarter inch (6 mm). Refer to Section 21.2 "On-Chip Voltage Regulator" for details. ## 2.4 Master Clear (MCLR) Pin The $\overline{\text{MCLR}}$ pin provides for two specific device functions: - · Device Reset - · Device programming and debugging During device programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the $\overline{\text{MCLR}}$ pin. Consequently, specific voltage levels (VIH and VIL) and fast signal transitions must not be adversely affected. Therefore, specific values of R and C will need to be adjusted based on the application and PCB requirements. For example, as shown in Figure 2-2, it is recommended that the capacitor C, be isolated from the $\overline{\text{MCLR}}$ pin during programming and debugging operations. Place the components shown in Figure 2-2 within one-quarter inch (6 mm) from the $\overline{\text{MCLR}}$ pin. # FIGURE 2-2: EXAMPLE OF MCLR PIN CONNECTIONS - Note 1: $R \le 10 \text{ k}\Omega$ is recommended. A suggested starting value is $10 \text{ k}\Omega$ . Ensure that the MCLR pin VIH and VIL specifications are met. - 2: $R1 \le 470\Omega$ will limit any current flowing into $\overline{MCLR}$ from the external capacitor C, in the event of $\overline{MCLR}$ pin breakdown, due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS). Ensure that the $\overline{MCLR}$ pin VIH and VIL specifications are met. #### 2.5 ICSP Pins The PGECx and PGEDx pins are used for In-Circuit Serial Programming™ (ICSP™) and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of Ohms, not to exceed 100 Ohms. Pull-up resistors, series diodes, and capacitors on the PGECx and PGEDx pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the "dsPIC33F/PIC24H Flash Programming Specification" (DS70152) for information on capacitive loading limits and pin input voltage high (VIH) and input low (VIL) requirements. Ensure that the "Communication Channel Select" (i.e., PGECx/PGEDx pins) programmed into the device matches the physical connections for the ICSP to MPLAB® ICD 3 or MPLAB REAL ICE $^{\rm TM}$ . For more information on ICD 3 and REAL ICE connection requirements, refer to the following documents that are available on the Microchip web site. - "Using MPLAB<sup>®</sup> ICD 3 In-Circuit Debugger" (poster) DS51765 - "MPLAB® ICD 3 Design Advisory" DS51764 - "MPLAB<sup>®</sup> REAL ICE™ In-Circuit Emulator User's Guide" DS51616 - "Using MPLAB® REAL ICE™" (poster) DS51749 #### 2.6 External Oscillator Pins Many MCUs have options for at least two oscillators: a high-frequency primary oscillator and a low-frequency secondary oscillator (refer to **Section 9.0 "Oscillator Configuration"** for details). The oscillator circuit should be placed on the same side of the board as the device. Also, place the oscillator circuit close to the respective oscillator pins, not exceeding one-half inch (12 mm) distance between them. The load capacitors should be placed next to the oscillator itself, on the same side of the board. Use a grounded copper pour around the oscillator circuit to isolate them from surrounding circuits. The grounded copper pour should be routed directly to the MCU ground. Do not run any signal traces or power traces inside the ground pour. Also, if using a two-sided board, avoid any traces on the other side of the board where the crystal is placed. A suggested layout is shown in Figure 2-3. FIGURE 2-3: SUGGESTED PLACEMENT OF THE OSCILLATOR CIRCUIT # 2.7 Oscillator Value Conditions on Device Start-up If the PLL of the target device is enabled and configured for the device start-up oscillator, the maximum oscillator source frequency must be limited to $\leq 8$ MHz for start-up with PLL enabled to comply with device PLL start-up conditions. This means that if the external oscillator frequency is outside this range, the application must start-up in the FRC mode first. The default PLL settings after a POR with an oscillator frequency outside this range will violate the device operating speed. Once the device powers up, the application firmware can initialize the PLL SFRs, CLKDIV and PLLDBF to a suitable value, and then perform a clock switch to the Oscillator + PLL clock source. Note that clock switching must be enabled in the device Configuration word. # 2.8 Configuration of Analog and Digital Pins During ICSP Operations If MPLAB ICD 3 or REAL ICE is selected as a debugger, it automatically initializes all of the A/D input pins (ANx) as "digital" pins, by setting all bits in the AD1PCFGL register. The bits in this register that correspond to the A/D pins that are initialized by MPLAB ICD 3 or REAL ICE, must not be cleared by the user application firmware; otherwise, communication errors will result between the debugger and the device. If your application needs to use certain A/D pins as analog input pins during the debug session, the user application must clear the corresponding bits in the AD1PCFGL register during initialization of the ADC module. When MPLAB ICD 3 or REAL ICE is used as a programmer, the user application firmware must correctly configure the AD1PCFGL register. Automatic initialization of this register is only done during debugger operation. Failure to correctly configure the register(s) will result in all A/D pins being recognized as analog input pins, resulting in the port value being read as a logic '0', which may affect user application functionality. #### 2.9 Unused I/Os Unused I/O pins should be configured as outputs and driven to a logic-low state. Alternatively, connect a 1k to 10k resistor between Vss and the unused pins. #### 3.0 CPU # Note 1: This data sheet summarizes the features of the PIC24HJXXXGPX06A/X08A/X10A family of devices. However, it is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 2. "CPU" (DS70204) of the "dsPIC33F/PIC24H Family Reference Manual", which is available from the Microchip web site (www.microchip.com). 2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information. The PIC24HJXXXGPX06A/X08A/X10A CPU module has a 16-bit (data) modified Harvard architecture with an enhanced instruction set and addressing modes. The CPU has a 24-bit instruction word with a variable length opcode field. The Program Counter (PC) is 23 bits wide and addresses up to 4M x 24 bits of user program memory space. The actual amount of program memory implemented varies by device. 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, single-cycle program loop constructs are supported using the REPEAT instruction, which is interruptible at any point. The PIC24HJXXXGPX06A/X08A/X10A devices have sixteen, 16-bit working registers in the programmer's model. Each of the working registers can serve as a data, address or address offset register. The 16th working register (W15) operates as a software Stack Pointer (SP) for interrupts and calls. The PIC24HJXXXGPX06A/X08A/X10A instruction set includes many addressing modes and is designed for optimum C compiler efficiency. For most instructions, the PIC24HJXXXGPX06A/X08A/X10A 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 A + B = C operations to be executed in a single cycle. A block diagram of the CPU is shown in Figure 3-1, and the programmer's model for the PIC24HJXXXGPX06A/X08A/X10A is shown in Figure 3-2. #### 3.1 Data Addressing Overview The data space can be linearly addressed as 32K words or 64 Kbytes using an Address Generation Unit (AGU). The upper 32 Kbytes of the data space memory map can optionally be mapped into program space at any 16K program word boundary defined by the 8-bit Program Space Visibility Page (PSVPAG) register. The program to data space mapping feature lets any instruction access program space as if it were data space. The data space also includes 2 Kbytes of DMA RAM, which is primarily used for DMA data transfers, but may be used as general purpose RAM. ## 3.2 Special MCU Features The PIC24HJXXXGPX06A/X08A/X10A features a 17-bit by 17-bit, single-cycle multiplier. The multiplier can perform signed, unsigned and mixed-sign multiplication. Using a 17-bit by 17-bit multiplier for 16-bit by 16-bit multiplication makes mixed-sign multiplication possible. The PIC24HJXXXGPX06A/X08A/X10A supports 16/16 and 32/16 integer divide operations. All divide instructions are iterative operations. They must be executed within a REPEAT loop, resulting in a total execution time of 19 instruction cycles. The divide operation can be interrupted during any of those 19 cycles without loss of data. A multi-bit data shifter is used to perform up to a 16-bit, left or right shift in a single cycle. FIGURE 3-1: PIC24HJXXXGPX06A/X08A/X10A CPU CORE BLOCK DIAGRAM