

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                    |                                                                               |
|----------------------------|-------------------------------------------------------------------------------|
|                            | A                                                                             |
| Product Status             | Active                                                                        |
| Core Processor             | PIC                                                                           |
| Core Size                  | 16-Bit                                                                        |
| Speed                      | 40 MIPs                                                                       |
| Connectivity               | I <sup>2</sup> C, PMP, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, DMA, POR, PWM, WDT                                    |
| Number of I/O              | 35                                                                            |
| Program Memory Size        | 32KB (11K x 24)                                                               |
| Program Memory Type        | FLASH                                                                         |
| EEPROM Size                | -                                                                             |
| RAM Size                   | 4K x 8                                                                        |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                     |
| Data Converters            | A/D 13x10b/12b                                                                |
| Oscillator Type            | Internal                                                                      |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                                 |
| Package / Case             | 44-TQFP                                                                       |
| Supplier Device Package    | 44-TQFP (10x10)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic24hj32gp304-e-pt |

# PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 AND PIC24HJ128GPX02/X04

# **Table of Contents**

| PIC2  | 24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 Product Families | 2   |
|-------|------------------------------------------------------------------------------|-----|
| 1.0   | Device Overview                                                              |     |
| 2.0   | Guidelines for Getting Started with 16-bit Microcontrollers                  | 13  |
| 3.0   | CPU                                                                          | 17  |
| 4.0   | Memory Organization                                                          | 25  |
| 5.0   | Flash Program Memory                                                         | 53  |
| 6.0   | Resets                                                                       | 59  |
| 7.0   | Interrupt Controller                                                         | 69  |
| 8.0   | Direct Memory Access (DMA)                                                   | 107 |
| 9.0   | Oscillator Configuration                                                     | 119 |
| 10.0  | Power-Saving Features                                                        | 129 |
| 11.0  | I/O Ports                                                                    | 135 |
| 12.0  | Timer1                                                                       | 161 |
| 13.0  | Timer2/3 And TImer4/5 Feature                                                | 165 |
| 14.0  | Input Capture                                                                | 171 |
| 15.0  | Output Compare                                                               | 175 |
|       | Serial Peripheral Interface (SPI)                                            |     |
| 17.0  | Inter-Integrated Circuit™ (I <sup>2</sup> C™)                                | 185 |
|       | Universal Asynchronous Receiver Transmitter (UART)                           |     |
| 19.0  | Enhanced CAN (ECAN™) Module                                                  | 199 |
| 20.0  | 10-bit/12-bit Analog-to-Digital Converter (ADC1)                             | 227 |
|       | Comparator Module                                                            |     |
| 22.0  | Real-Time Clock and Calendar (RTCC)                                          | 247 |
|       | Programmable Cyclic Redundancy Check (CRC) Generator                         |     |
| 24.0  | Parallel Master Port (PMP)                                                   | 265 |
| 25.0  | Special Features                                                             | 273 |
| 26.0  | Instruction Set Summary                                                      | 283 |
| 27.0  | Development Support                                                          | 291 |
| 28.0  | Electrical Characteristics                                                   | 295 |
| 29.0  | High Temperature Electrical Characteristics                                  | 345 |
| 32.0  | DC and AC Device Characteristics Graphs                                      | 357 |
| 33.0  | Packaging Information                                                        | 361 |
| Appe  | endix A: Revision History                                                    | 371 |
| The I | Microchip Web Site                                                           | 385 |
| Cust  | omer Change Notification Service                                             | 385 |
|       | omer Support                                                                 |     |
| Read  | der Response                                                                 | 386 |
| D     | lust Identification Cyctom                                                   | 207 |



FIGURE 4-4: DATA MEMORY MAP FOR PIC24HJ128GP202/204, PIC24HJ64GP202/204, PIC24HJ128GP502/504 AND PIC24HJ64GP502/504 DEVICES WITH 8 KB RAM

## 4.3 Memory Organization Resources

Many useful resources related to Memory Organization are provided on the main product page of the Microchip web site for the devices listed in this data sheet. This product page, which can be accessed using this link, contains the latest updates and additional information.

Note:

In the event you are not able to access the product page using the link above, enter this URL in your browser:

http://www.microchip.com/wwwprod-ucts/Devices.aspx?dDoc-

Name=en534555

## 4.3.1 KEY RESOURCES

- Section 4. "Program Memory" (DS70203)
- · Code Samples
- · Application Notes
- · Software Libraries
- Webinars
- All related dsPIC33F/PIC24H Family Reference Manuals Sections
- · Development Tools

# TABLE 4-32: SECURITY REGISTER MAP(1)

| 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 |
|-----------|------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|--------|--------|--------|---------------|
| BSRAM     | 0750 | -      |        | _      |        | _      | -      | _     | _     | -     | _     | _     | _     | _     | IW_BSR | IR_BSR | RL_BSR | 0000          |
| SSRAM     | 0752 | _      | -      | -      | _      | _      | _      | _     | _     | -     | _     | _     | _     | _     | IW_SSR | IR_SSR | RL_SSR | 0000          |

Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

Note 1: This register is not present in devices with 32K Flash (PIC24HJ32GP302/304).

## **TABLE 4-33: 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    | 0760 | WR     | WREN   | WRERR  | -      | _      | _      | _     | _     | _           | ERASE | _     | _     | NVMOP<3:0> |       |       | 0000  |               |
| NVMKEY    | 0766 | _      | -      | _      | -      | -      | -      | -     | -     | NVMKEY<7:0> |       |       |       |            | 0000  |       |       |               |

Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

#### TABLE 4-34: PMD 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 |
|-----------|------|--------|--------|--------|--------|--------|--------|--------|-------|--------|-------|-------|--------|--------|-------|-------|-------|---------------|
| PMD1      | 0770 | T5MD   | T4MD   | T3MD   | T2MD   | T1MD   | _      | _      | _     | I2C1MD | U2MD  | U1MD  | SPI2MD | SPI1MD | _     | C1MD  | AD1MD | 0000          |
| PMD2      | 0772 | IC8MD  | IC7MD  | _      | _      | _      | _      | IC2MD  | IC1MD | _      | _     | _     | _      | OC4MD  | OC3MD | OC2MD | OC1MD | 0000          |
| PMD3      | 0774 | _      | -      | _      | _      | _      | CMPMD  | RTCCMD | PMPMD | CRCMD  | -     | _     | _      | _      | -     | _     | _     | 0000          |

Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

# 4.6 Interfacing Program and Data Memory Spaces

The PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 architecture uses a 24-bit-wide program space and a 16-bit-wide data space. The architecture is also a modified Harvard scheme, meaning that data can also be present in the program space. To use this data successfully, it must be accessed in a way that preserves the alignment of information in both spaces.

Aside from normal execution, the PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 architecture provides two methods by which program space can be accessed during operation:

- Using table instructions to access individual bytes or words anywhere in the program space
- Remapping a portion of the program space into the data space (Program Space Visibility)

Table instructions allow an application to read or write to small areas of the program memory. This capability makes the method ideal for accessing data tables that need to be updated periodically. It also allows access to all bytes of the program word. The remapping method allows an application to access a large block of data on a read-only basis, which is ideal for look-ups from a large table of static data. The application can only access the least significant word of the program word.

#### 4.6.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 Page 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 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 table operations, this limits remapping operations strictly to the user memory area.

Table 4-36 and Figure 4-6 show 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, and D<15:0> refers to a data space word.

TABLE 4-36: 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>                   |           |                                   |                    |     |  |  |  |
| (Code Execution)         |               | 0xx xxxx xxxx xxxx xxxx xxx0 |           |                                   |                    |     |  |  |  |
| TBLRD/TBLWT              | User          | ТВ                           | LPAG<7:0> |                                   | Data EA<15:0>      |     |  |  |  |
| (Byte/Word Read/Write)   |               | 0                            | xxx xxxx  | xxxx xx                           | XXX XXXX XXXX      |     |  |  |  |
|                          | Configuration | TB                           | LPAG<7:0> | Data EA<15:0>                     |                    |     |  |  |  |
|                          |               | 1                            | xxx xxxx  | xxxx x                            | XXX XXXX XXXX      |     |  |  |  |
| Program Space Visibility | User          | 0                            | PSVPAG<7  | <7:0> Data EA<14:0> <sup>(1</sup> |                    |     |  |  |  |
| (Block Remap/Read)       |               | 0                            | XXXX XXXX | ζ.                                | xxx xxxx xxxx xxxx |     |  |  |  |

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>.

## 7.6 Interrupt Setup Procedures

#### 7.6.1 INITIALIZATION

To configure an interrupt source at initialization:

- Set the NSTDIS 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 depends 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 can 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.

## 7.6.2 INTERRUPT SERVICE ROUTINE

The method used to declare an ISR and initialize the IVT with the correct vector address depends on the programming language (C or assembler) and the language development tool suite used to develop the application.

In general, the user application must clear the interrupt flag in the appropriate IFSx register for the source of interrupt that the ISR handles. Otherwise, the program re-enters the ISR 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.

## 7.6.3 TRAP SERVICE ROUTINE

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.

## 7.6.4 INTERRUPT DISABLE

All user interrupts can be disabled using this procedure:

- Push the current SR value onto the software stack using the PUSH instruction.
- 2. Force the CPU to priority level 7 by inclusive ORing the value 0xOE with SRL.

To enable user interrupts, the  ${\tt POP}$  instruction can be used to restore the previous SR value.

Note: Only user interrupts with a priority level of 7 or lower can be disabled. Trap sources (level 8-level 15) cannot be disabled.

The DISI instruction provides a convenient way to disable interrupts of priority levels 1-6 for a fixed period of time. Level 7 interrupt sources are not disabled by the DISI instruction.

#### REGISTER 8-8: DMACS1: DMA CONTROLLER STATUS REGISTER 1

| U-0    | U-0 | U-0 | U-0 | R-1        | R-1 | R-1 | R-1   |  |  |  |
|--------|-----|-----|-----|------------|-----|-----|-------|--|--|--|
| _      | _   | _   | _   | LSTCH<3:0> |     |     |       |  |  |  |
| bit 15 |     |     |     |            |     |     | bit 8 |  |  |  |

| R-0   |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PPST7 | PPST6 | PPST5 | PPST4 | PPST3 | PPST2 | PPST1 | PPST0 |
| 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 **Unimplemented:** Read as '0'

bit 11-8 LSTCH<3:0>: Last DMA Channel Active bits

1111 = No DMA transfer has occurred since system Reset

1110-1000 = Reserved

0111 = Last data transfer was by DMA Channel 7

0110 = Last data transfer was by DMA Channel 6

0101 = Last data transfer was by DMA Channel 5

0100 = Last data transfer was by DMA Channel 4

0011 = Last data transfer was by DMA Channel 3

0010 = Last data transfer was by DMA Channel 2

0001 = Last data transfer was by DMA Channel 1

0000 = Last data transfer was by DMA Channel 0

bit 7 PPST7: Channel 7 Ping-Pong Mode Status Flag bit

1 = DMA7STB register selected

0 = DMA7STA register selected

bit 6 PPST6: Channel 6 Ping-Pong Mode Status Flag bit

1 = DMA6STB register selected

0 = DMA6STA register selected

bit 5 PPST5: Channel 5 Ping-Pong Mode Status Flag bit

1 = DMA5STB register selected

0 = DMA5STA register selected

bit 4 PPST4: Channel 4 Ping-Pong Mode Status Flag bit

1 = DMA4STB register selected

0 = DMA4STA register selected

bit 3 PPST3: Channel 3 Ping-Pong Mode Status Flag bit

1 = DMA3STB register selected

0 = DMA3STA register selected

bit 2 PPST2: Channel 2 Ping-Pong Mode Status Flag bit

1 = DMA2STB register selected

0 = DMA2STA register selected

bit 1 PPST1: Channel 1 Ping-Pong Mode Status Flag bit

1 = DMA1STB register selected 0 = DMA1STA register selected

bit 0 PPST0: Channel 0 Ping-Pong Mode Status Flag bit

1 = DMA0STB register selected

0 = DMA0STA register selected

## REGISTER 9-3: PLLFBD: PLL FEEDBACK DIVISOR REGISTER<sup>(1)</sup>

| U-0    | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0     |
|--------|-----|-----|-----|-----|-----|-----|-----------|
| _      | _   | _   | _   | _   | _   | _   | PLLDIV<8> |
| bit 15 |     |     |     |     |     |     | bit 8     |

| R/W-0 | R/W-0 | R/W-1 | R/W-1 | R/W-0  | R/W-0 | R/W-0 | R/W-0 |
|-------|-------|-------|-------|--------|-------|-------|-------|
|       |       |       | PLLDI | V<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-0 PLLDIV<8:0>: PLL Feedback Divisor bits (also denoted as 'M', PLL multiplier)

111111111 = 513

•

•

•

000110000 = **50** (default)

•

•

•

000000010 = 4

000000001 = 3

000000000 = 2

Note 1: This register is reset only on a Power-on Reset (POR).

# PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 AND PIC24HJ128GPX02/X04

TABLE 11-1: SELECTABLE INPUT SOURCES (MAPS INPUT TO FUNCTION)<sup>(1)</sup>

| Input Name              | Function Name | Register | Configuration<br>Bits |
|-------------------------|---------------|----------|-----------------------|
| External Interrupt 1    | INT1          | RPINR0   | INT1R<4:0>            |
| External Interrupt 2    | INT2          | RPINR1   | INT2R<4:0>            |
| Timer2 External Clock   | T2CK          | RPINR3   | T2CKR<4:0>            |
| Timer3 External Clock   | T3CK          | RPINR3   | T3CKR<4:0>            |
| Timer4 External Clock   | T4CK          | RPINR4   | T4CKR<4:0>            |
| Timer5 External Clock   | T5CK          | RPINR4   | T5CKR<4:0>            |
| Input Capture 1         | IC1           | RPINR7   | IC1R<4:0>             |
| Input Capture 2         | IC2           | RPINR7   | IC2R<4:0>             |
| Input Capture 7         | IC7           | RPINR10  | IC7R<4:0>             |
| Input Capture 8         | IC8           | RPINR10  | IC8R<4:0>             |
| Output Compare Fault A  | OCFA          | RPINR11  | OCFAR<4:0>            |
| UART1 Receive           | U1RX          | RPINR18  | U1RXR<4:0>            |
| UART1 Clear To Send     | U1CTS         | RPINR18  | U1CTSR<4:0>           |
| UART2 Receive           | U2RX          | RPINR19  | U2RXR<4:0>            |
| UART2 Clear To Send     | U2CTS         | RPINR19  | U2CTSR<4:0>           |
| SPI1 Data Input         | SDI1          | RPINR20  | SDI1R<4:0>            |
| SPI1 Clock Input        | SCK1          | RPINR20  | SCK1R<4:0>            |
| SPI1 Slave Select Input | SS1           | RPINR21  | SS1R<4:0>             |
| SPI2 Data Input         | SDI2          | RPINR22  | SDI2R<4:0>            |
| SPI2 Clock Input        | SCK2          | RPINR22  | SCK2R<4:0>            |
| SPI2 Slave Select Input | SS2           | RPINR23  | SS2R<4:0>             |
| ECAN1 Receive           | CIRX          | RPINR26  | CIRXR<4:0>            |

Note 1: Unless otherwise noted, all inputs use Schmitt input buffers.

## 18.0 UNIVERSAL ASYNCHRONOUS RECEIVER TRANSMITTER (UART)

Note 1: This data sheet summarizes the features of the PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 families of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 17. "UART" (DS70188) 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 Universal Asynchronous Receiver Transmitter (UART) module is one of the serial I/O modules available in the PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 device family. The UART is a full-duplex asynchronous system that can communicate with peripheral devices, such as personal computers, LIN 2.0, RS-232 and RS-485 interfaces. The module also supports a hardware flow control option with the UxCTS and UxRTS pins and also includes an IrDA® encoder and decoder.

The primary features of the UART module are:

- Full-Duplex, 8- 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 with 16-bit prescaler
- Baud rates ranging from 10 Mbps to 38 bps at 40 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 (9th bit = 1)
- · Transmit and Receive interrupts
- · A separate interrupt for all UART error conditions
- · Loopback mode for diagnostic support
- · Support for sync and break characters
- · Support for automatic baud rate detection
- IrDA<sup>®</sup> encoder and decoder logic
- 16x baud clock output for IrDA<sup>®</sup> support

A simplified block diagram of the UART module is shown in Figure 18-1. The UART module consists of these key hardware elements:

- · Baud Rate Generator
- · Asynchronous Transmitter
- · Asynchronous Receiver

FIGURE 18-1: UART SIMPLIFIED BLOCK DIAGRAM



Note 1: Both UART1 and UART2 can trigger a DMA data transfer.

2: If DMA transfers are required, the UART TX/RX FIFO buffer must be set to a size of 1 byte/word (i.e., UTXISEL<1:0> = 00 and URXISEL<1:0> = 00).

# REGISTER 19-16: CIRXFnSID: ECAN™ ACCEPTANCE FILTER STANDARD IDENTIFIER REGISTER n (n = 0-15)

| R/W-x  | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x |
|--------|-------|-------|-------|-------|-------|-------|-------|
| SID10  | SID9  | SID8  | SID7  | SID6  | SID5  | SID4  | SID3  |
| bit 15 |       |       |       |       |       |       | bit 8 |

| R/W-x | R/W-x | R/W-x | U-0 | R/W-x | U-0 | R/W-x | R/W-x |
|-------|-------|-------|-----|-------|-----|-------|-------|
| SID2  | SID1  | SID0  | _   | EXIDE | _   | EID17 | EID16 |
| bit 7 |       |       |     |       |     |       | bit 0 |

| Legend:           | C = Writeable bit, but only '0' can be written to clear the 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-5 SID<10:0>: Standard Identifier bits

1 = Message address bit SIDx must be '1' to match filter 0 = Message address bit SIDx must be '0' to match filter

bit 4 Unimplemented: Read as '0'

bit 3 **EXIDE:** Extended Identifier Enable bit

If MIDE = 1, then:

1 = Match only messages with extended identifier addresses0 = Match only messages with standard identifier addresses

 $\frac{\text{If MIDE = 0, then:}}{\text{Ignore the EXIDE bit.}}$ 

bit 2 Unimplemented: Read as '0'

bit 1-0 **EID<17:16>:** Extended Identifier bits

1 = Message address bit EIDx must be '1' to match filter 0 = Message address bit EIDx must be '0' to match filter

## PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 AND PIC24HJ128GPX02/X04

## REGISTER 19-24: CIRXOVF1: ECAN™ RECEIVE BUFFER OVERFLOW REGISTER 1

| R/C-0   | R/C-0   | R/C-0   | R/C-0   | R/C-0   | R/C-0   | R/C-0  | R/C-0  |
|---------|---------|---------|---------|---------|---------|--------|--------|
| RXOVF15 | RXOVF14 | RXOVF13 | RXOVF12 | RXOVF11 | RXOVF10 | RXOVF9 | RXOVF8 |
| bit 15  |         |         |         |         |         |        | bit 8  |

| R/C-0  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| RXOVF7 | RXOVF6 | RXOVF5 | RXOVF4 | RXOVF3 | RXOVF2 | RXOVF1 | RXOVF0 |
| bit 7  |        |        |        |        |        |        | bit 0  |

Legend:C = Writeable bit, but only '0' can be written to clear the 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-0 **RXOVF<15:0>:** Receive Buffer n Overflow bits

1 = Module attempted to write to a full buffer (set by module)

0 = No overflow condition

## REGISTER 19-25: CIRXOVF2: ECAN™ RECEIVE BUFFER OVERFLOW REGISTER 2

| R/C-0   |
|---------|---------|---------|---------|---------|---------|---------|---------|
| RXOVF31 | RXOVF30 | RXOVF29 | RXOVF28 | RXOVF27 | RXOVF26 | RXOVF25 | RXOVF24 |
| bit 15  |         |         |         |         |         |         | bit 8   |

| R/C-0   |
|---------|---------|---------|---------|---------|---------|---------|---------|
| RXOVF23 | RXOVF22 | RXOVF21 | RXOVF20 | RXOVF19 | RXOVF18 | RXOVF17 | RXOVF16 |
| bit 7   |         |         |         |         |         |         | bit 0   |

| Legend:           | C = Writeable bit, but only '0' can be written to clear the 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-0 **RXOVF<31:16>:** Receive Buffer n Overflow bits

1 = Module attempted to write to a full buffer (set by module)

0 = No overflow condition

## REGISTER 20-3: AD1CON3: ADC1 CONTROL REGISTER 3

| R/W-0  | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0        | R/W-0 | R/W-0 |
|--------|-----|-----|-------|-------|--------------|-------|-------|
| ADRC   | _   | _   |       |       | SAMC<4:0>(1) | )     |       |
| bit 15 |     |     |       |       |              |       | bit 8 |

| R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0               | R/W-0 | R/W-0 | R/W-0 |
|-------|-------|-------|-------|---------------------|-------|-------|-------|
|       |       |       | ADCS< | 7:0> <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 ADRC: ADC Conversion Clock Source bit

1 = ADC internal RC clock

0 = Clock derived from system clock

bit 14-13 **Unimplemented:** Read as '0'

bit 12-8 **SAMC<4:0>:** Auto Sample Time bits<sup>(1)</sup>

11111 = **31** TAD

.

00001 **= 1 TAD** 

00000 **= 0** TAD

bit 7-0 ADCS<7:0>: ADC Conversion Clock Select bits<sup>(2)</sup>

11111111 = Reserved

•

.

•

•

01000000 = **Reserved** 

 $001111111 = Tcy \cdot (ADCS < 7:0 > + 1) = 64 \cdot Tcy = Tad$ 

•

•

•

 $00000010 = Tcy \cdot (ADCS < 7:0 > + 1) = 3 \cdot Tcy = Tad$ 

00000001 = Tcy  $\cdot$  (ADCS<7:0> + 1) = 2  $\cdot$  Tcy = TaD

 $000000000 = Tcy \cdot (ADCS < 7:0 > + 1) = 1 \cdot Tcy = Tad$ 

**Note 1:** This bit only used if AD1CON1<7:5 (SSRC<2:0>) = 111.

2: This bit is not used if AD1CON3<15> (ADRC) = 1.

## REGISTER 21-1: CMCON: COMPARATOR CONTROL REGISTER (CONTINUED)

bit 6 **C1OUT:** Comparator 1 Output bit

When C1INV = 0: 1 = C1 VIN+ > C1 VIN-0 = C1 VIN+ < C1 VIN-When C1INV = 1: 0 = C1 VIN+ > C1 VIN-1 = C1 VIN+ < C1 VIN-

bit 5 **C2INV:** Comparator 2 Output Inversion bit

1 = C2 output inverted0 = C2 output not inverted

bit 4 C1INV: Comparator 1 Output Inversion bit

1 = C1 output inverted0 = C1 output not inverted

bit 3 C2NEG: Comparator 2 Negative Input Configure bit

1 = Input is connected to VIN+ 0 = Input is connected to VIN-

See Figure 21-1 for the comparator modes.

bit 2 C2POS: Comparator 2 Positive Input Configure bit

1 = Input is connected to VIN+0 = Input is connected to CVREF

See Figure 21-1 for the comparator modes.

bit 1 C1NEG: Comparator 1 Negative Input Configure bit

1 = Input is connected to VIN+ 0 = Input is connected to VIN-

See Figure 21-1 for the comparator modes.

bit 0 C1POS: Comparator 1 Positive Input Configure bit

1 = Input is connected to VIN+0 = Input is connected to CVREF

See Figure 21-1 for the comparator modes.

Note 1: If C2OUTEN = 1, the C2OUT peripheral output must be configured to an available RPx pin. See Section 11.6 "Peripheral Pin Select" for more information.

2: If C1OUTEN = 1, the C1OUT peripheral output must be configured to an available RPx pin. See Section 11.6 "Peripheral Pin Select" for more information.

#### REGISTER 24-5: PMSTAT: PARALLEL PORT STATUS REGISTER

| R-0    | R/W-0, HS | U-0 | U-0 | R-0  | R-0  | R-0  | R-0   |
|--------|-----------|-----|-----|------|------|------|-------|
| IBF    | IBOV      | _   | _   | IB3F | IB2F | IB1F | IB0F  |
| bit 15 |           |     |     |      |      |      | bit 8 |

| R-1   | R/W-0, HS | U-0 | U-0 | R-1  | R-1  | R-1  | R-1   |
|-------|-----------|-----|-----|------|------|------|-------|
| OBE   | OBUF      | _   | _   | OB3E | OB2E | OB1E | OB0E  |
| bit 7 |           |     |     |      |      |      | bit 0 |

| Legend:           | HS = Hardware Set 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 **IBF:** Input Buffer Full Status bit

1 = All writable input buffer registers are full

0 = Some or all of the writable input buffer registers are empty

bit 14 IBOV: Input Buffer Overflow Status bit

1 = A write attempt to a full input byte register occurred (must be cleared in software)

0 = No overflow occurred

bit 13-12 **Unimplemented:** Read as '0'

bit 11-8 **IB3F:IB0F** Input Buffer x Status Full bits

1 = Input buffer contains data that has not been read (reading buffer will clear this bit)

0 = Input buffer does not contain any unread data

bit 7 **OBE:** Output Buffer Empty Status bit

1 = All readable output buffer registers are empty

0 = Some or all of the readable output buffer registers are full

bit 6 **OBUF:** Output Buffer Underflow Status bits

1 = A read occurred from an empty output byte register (must be cleared in software)

0 = No underflow occurred

bit 5-4 **Unimplemented:** Read as '0'

bit 3-0 **OB3E:OB0E** Output Buffer x Status Empty bit

1 = Output buffer is empty (writing data to the buffer will clear this bit)

0 = Output buffer contains data that has not been transmitted

#### 25.0 SPECIAL FEATURES

#### **Note 1:** This data sheet summarizes the features PIC24HJ32GP302/304 of the PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 families 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.

The PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 devices include the following features that are intended to maximize application flexibility and reliability, and minimize cost through elimination of external components:

- · Flexible configuration
- Watchdog Timer (WDT)
- Code Protection and CodeGuard™ Security
- · JTAG Boundary Scan Interface
- In-Circuit Serial Programming™ (ICSP™)
- In-Circuit Emulation

## 25.1 Configuration Bits

The PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 devices provide nonvolatile memory implementation for device configuration bits. Refer to **Section 25. "Device Configuration"** (DS70194), in the "dsPIC33F/PIC24H Family Reference Manual" for more information on this implementation.

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 0xF80000.

The individual Configuration bit descriptions for the Configuration registers are shown in Table 25-1.

Note that address 0xF80000 is beyond the user program memory space. It belongs to the configuration memory space (0x800000-0xFFFFFF), which can only be accessed using table reads and table writes.

The Device Configuration register map is shown in Table 25-1.

TABLE 25-1: DEVICE CONFIGURATION REGISTER MAP

| Address  | Name               | Bit 7                   | Bit 6              | Bit 5   | Bit 4  | Bit 3      | Bit 2      | Bit 1 | Bit 0   |
|----------|--------------------|-------------------------|--------------------|---------|--------|------------|------------|-------|---------|
| 0xF80000 | FBS                | RBS<1:0>                |                    | _       | _      | BSS<2:0>   |            |       | BWRP    |
| 0xF80002 | FSS <sup>(1)</sup> | RSS<                    | :1:0>              | _       | _      |            | SSS<2:0>   |       | SWRP    |
| 0xF80004 | FGS                | _                       | _                  | _       | _      | _          | GSS<1      | :0>   | GWRP    |
| 0xF80006 | FOSCSEL            | IESO                    | _                  | _       | _      | -          | FNOSC<2:0> |       |         |
| 0xF80008 | FOSC               | FCKSM                   | 1<1:0>             | IOL1WAY | _      | _          | OSCIOFNC   | POSCN | ID<1:0> |
| 0xF8000A | FWDT               | FWDTEN                  | WINDIS             | _       | WDTPRE |            | WDTPOST<   | <3:0> |         |
| 0xF8000C | FPOR               | Reserved <sup>(2)</sup> |                    | ALTI2C  | _      | FPWRT<2:0> |            |       |         |
| 0xF8000E | FICD               | Reserv                  | ved <sup>(3)</sup> | JTAGEN  | _      | _          | _          | ICS<  | :1:0>   |
| 0xF80010 | FUID0              | User Unit ID Byte 0     |                    |         |        |            |            |       |         |
| 0xF80012 | FUID1              | User Unit ID Byte 1     |                    |         |        |            |            |       |         |
| 0xF80014 | FUID2              | User Unit ID Byte 2     |                    |         |        |            |            |       |         |
| 0xF80016 | FUID3              | User Unit ID Byte 3     |                    |         |        |            |            |       |         |

**Legend:** — = unimplemented bit, read as '0'.

- Note 1: This Configuration register is not available and reads as 0xFF on PIC24HJ32GP302/304 devices.
  - 2: These bits are reserved and always read as '1'.
  - 3: These bits are reserved for use by development tools and must be programmed as '1'.

FIGURE 28-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING CHARACTERISTICS



TABLE 28-37: I2Cx BUS DATA TIMING REQUIREMENTS (SLAVE MODE)

| AC CHARACTERISTICS |              |                               |                           | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated)  Operating temperature -40°C ≤TA ≤+85°C for Industrial -40°C ≤TA ≤+125°C for Extended |         |    |                                             |  |
|--------------------|--------------|-------------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|---------------------------------------------|--|
| Param.             | Symbol       | Charac                        | Characteristic            |                                                                                                                                                             | Min Max |    | Conditions                                  |  |
| IS10               | TLO:SCL      | Clock Low Time                | 100 kHz mode              | 4.7                                                                                                                                                         | _       | μs | Device must operate at a minimum of 1.5 MHz |  |
|                    |              |                               | 400 kHz mode              | 1.3                                                                                                                                                         | _       | μs | Device must operate at a minimum of 10 MHz  |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0.5                                                                                                                                                         | _       | μS | _                                           |  |
| IS11               | THI:SCL      | Clock High Time               | 100 kHz mode              | 4.0                                                                                                                                                         | _       | μS | Device must operate at a minimum of 1.5 MHz |  |
|                    |              |                               | 400 kHz mode              | 0.6                                                                                                                                                         | _       | μs | Device must operate at a minimum of 10 MHz  |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0.5                                                                                                                                                         | _       | μs | _                                           |  |
| IS20               | TF:SCL       | SDAx and SCLx                 | 100 kHz mode              | _                                                                                                                                                           | 300     | ns | CB is specified to be from                  |  |
|                    |              | Fall Time                     | 400 kHz mode              | 20 + 0.1 CB                                                                                                                                                 | 300     | ns | 10 to 400 pF                                |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | _                                                                                                                                                           | 100     | ns |                                             |  |
| IS21               | TR:SCL       | SDAx and SCLx<br>Rise Time    | 100 kHz mode              | _                                                                                                                                                           | 1000    | ns | CB is specified to be from                  |  |
|                    |              |                               | 400 kHz mode              | 20 + 0.1 CB                                                                                                                                                 | 300     | ns | 10 to 400 pF                                |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | _                                                                                                                                                           | 300     | ns |                                             |  |
| IS25               | TSU:DAT      | Data Input<br>Setup Time      | 100 kHz mode              | 250                                                                                                                                                         | _       | ns | _                                           |  |
|                    |              |                               | 400 kHz mode              | 100                                                                                                                                                         | _       | ns |                                             |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 100                                                                                                                                                         | _       | ns |                                             |  |
| IS26               | THD:DAT      | Data Input<br>Hold Time       | 100 kHz mode              | 0                                                                                                                                                           | _       | μs | _                                           |  |
|                    |              |                               | 400 kHz mode              | 0                                                                                                                                                           | 0.9     | μs |                                             |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0                                                                                                                                                           | 0.3     | μs |                                             |  |
| IS30               | Tsu:sta      | Start Condition<br>Setup Time | 100 kHz mode              | 4.7                                                                                                                                                         | _       | μs | Only relevant for Repeated                  |  |
|                    |              |                               | 400 kHz mode              | 0.6                                                                                                                                                         | _       | μs | Start condition                             |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0.25                                                                                                                                                        |         | μs |                                             |  |
| IS31               | THD:STA      | Start Condition               | 100 kHz mode              | 4.0                                                                                                                                                         | _       | μs | After this period, the first                |  |
| 1001               |              | Hold Time                     | 400 kHz mode              | 0.6                                                                                                                                                         | _       | μs | clock pulse is generated                    |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0.25                                                                                                                                                        | _       | μS |                                             |  |
| IS33               |              | Stop Condition                | 100 kHz mode              | 4.7                                                                                                                                                         | _       | μs | _                                           |  |
|                    |              | Setup Time                    | 400 kHz mode              | 0.6                                                                                                                                                         |         | μs |                                             |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0.6                                                                                                                                                         |         | μs |                                             |  |
| IS34               | THD:ST       | Stop Condition<br>Hold Time   | 100 kHz mode              | 4000                                                                                                                                                        | _       | ns | _                                           |  |
| 0                  | 0            |                               | 400 kHz mode              | 600                                                                                                                                                         |         | ns |                                             |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 250                                                                                                                                                         |         | ns |                                             |  |
| IS40               | IS40 TAA:SCL | Output Valid<br>From Clock    | 100 kHz mode              | 0                                                                                                                                                           | 3500    | ns | _                                           |  |
|                    |              |                               | 400 kHz mode              | 0                                                                                                                                                           | 1000    | ns |                                             |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0                                                                                                                                                           | 350     | ns |                                             |  |
| IS45               | TBF:SDA      | 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         |  |
|                    |              |                               | 1 MHz mode <sup>(1)</sup> | 0.5                                                                                                                                                         | _       | μs | our start                                   |  |
| IS50               | Св           | Bus Capacitive Lo             | ading                     | _                                                                                                                                                           | 400     | pF | _                                           |  |

Note 1: Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only).

FIGURE 28-23: ADC CONVERSION (10-BIT MODE) TIMING CHARACTERISTICS (CHPS<1:0> = 01, SIMSAM = 0, ASAM = 0, SSRC<2:0> = 000)



FIGURE 28-24: ADC CONVERSION (10-BIT MODE) TIMING CHARACTERISTICS (CHPS<1:0> = 01, SIMSAM = 0, ASAM = 1, SSRC<2:0> = 111, SAMC<4:0> = 00001)



# 28-Lead Plastic Quad Flat, No Lead Package (MM) – 6x6x0.9 mm Body [QFN-S] 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  |  |  |
| Number of Pins         |                  | 28          |          |      |  |  |
| Pitch                  | е                | 0.65 BSC    |          |      |  |  |
| Overall Height         | A                | 0.80        | 0.90     | 1.00 |  |  |
| Standoff               | A1               | 0.00        | 0.02     | 0.05 |  |  |
| Contact Thickness      | A3               |             | 0.20 REF |      |  |  |
| Overall Width          | E                | 6.00 BSC    |          |      |  |  |
| Exposed Pad Width      | E2               | 3.65        | 3.70     | 4.70 |  |  |
| Overall Length         | D                |             | 6.00 BSC |      |  |  |
| Exposed Pad Length     | D2               | 3.65        | 3.70     | 4.70 |  |  |
| Contact Width          | b                | 0.23        | 0.38     | 0.43 |  |  |
| Contact Length         | L                | 0.30        | 0.40     | 0.50 |  |  |
| Contact-to-Exposed Pad | К                | 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-124B

# **INDEX**

| A                                                           |          | D                                         |            |
|-------------------------------------------------------------|----------|-------------------------------------------|------------|
| A/D Converter                                               | 227      | Data Address Space                        | 27         |
| DMA                                                         | 227      | Alignment                                 | 27         |
| Initialization                                              | 227      | Memory Map for PIC24HJ128GP202/204 and    |            |
| Key Features                                                |          | PIC24HJ64GP202/204 Devices                |            |
| AC Characteristics                                          |          | with 8 KB RAM                             | 29         |
| ADC Module                                                  |          | Memory Map for PIC24HJ32GP302/304 Devices |            |
| ADC Module (10-bit Mode)                                    |          | with 4 KB RAM                             |            |
| ADC Module (12-bit Mode)                                    |          | Near Data Space                           |            |
| Internal RC Accuracy                                        |          | Software Stack                            |            |
| Load Conditions                                             | 306, 348 | Width                                     | 27         |
| ADC Module                                                  | 26       | DC and AC Characteristics                 | 255        |
| ADC11 Register Map  Alternate Interrupt Vector Table (AIVT) |          | Graphs and Tables  DC Characteristics     |            |
| Arithmetic Logic Unit (ALU)                                 |          | Doze Current (IDOZE)                      |            |
| Assembler                                                   | 20       | High Temperature                          |            |
| MPASM Assembler                                             | 292      | I/O Pin Input Specifications              |            |
|                                                             |          | I/O Pin Output                            |            |
| В                                                           |          | I/O Pin Output Specifications             |            |
| Block Diagrams                                              |          | Idle Current (IDOZE)                      |            |
| 16-bit Timer1 Module                                        | 161      | Idle Current (IIDLE)                      |            |
| A/D Module                                                  |          | Operating Current (IDD)                   |            |
| Connections for On-Chip Voltage Regulator                   |          | Operating MIPS vs. Voltage                |            |
| Device Clock                                                | 119, 121 | Power-Down Current (IPD)                  |            |
| ECAN Module                                                 | 201      | Power-down Current (IPD)                  |            |
| Input Capture                                               | 171      | Program Memory30                          | 5, 347     |
| Output Compare                                              |          | Temperature and Voltage                   | 346        |
| PIC24HJ32GP302/304, PIC24HJ64GPX02                          |          | Temperature and Voltage Specifications    | 297        |
| PIC24HJ128GPX02/X04                                         |          | Thermal Operating Conditions              |            |
| PIC24HJ32GP302/304, PIC24HJ64GPX02                          |          | Development Support                       | 291        |
| PIC24HJ128GPX02/X04 CPU Core                                |          | DMA Module                                |            |
| PLL                                                         |          | DMA Register Map                          |            |
| Reset System                                                |          | DMAC Registers                            |            |
| Shared Port Structure<br>SPI                                |          | DMAxCNT                                   |            |
| Timer2 (16-bit)                                             |          | DMAxCON                                   |            |
| Timer2 (10-bit)                                             |          | DMAxPEO                                   |            |
| UART                                                        |          | DMAxREQ<br>DMAxSTA                        |            |
| Watchdog Timer (WDT)                                        |          | DMAXSTA                                   |            |
|                                                             |          | Doze Mode                                 |            |
| C                                                           |          | Doze Wode                                 | 150        |
| C Compilers                                                 |          | E                                         |            |
| MPLAB C18                                                   | 292      | ECAN Module                               |            |
| Clock Switching                                             | 128      | CiBUFPNT1 register                        | 213        |
| Enabling                                                    | 128      | CiBUFPNT2 register                        |            |
| Sequence                                                    | 128      | CiBUFPNT3 register                        |            |
| Code Examples                                               |          | CiBUFPNT4 register                        | 215        |
| Erasing a Program Memory Page                               |          | CiCFG1 register                           | 211        |
| Initiating a Programming Sequence                           |          | CiCFG2 register                           | 212        |
| Loading Write Buffers                                       |          | CiCTRL1 register                          | 204        |
| Port Write/Read                                             |          | CiCTRL2 register                          |            |
| PWRSAV Instruction Syntax                                   |          | CiEC register                             |            |
| Code Protection                                             |          | CiFCTRL register                          |            |
| Configuration Bits                                          |          | CiFEN1 register                           |            |
| Configuration Register Map                                  |          | CiFIFO register                           |            |
| Configuring Analog Port Pins                                | 136      | CiFMSKSEL1 register                       |            |
| CPU Control Register                                        | 04       | CiFMSKSEL2 register                       |            |
| Control Register                                            |          | CilNTE register                           |            |
| CPU Clocking System                                         |          | CiDYE-EID register                        |            |
| PLL Configuration                                           |          | CiRXFnEID register                        |            |
| Selection                                                   |          | CiRXFnSID register                        |            |
| Sources  Customer Change Notification Service               |          | CiRXFUL1 register                         |            |
| Customer Notification Service                               |          | CiRXFUL2 register                         |            |
| Customer Support                                            |          | CiRXMnEID register<br>CiRXMnSID register  |            |
| Cactomer Support                                            |          | CiRXOVF1 register                         | 219<br>221 |