

#### 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 -</u> <u>Microcontrollers</u>"

#### Details

| Details                    |                                                                                |
|----------------------------|--------------------------------------------------------------------------------|
| 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              | 21                                                                             |
| Program Memory Size        | 64KB (22K x 24)                                                                |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                | -                                                                              |
| RAM Size                   | 8K x 8                                                                         |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                      |
| Data Converters            | A/D 10x10b/12b                                                                 |
| Oscillator Type            | Internal                                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                              |
| Mounting Type              | Surface Mount                                                                  |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                                 |
| Supplier Device Package    | 28-SOIC                                                                        |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic24hj64gp202t-i-so |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

## 7.0 INTERRUPT CONTROLLER

- **Note 1:** This data sheet summarizes the features the PIC24HJ32GP302/304. of 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 32. "Interrupts (Part III)" (DS70214) of the"dsPIC33F/PIC24H Family Reference Manual", which is available from the Microchip web site (www.microchip.com).
  - 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 interrupt controller reduces the numerous peripheral interrupt request signals to a single interrupt request signal to the PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 CPU.

The interrupt controller has the following features:

- Up to eight processor exceptions and software traps
- Eight user-selectable priority levels
- Interrupt Vector Table (IVT) with up to 118 vectors
- A unique vector for each interrupt or exception source
- Fixed priority within a specified user priority level
- Alternate Interrupt Vector Table (AIVT) for debug support
- Fixed interrupt entry and return latencies

## 7.1 Interrupt Vector Table

The Interrupt Vector Table (IVT), shown in Figure 7-1, resides in program memory, starting at location 000004h. The IVT contains 126 vectors consisting of eight nonmaskable trap vectors plus up to 118 sources of interrupt. In general, each interrupt source has its own vector. Each interrupt vector contains a 24 bit wide address. The value programmed into each interrupt vector location is the starting address of the associated Interrupt Service Routine (ISR).

Interrupt vectors are prioritized in terms of their natural priority. This priority is linked to their position in the vector table. Lower addresses generally have a higher natural priority. For example, the interrupt associated with vector 0 takes priority over interrupts at any other vector address.

PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 devices implement up to 45 unique interrupts and five nonmaskable traps. These are summarized in Table 7-1.

#### 7.1.1 ALTERNATE INTERRUPT VECTOR TABLE

The Alternate Interrupt Vector Table (AIVT) is located after the IVT, as shown in Figure 7-1. Access to the AIVT is provided by the ALTIVT control bit (INTCON2<15>). If the ALTIVT bit is set, all interrupt and exception processes use the alternate vectors instead of the default vectors. The alternate vectors are organized in the same manner as the default vectors.

The AIVT supports debugging by providing a means to switch between an application and a support environment without requiring the interrupt vectors to be reprogrammed. This feature also enables switching between applications for evaluation of different software algorithms at run time. If the AIVT is not needed, the AIVT should be programmed with the same addresses used in the IVT.

## 7.2 Reset Sequence

A device Reset is not a true exception because the interrupt controller is not involved in the Reset process. The PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 device clears its registers in response to a Reset, which forces the PC to zero. The microcontroller then begins program execution at location 0x000000. A GOTO instruction at the Reset address can redirect program execution to the appropriate start-up routine.

**Note:** Any unimplemented or unused vector locations in the IVT and AIVT should be programmed with the address of a default interrupt handler routine that contains a RESET instruction.

| Vector<br>Number | IVT Address       | AIVT Address      | Interrupt Source              |  |  |
|------------------|-------------------|-------------------|-------------------------------|--|--|
| 55-68            | 0x000072-0x00008C | 0x000172-0x00018C | Reserved                      |  |  |
| 69               | 0x00008E          | 0x00018E          | DMA5 – DMA Channel 5          |  |  |
| 70               | 0x000090          | 0x000190          | RTCC – Real Time Clock        |  |  |
| 71-72            | 0x000092-0x000094 | 0x000192-0x000194 | Reserved                      |  |  |
| 73               | 0x000096          | 0x000196          | U1E – UART1 Error             |  |  |
| 74               | 0x000098          | 0x000198          | U2E – UART2 Error             |  |  |
| 75               | 0x00009A          | 0x00019A          | CRC – CRC Generator Interrupt |  |  |
| 76               | 0x00009C          | 0x00019C          | DMA6 – DMA Channel 6          |  |  |
| 77               | 0x00009E          | 0x00019E          | DMA7 – DMA Channel 7          |  |  |
| 78               | 0x0000A0          | 0x0001A0          | C1TX – ECAN1 TX Data Request  |  |  |
| 79-126           | 0x0000A2-0x0000FE | 0x0001A2-0x0001FE | Reserved                      |  |  |

#### TABLE 7-1: INTERRUPT VECTORS (CONTINUED)

| REGISTER              | 27-4: INTC                                                                                                                       | CON2: INTERR                                                                                                                     | UPT CONT                          | ROL REGIST       | ER 2             |                 |        |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------------|------------------|-----------------|--------|
| R/W-0                 | R-0                                                                                                                              | U-0                                                                                                                              | U-0                               | U-0              | U-0              | U-0             | U-0    |
| ALTIVT                | DISI                                                                                                                             | _                                                                                                                                | _                                 | —                | —                | —               | _      |
| bit 15                |                                                                                                                                  |                                                                                                                                  |                                   |                  |                  |                 | bit 8  |
| U-0                   | U-0                                                                                                                              | U-0                                                                                                                              | U-0                               | U-0              | R/W-0            | R/W-0           | R/W-0  |
| _                     | _                                                                                                                                | _                                                                                                                                | _                                 | —                | INT2EP           | INT1EP          | INT0EP |
| bit 7                 |                                                                                                                                  | ·                                                                                                                                |                                   |                  |                  |                 | bit C  |
|                       |                                                                                                                                  |                                                                                                                                  |                                   |                  |                  |                 |        |
| Legend:<br>R = Readab | ole bit                                                                                                                          | W = Writable                                                                                                                     | bit                               | U = Unimpler     | mented bit, read | as '0'          |        |
| -n = Value a          | at POR                                                                                                                           | '1' = Bit is set                                                                                                                 | t                                 | '0' = Bit is cle |                  | x = Bit is unkr | nown   |
| bit 14                | 1 <b>= Use alt</b><br>0 <b>= Use sta</b><br><b>DISI:</b> DISI<br>1 <b>=</b> DISI ir                                              | nable Alternate Ir<br>ernate vector tab<br>andard (default) v<br>Instruction Statu<br>nstruction is activ<br>nstruction is not a | le<br>vector table<br>is bit<br>e |                  |                  |                 |        |
| bit 13-3              | Unimplemented: Read as '0'                                                                                                       |                                                                                                                                  |                                   |                  |                  |                 |        |
| bit 2                 | 1 = Interrup                                                                                                                     | xternal Interrupt 2<br>ot on negative ed<br>ot on positive edg                                                                   | ge                                | t Polarity Selec | t bit            |                 |        |
| bit 1                 | INT1EP: External Interrupt 1 Edge Detect Polarity Select bit<br>1 = Interrupt on negative edge<br>0 = Interrupt on positive edge |                                                                                                                                  |                                   |                  |                  |                 |        |
| bit 0                 | <b>INTOEP:</b> External Interrupt 0 Edge Detect Polarity Select bit                                                              |                                                                                                                                  |                                   |                  |                  |                 |        |

## REGISTER 7-4: INTCON2: INTERRUPT CONTROL REGISTER 2

1 = Interrupt on negative edge 0 = Interrupt on positive edge

| REGISTER 9-                                                              | -4: OSCTUN: FRC OSCILLATOR TUNING REGISTER <sup>(2)</sup> |                                                     |               |                  |                      |                 |       |  |  |
|--------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------|---------------|------------------|----------------------|-----------------|-------|--|--|
| U-0                                                                      | U-0                                                       | U-0                                                 | U-0           | U-0              | U-0                  | U-0             | U-0   |  |  |
| _                                                                        | _                                                         |                                                     |               |                  | _                    | _               | _     |  |  |
| bit 15                                                                   |                                                           |                                                     |               |                  |                      |                 | bit 8 |  |  |
|                                                                          |                                                           |                                                     |               |                  |                      |                 |       |  |  |
| U-0                                                                      | U-0                                                       | R/W-0                                               | R/W-0         | R/W-0            | R/W-0                | R/W-0           | R/W-0 |  |  |
| _                                                                        | —                                                         |                                                     |               | TUN              | <5:0> <sup>(1)</sup> |                 |       |  |  |
| bit 7                                                                    |                                                           |                                                     |               |                  |                      |                 | bit 0 |  |  |
|                                                                          |                                                           |                                                     |               |                  |                      |                 |       |  |  |
| Legend:                                                                  |                                                           |                                                     |               |                  |                      |                 |       |  |  |
| R = Readable                                                             | bit                                                       | W = Writable bit U = Unimplemented bit, read as '0' |               |                  |                      |                 |       |  |  |
| -n = Value at P                                                          | OR                                                        | '1' = Bit is set                                    |               | '0' = Bit is cle | ared                 | x = Bit is unkr | nown  |  |  |
|                                                                          |                                                           |                                                     |               |                  |                      |                 |       |  |  |
| bit 15-6                                                                 | 5-6 Unimplemented: Read as '0'                            |                                                     |               |                  |                      |                 |       |  |  |
| bit 5-0 <b>TUN&lt;5:0&gt;:</b> FRC Oscillator Tuning bits <sup>(1)</sup> |                                                           |                                                     |               |                  |                      |                 |       |  |  |
|                                                                          | 111111 = Center frequency -0.375% (7.345 MHz)             |                                                     |               |                  |                      |                 |       |  |  |
|                                                                          | •                                                         |                                                     |               |                  |                      |                 |       |  |  |
|                                                                          | •                                                         |                                                     |               |                  |                      |                 |       |  |  |
|                                                                          | •                                                         |                                                     | 44.0050/ /0.5 |                  |                      |                 |       |  |  |
|                                                                          | 100001 = Center frequency -11.625% (6.52 MHz)             |                                                     |               |                  |                      |                 |       |  |  |
|                                                                          | 100000 = Center frequency -12% (6.49 MHz)                 |                                                     |               |                  |                      |                 |       |  |  |

Note 1: OSCTUN functionality has been provided to help customers compensate for temperature effects on the

FRC frequency over a wide range of temperatures. The tuning step size is an approximation and is neither

| <ol><li>This register is reset only on a Power-on Reset (POI</li></ol> |
|------------------------------------------------------------------------|
|------------------------------------------------------------------------|

011111 = Center frequency +11.625% (8.23 MHz) 011110 = Center frequency +11.25% (8.20 MHz)

000001 = Center frequency +0.375% (7.40 MHz) 000000 = Center frequency (7.37 MHz nominal)

•

characterized nor tested.

| U-0                | U-0                          | U-0                                                                     | R/W-1      | R/W-1            | R/W-1           | R/W-1           | R/W-1 |  |
|--------------------|------------------------------|-------------------------------------------------------------------------|------------|------------------|-----------------|-----------------|-------|--|
| _                  | —                            | _                                                                       | IC8R<4:0>  |                  |                 |                 |       |  |
| it 15              |                              |                                                                         |            |                  |                 |                 | bit 8 |  |
| U-0                | U-0                          | U-0                                                                     | R/W-1      | R/W-1            | R/W-1           | R/W-1           | R/W-1 |  |
| —                  |                              | _                                                                       |            |                  | IC7R<4:0>       |                 |       |  |
| oit 7              |                              |                                                                         | •          |                  |                 |                 | bit C |  |
| Legend:            |                              |                                                                         |            |                  |                 |                 |       |  |
| R = Readabl        | e bit                        | W = Writable                                                            | bit        | U = Unimplei     | mented bit, rea | ad as '0'       |       |  |
| -n = Value at      | POR                          | '1' = Bit is set                                                        |            | '0' = Bit is cle | eared           | x = Bit is unkr | nown  |  |
|                    | •<br>•<br>•                  |                                                                         |            |                  |                 |                 |       |  |
|                    | •<br>00001 = Inpu            |                                                                         |            |                  |                 |                 |       |  |
| hit 7 E            | 00000 = Inpu                 |                                                                         | o <b>'</b> |                  |                 |                 |       |  |
| bit 7-5<br>bit 4-0 | IC7R<4:0>: A<br>11111 = Inpu | nted: Read as '<br>Assign Input Ca<br>ut tied to Vss<br>ut tied to RP25 |            | to the correspo  | onding RPn pir  | ı               |       |  |
|                    | •                            |                                                                         |            |                  |                 |                 |       |  |
|                    | 00001 = Inpu<br>00000 = Inpu |                                                                         |            |                  |                 |                 |       |  |

## REGISTER 11-6: RPINR10: PERIPHERAL PIN SELECT INPUT REGISTERS 10

## REGISTER 11-19: RPOR4: PERIPHERAL PIN SELECT OUTPUT REGISTERS 4

| U-0 | U-0              | R/W-0                                     | R/W-0                                        | R/W-0                                                                                                                                                    | R/W-0                                                                                                                                                                                                           | R/W-0                                                                                                                                                       |
|-----|------------------|-------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _   | —                |                                           |                                              | RP9R<4:0>                                                                                                                                                | •                                                                                                                                                                                                               |                                                                                                                                                             |
|     |                  |                                           |                                              |                                                                                                                                                          |                                                                                                                                                                                                                 | bit 8                                                                                                                                                       |
|     |                  |                                           |                                              |                                                                                                                                                          |                                                                                                                                                                                                                 |                                                                                                                                                             |
| U-0 | U-0              | R/W-0                                     | R/W-0                                        | R/W-0                                                                                                                                                    | R/W-0                                                                                                                                                                                                           | R/W-0                                                                                                                                                       |
| —   | —                | RP8R<4:0>                                 |                                              |                                                                                                                                                          |                                                                                                                                                                                                                 |                                                                                                                                                             |
|     |                  |                                           |                                              |                                                                                                                                                          |                                                                                                                                                                                                                 | bit 0                                                                                                                                                       |
|     |                  |                                           |                                              |                                                                                                                                                          |                                                                                                                                                                                                                 |                                                                                                                                                             |
|     |                  |                                           |                                              |                                                                                                                                                          |                                                                                                                                                                                                                 |                                                                                                                                                             |
| it  | W = Writable     | le bit U = Unimplemented bit, read as '0' |                                              |                                                                                                                                                          | ad as '0'                                                                                                                                                                                                       |                                                                                                                                                             |
| DR  | '1' = Bit is set | t '0' = Bit is cleared x = Bit is unknown |                                              | nown                                                                                                                                                     |                                                                                                                                                                                                                 |                                                                                                                                                             |
|     |                  |                                           | <br>U-0 U-0 R/W-0<br><br>it W = Writable bit | —         —         —           U-0         U-0         R/W-0           —         —         —           it         W = Writable bit         U = Unimpler | —         —         RP9R<4:0>           U-0         U-0         R/W-0         R/W-0           —         —         —         RP8R<4:0>           it         W = Writable bit         U = Unimplemented bit, real | —         —         RP9R<4:0>           U-0         U-0         R/W-0         R/W-0         R/W-0           —         —         RP8R<4:0>         RP8R<4:0> |

bit 15-13 Unimplemented: Read as '0'

bit 12-8 **RP9R<4:0>:** Peripheral Output Function is Assigned to RP9 Output Pin bits (see Table 11-2 for peripheral function numbers)

bit 7-5 Unimplemented: Read as '0'

bit 4-0 **RP8R<4:0>:** Peripheral Output Function is Assigned to RP8 Output Pin bits (see Table 11-2 for peripheral function numbers)

#### REGISTER 11-20: RPOR5: PERIPHERAL PIN SELECT OUTPUT REGISTERS 5

| U-0    | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0      | R/W-0 | R/W-0 |  |
|--------|-----|-----|-------|-------|------------|-------|-------|--|
| —      | —   | —   |       |       | RP11R<4:0> |       |       |  |
| bit 15 |     |     | bit 8 |       |            |       |       |  |

| U-0   | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0      | R/W-0 | R/W-0 |
|-------|-----|-----|-------|-------|------------|-------|-------|
| —     | —   | —   |       |       | RP10R<4: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-13 Unimplemented: Read as '0'

bit 12-8 **RP11R<4:0>:** Peripheral Output Function is Assigned to RP11 Output Pin bits (see Table 11-2 for peripheral function numbers)

bit 7-5 Unimplemented: Read as '0'

bit 4-0 **RP10R<4:0>:** Peripheral Output Function is Assigned to RP10 Output Pin bits (see Table 11-2 for peripheral function numbers)

The Timer2/3 and Timer4/5 modules can operate in one of the following modes:

- Timer mode
- · Gated Timer mode
- Synchronous Counter mode

In Timer and Gated Timer modes, the input clock is derived from the internal instruction cycle clock (FcY). In Synchronous Counter mode, the input clock is derived from the external clock input at TxCK pin.

The timer modes are determined by the following bits:

- TCS (TxCON<1>): Timer Clock Source Control bit
- TGATE (TxCON<6>): Timer Gate Control bit

Timer control bit settings for different operating modes are given in the Table 13-1.

| TABLE 13-1:TIMER MODE SETTINGS |
|--------------------------------|
|--------------------------------|

| Mode                | TCS | TGATE |
|---------------------|-----|-------|
| Timer               | 0   | 0     |
| Gated timer         | 0   | 1     |
| Synchronous counter | 1   | Х     |

## 13.1 16-Bit Operation

To configure any of the timers for individual 16-bit operation:

- 1. Clear the T32 bit corresponding to that timer.
- 2. Select the timer prescaler ratio using the TCKPS<1:0> bits.
- 3. Set the Clock and Gating modes using the TCS and TGATE bits.
- 4. Load the timer period value into the PRx register.
- 5. If interrupts are required, set the interrupt enable bit, TxIE. Use the priority bits, TxIP<2:0>, to set the interrupt priority.
- 6. Set the TON bit.

| Note: | Only Timer2 and Timer3 can trigger a |
|-------|--------------------------------------|
|       | DMA data transfer.                   |

## 13.2 32-Bit Operation

A 32-bit timer module can be formed by combining a Type B and a Type C 16-bit timer module. For 32-bit timer operation, the T32 control bit in the Type B Timer Control register (TxCON<3>) must be set. The Type C timer holds the most significant word (msw) and the Type B timer holds the least significant word (lsw) for 32-bit operation.

When configured for 32-bit operation, only the Type B Timer Control register (TxCON) bits are required for setup and control. Type C timer control register bits are ignored (except TSIDL bit).

For interrupt control, the combined 32-bit timer uses the interrupt enable, interrupt flag and interrupt priority control bits of the Type C timer. The interrupt control and status bits for the Type B timer are ignored during 32-bit timer operation.

The Type B and Type C timers that can be combined to form a 32-bit timer are listed in Table 13-2.

#### TABLE 13-2: 32-BIT TIMER

| TYPE B Timer (Isw) | TYPE C Timer (msw) |
|--------------------|--------------------|
| Timer2             | Timer3             |
| Timer4             | Timer5             |

A block diagram representation of the 32-bit timer module is shown in Figure 13-3. The 32-timer module can operate in one of the following modes:

- Timer mode
- · Gated Timer mode
- · Synchronous Counter mode

To configure the features of Timer2/3 or Timer4/5 for 32-bit operation:

- 1. Set the T32 control bit.
- 2. Select the prescaler ratio for Timer2 or Timer4 using the TCKPS<1:0> bits.
- 3. Set the Clock and Gating modes using the corresponding TCS and TGATE bits.
- 4. Load the timer period value. PR3 or PR5 contains the most significant word of the value, while PR2 or PR4 contains the least significant word.
- If interrupts are required, set the interrupt enable bits, T3IE or T5IE. Use the priority bits, T3IP<2:0> or T5IP<2:0> to set the interrupt priority. While Timer2 or Timer4 controls the timer, the interrupt appears as a Timer3 or Timer5 interrupt.
- 6. Set the corresponding TON bit.

The timer value at any point is stored in the register pair, TMR3:TMR2 or TMR5:TMR4, which always contains the most significant word of the count, while TMR2 or TMR4 contains the least significant word.

## 15.2 Output Compare Resources

Many useful resources related to Output Compare 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/wwwproducts/ Devices.aspx?dDocName=en532315

#### 15.2.1 KEY RESOURCES

- Section 13. "Output Compare" (DS70209)
- Code Samples
- Application Notes
- Software Libraries
- Webinars
- All related dsPIC33F/PIC24H Family Reference Manuals Sections
- Development Tools

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

| U-0          | U-0                                             | U-0                                                                | U-0           | U-0               | U-0                | U-0             | U-0   |  |  |  |
|--------------|-------------------------------------------------|--------------------------------------------------------------------|---------------|-------------------|--------------------|-----------------|-------|--|--|--|
|              | _                                               | _                                                                  | _             | _                 | _                  |                 | _     |  |  |  |
| bit 15       |                                                 |                                                                    |               |                   |                    |                 | bit 8 |  |  |  |
|              |                                                 |                                                                    |               |                   |                    |                 |       |  |  |  |
| R/W-0        | R/W-0                                           | R/W-0                                                              | U-0           | R/W-0             | R/W-0              | R/W-0           | R/W-0 |  |  |  |
| IVRIE        | WAKIE                                           | ERRIE                                                              |               | FIFOIE            | RBOVIE             | RBIE            | TBIE  |  |  |  |
| bit 7        |                                                 |                                                                    |               |                   |                    |                 | bit 0 |  |  |  |
| Legend:      |                                                 | C = Writeable                                                      | bit, but only | '0' can be writte | en to clear the bi | it              |       |  |  |  |
| R = Readab   | le bit                                          | W = Writable                                                       |               |                   | mented bit, read   |                 |       |  |  |  |
| -n = Value a | It POR                                          | '1' = Bit is set                                                   |               | '0' = Bit is cle  | ared               | x = Bit is unkr | nown  |  |  |  |
|              |                                                 |                                                                    |               |                   |                    |                 |       |  |  |  |
| bit 15-8     |                                                 | nted: Read as '                                                    |               |                   |                    |                 |       |  |  |  |
| bit 7        |                                                 | d Message Rec                                                      |               | pt Enable bit     |                    |                 |       |  |  |  |
|              |                                                 | Request Enable                                                     |               |                   |                    |                 |       |  |  |  |
| L:1 0        | •                                               | Request not en                                                     |               | 1 h 14            |                    |                 |       |  |  |  |
| bit 6        |                                                 | Wake-up Activi<br>Request Enable                                   |               | lag bit           |                    |                 |       |  |  |  |
|              |                                                 | Request not en                                                     |               |                   |                    |                 |       |  |  |  |
| bit 5        |                                                 | r Interrupt Enab                                                   |               |                   |                    |                 |       |  |  |  |
|              |                                                 | Request Enable                                                     |               |                   |                    |                 |       |  |  |  |
|              |                                                 | Request not en                                                     |               |                   |                    |                 |       |  |  |  |
| bit 4        | Unimpleme                                       | nted: Read as '                                                    | 0'            |                   |                    |                 |       |  |  |  |
| bit 3        | FIFOIE: FIFO                                    | O Almost Full In                                                   | terrupt Enabl | e bit             |                    |                 |       |  |  |  |
|              |                                                 | 1 = Interrupt Request Enabled                                      |               |                   |                    |                 |       |  |  |  |
|              | •                                               | Request not en                                                     |               |                   |                    |                 |       |  |  |  |
| bit 2        | RBOVIE: RX Buffer Overflow Interrupt Enable bit |                                                                    |               |                   |                    |                 |       |  |  |  |
|              | •                                               | 1 = Interrupt Request Enabled                                      |               |                   |                    |                 |       |  |  |  |
| bit 1        |                                                 | = Interrupt Request not enabled                                    |               |                   |                    |                 |       |  |  |  |
| DILI         |                                                 | BIE: RX Buffer Interrupt Enable bit<br>= Interrupt Request Enabled |               |                   |                    |                 |       |  |  |  |
|              |                                                 | Request not en                                                     |               |                   |                    |                 |       |  |  |  |
|              |                                                 |                                                                    |               |                   |                    |                 |       |  |  |  |
| bit 0        |                                                 | <b>TBIE:</b> TX Buffer Interrupt Enable bit                        |               |                   |                    |                 |       |  |  |  |
| bit U        |                                                 | Request Enable                                                     |               |                   |                    |                 |       |  |  |  |

| R/W-0        | R-0                                                                                                                                                     | R-0                                                                                                             | R-0                            | R/W-0            | R/W-0             | R/W-0           | R/W-0         |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------|------------------|-------------------|-----------------|---------------|--|--|--|
| TXENn        | TXABTn                                                                                                                                                  | TXLARBn                                                                                                         | TXERRn                         | TXREQn           | RTRENn            | TXnPF           | RI<1:0>       |  |  |  |
| bit 15       |                                                                                                                                                         |                                                                                                                 |                                |                  |                   | •               | bit 8         |  |  |  |
|              |                                                                                                                                                         |                                                                                                                 |                                |                  |                   |                 |               |  |  |  |
| R/W-0        | R-0                                                                                                                                                     | R-0                                                                                                             | R-0                            | R/W-0            | R/W-0             | R/W-0           | R/W-0         |  |  |  |
| TXENm        | TXABTm <sup>(1)</sup>                                                                                                                                   | TXLARBm <sup>(1)</sup>                                                                                          | TXERRm <sup>(1)</sup>          | TXREQm           | RTRENm            | TXmPF           | RI<1:0>       |  |  |  |
| bit 7        |                                                                                                                                                         |                                                                                                                 |                                |                  |                   |                 | bit (         |  |  |  |
| Legend:      |                                                                                                                                                         | C = Writeable                                                                                                   | bit but only '(                | )' can be writte | en to clear the b | it              |               |  |  |  |
| R = Readab   | le bit                                                                                                                                                  | W = Writable                                                                                                    | -                              |                  | nented bit, read  |                 |               |  |  |  |
| -n = Value a |                                                                                                                                                         | '1' = Bit is set                                                                                                |                                | '0' = Bit is cle |                   | x = Bit is unkr | nown          |  |  |  |
|              |                                                                                                                                                         |                                                                                                                 |                                |                  |                   |                 |               |  |  |  |
| bit 15-8     | See Definitior                                                                                                                                          | n for Bits 7-0, C                                                                                               | Controls Buffer                | n                |                   |                 |               |  |  |  |
| bit 7        |                                                                                                                                                         | RX Buffer Sele                                                                                                  |                                |                  |                   |                 |               |  |  |  |
|              | 1 = Buffer TR                                                                                                                                           | Bn is a transm                                                                                                  | it buffer                      |                  |                   |                 |               |  |  |  |
|              | 0 = Buffer TR                                                                                                                                           | Bn is a receive                                                                                                 | e buffer                       |                  |                   |                 |               |  |  |  |
| bit 6        | TXABTm: Me                                                                                                                                              | essage Aborted                                                                                                  | d bit <sup>(1)</sup>           |                  |                   |                 |               |  |  |  |
|              | 1 = Message                                                                                                                                             |                                                                                                                 |                                |                  |                   |                 |               |  |  |  |
|              | -                                                                                                                                                       | -                                                                                                               | nsmission succ                 | -                |                   |                 |               |  |  |  |
| bit 5        |                                                                                                                                                         | 0                                                                                                               | Arbitration bit <sup>(1)</sup> |                  |                   |                 |               |  |  |  |
|              |                                                                                                                                                         |                                                                                                                 | while being se                 |                  |                   |                 |               |  |  |  |
| 1.1.4        |                                                                                                                                                         |                                                                                                                 | bitration while                |                  |                   |                 |               |  |  |  |
| bit 4        |                                                                                                                                                         |                                                                                                                 | uring Transmis                 |                  |                   |                 |               |  |  |  |
|              |                                                                                                                                                         | bus error occurred while the message was being sent<br>bus error did not occur while the message was being sent |                                |                  |                   |                 |               |  |  |  |
| bit 3        |                                                                                                                                                         | essage Send F                                                                                                   |                                | sage was bei     | ng sent           |                 |               |  |  |  |
|              |                                                                                                                                                         | -                                                                                                               | -                              | bit automatica   | ally clears when  | the message i   | s successfull |  |  |  |
|              | 0 = Clearing t                                                                                                                                          | he bit to '0' wh                                                                                                | ile set request                | s a message a    | abort             |                 |               |  |  |  |
| bit 2        | RTRENm: Au                                                                                                                                              | ito-Remote Tra                                                                                                  | ansmit Enable I                | bit              |                   |                 |               |  |  |  |
|              | <ul> <li>1 = When a remote transmit is received, TXREQ will be set</li> <li>0 = When a remote transmit is received, TXREQ will be unaffected</li> </ul> |                                                                                                                 |                                |                  |                   |                 |               |  |  |  |
| bit 1-0      | TXmPRI<1:0>: Message Transmission Priority bits                                                                                                         |                                                                                                                 |                                |                  |                   |                 |               |  |  |  |
|              | 11 = Highest                                                                                                                                            | 11 = Highest message priority                                                                                   |                                |                  |                   |                 |               |  |  |  |
|              | •                                                                                                                                                       | ermediate mes                                                                                                   | • • •                          |                  |                   |                 |               |  |  |  |
|              | 01 = Low inte                                                                                                                                           | rmediate mess                                                                                                   | sage priority                  |                  |                   |                 |               |  |  |  |
|              |                                                                                                                                                         | message priori                                                                                                  |                                |                  |                   |                 |               |  |  |  |

#### ~ .

The buffers, SID, EID, DLC, Data Field and Receive Status registers are located in DMA RAM. Note:

## 20.0 10-BIT/12-BIT ANALOG-TO-DIGITAL CONVERTER (ADC1)

- Note 1: This data sheet summarizes the features PIC24HJ32GP302/304, of the PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 of families devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 16. "Analog-to-Digital Converter (ADC)" (DS70183) 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 PIC24HJ32GP302/304, PIC24HJ64GPX02/X04 and PIC24HJ128GPX02/X04 devices have up to 13 ADC input channels.

The AD12B bit (AD1CON1<10>) allows each of the ADC modules to be configured by the user as either a 10-bit, 4-sample/hold ADC (default configuration) or a 12-bit, 1-sample/hold ADC.

Note: The ADC module needs to be disabled before modifying the AD12B bit.

## 20.1 Key Features

The 10-bit ADC configuration has the following key features:

- Successive Approximation (SAR) conversion
- Conversion speeds of up to 1.1 Msps
- Up to 13 analog input pins
- External voltage reference input pins
- Simultaneous sampling of up to four analog input pins
- Automatic Channel Scan mode
- Selectable conversion trigger source
- Selectable Buffer Fill modes
- · Operation during CPU Sleep and Idle modes

The 12-bit ADC configuration supports all the above features, except:

- In the 12-bit configuration, conversion speeds of up to 500 ksps are supported
- There is only one sample/hold amplifier in the 12-bit configuration, so simultaneous sampling of multiple channels is not supported.

Depending on the particular device pinout, the ADC can have up to 13 analog input pins, designated AN0 through AN12. In addition, there are two analog input pins for external voltage reference connections. These voltage reference inputs can be shared with other analog input pins. The actual number of analog input pins and external voltage reference input configuration depends on the specific device.

Block diagrams of the ADC module are shown in Figure 20-1 and Figure 20-2.

## 20.2 ADC Initialization

The following configuration steps should be performed.

- 1. Configure the ADC module:
  - a) Select port pins as analog inputs (AD1PCFGH<15:0> or AD1PCFGL<15:0>)
  - b) Select voltage reference source to match expected range on analog inputs (AD1CON2<15:13>)
  - c) Select the analog conversion clock to match desired data rate with processor clock (AD1CON3<7:0>)
  - d) Determine how many S/H channels are used (AD1CON2<9:8> and AD1PCFGH<15:0> or AD1PCFGL<15:0>)
  - e) Select the appropriate sample/conversion sequence (AD1CON1<7:5> and AD1CON3<12:8>)
  - f) Select how conversion results are presented in the buffer (AD1CON1<9:8>)
  - g) Turn on ADC module (AD1CON1<15>)
- 2. Configure ADC interrupt (if required):
  - a) Clear the AD1IF bit
  - b) Select ADC interrupt priority

## 20.3 ADC and DMA

If more than one conversion result needs to be buffered before triggering an interrupt, DMA data transfers can be used. ADC1 can trigger a DMA data transfer. If ADC1 is selected as the DMA IRQ source, a DMA transfer occurs when the AD1IF bit gets set as a result of an ADC1 sample conversion sequence.

The SMPI<3:0> bits (AD1CON2<5:2>) are used to select how often the DMA RAM buffer pointer is incremented.

The ADDMABM bit (AD1CON1<12>) determines how the conversion results are filled in the DMA RAM buffer area being used for ADC. If this bit is set, DMA buffers are written in the order of conversion. The module provides an address to the DMA channel that is the same as the address used for the non-DMA stand-alone buffer. If the ADDMABM bit is cleared, then DMA buffers are written in Scatter/Gather mode. The module provides a scatter/gather address to the DMA channel, based on the index of the analog input and the size of the DMA buffer.

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

#### **REGISTER 22-6: RTCVAL (WHEN RTCPTR<1:0> =** 01): **WKDYHR: WEEKDAY AND HOURS VALUE REGISTER<sup>(1)</sup>**

| U-0    | U-0 | U-0   | U-0   | U-0   | R/W-x   | R/W-x     | R/W-x   |
|--------|-----|-------|-------|-------|---------|-----------|---------|
| 0-0    | 0-0 | 0-0   | 0-0   | 0-0   | N/ VV-X |           | FV/VV-X |
| —      | —   |       | _     | _     |         | WDAY<2:0> |         |
| bit 15 |     |       |       |       |         |           | bit 8   |
|        |     |       |       |       |         |           |         |
| U-0    | U-0 | R/W-x | R/W-x | R/W-x | R/W-x   | R/W-x     | R/W-x   |

| U-0   | U-0 | R/W-x      | R/W-x | R/W-x      | R/W-x | R/W-x | R/W-x |
|-------|-----|------------|-------|------------|-------|-------|-------|
| —     | —   | HRTEN<1:0> |       | HRONE<3:0> |       |       |       |
| bit 7 |     |            |       |            |       |       | bit 0 |

| Legend:           |                  |                       |                    |
|-------------------|------------------|-----------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit | t, read as '0'     |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared  | x = Bit is unknown |

| bit 15-11 | Unimplemented: Read as '0'                                                                |
|-----------|-------------------------------------------------------------------------------------------|
| bit 10-8  | WDAY<2:0>: Binary Coded Decimal Value of Weekday Digit; contains a value from 0 to 6      |
| bit 7-6   | Unimplemented: Read as '0'                                                                |
| bit 5-4   | HRTEN<1:0>: Binary Coded Decimal Value of Hour's Tens Digit; contains a value from 0 to 2 |
| bit 3-0   | HRONE<3:0>: Binary Coded Decimal Value of Hour's Ones Digit; contains a value from 0 to 9 |

**Note 1:** A write to this register is only allowed when RTCWREN = 1.

## **REGISTER 22-7: RTCVAL (WHEN RTCPTR<1:0> =** 00): **MINUTES AND SECONDS VALUE REGISTER**

| U-0    | R/W-x       | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x   | R/W-x |
|--------|-------------|-------|-------|-------|-------|---------|-------|
| —      | MINTEN<2:0> |       |       |       | MINON | IE<3:0> |       |
| bit 15 |             |       |       |       |       |         | bit 8 |
|        |             |       |       |       |       |         |       |
| U-0    | R/W-x       | R/W-x | R/W-x | R/W-x | R/W-x | R/W-x   | R/W-x |
|        | SECTEN<2:0> |       |       |       | SECON | IE<3:0> |       |

| Legend:           |                  |                        |                    |
|-------------------|------------------|------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, | read as '0'        |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared   | x = Bit is unknown |

| bit 15    | Unimplemented: Read as '0'                                                                   |
|-----------|----------------------------------------------------------------------------------------------|
| bit 14-12 | MINTEN<2:0>: Binary Coded Decimal Value of Minute's Tens Digit; contains a value from 0 to 5 |
| bit 11-8  | MINONE<3:0>: Binary Coded Decimal Value of Minute's Ones Digit; contains a value from 0 to 9 |
| bit 7     | Unimplemented: Read as '0'                                                                   |
| bit 6-4   | SECTEN<2:0>: Binary Coded Decimal Value of Second's Tens Digit; contains a value from 0 to 5 |
| bit 3-0   | SECONE<3:0>: Binary Coded Decimal Value of Second's Ones Digit; contains a value from 0 to 9 |

bit 7

bit 0

| TADLE 23-2.  |          |             |                                                                                                                                                                                                                         |  |  |
|--------------|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit Field    | Register | RTSP Effect | Description                                                                                                                                                                                                             |  |  |
| WDTPRE       | FWDT     | Immediate   | Watchdog Timer Prescaler bit<br>1 = 1:128<br>0 = 1:32                                                                                                                                                                   |  |  |
| WDTPOST<3:0> | FWDT     | Immediate   | Watchdog Timer Postscaler bits<br>1111 = 1:32,768<br>1110 = 1:16,384<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•                                                                                   |  |  |
| FPWRT<2:0>   | FPOR     | Immediate   | Power-on Reset Timer Value Select bits<br>111 = PWRT = 128 ms<br>110 = PWRT = 64 ms<br>101 = PWRT = 32 ms<br>100 = PWRT = 16 ms<br>011 = PWRT = 8 ms<br>010 = PWRT = 4 ms<br>001 = PWRT = 2 ms<br>000 = PWRT = Disabled |  |  |
| ALTI2C       | FPOR     | Immediate   | Alternate $I^2C^{TM}$ pins<br>1 = $I^2C$ mapped to SDA1/SCL1 pins<br>0 = $I^2C$ mapped to ASDA1/ASCL1 pins                                                                                                              |  |  |
| JTAGEN       | FICD     | Immediate   | JTAG Enable bit<br>1 = JTAG enabled<br>0 = JTAG disabled                                                                                                                                                                |  |  |
| ICS<1:0>     | FICD     | Immediate   | ICD Communication Channel Select bits<br>11 = Communicate on PGEC1 and PGED1<br>10 = Communicate on PGEC2 and PGED2<br>01 = Communicate on PGEC3 and PGED3<br>00 = Reserved, do not use                                 |  |  |

### TABLE 25-2: PIC24H CONFIGURATION BITS DESCRIPTION (CONTINUED)

**Note 1:** This Configuration register is not available on PIC24HJ32GP302/304 devices.

## TABLE 25-3: CODE FLASH SECURITY SEGMENT SIZES FOR 32 KB DEVICES

| CONFIG BITS          | BSS<2:0> = x11 0K                                                                                                                                                                                                                  | BSS<2:0> = x10 1K                                                                                                                                                                                           | BSS<2:0> = x01 4K                                                                                                                                                                                                                                                                     | BSS<2:0> = x00 8K                                                                                                                                                                              |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| SSS<2:0> = x11<br>0K | VS = 256 IW         0x00000h<br>0x0001FEh<br>0x000200h<br>0x0007FEh<br>0x000800h<br>0x001FFEh<br>0x002000h<br>0x001FFEh<br>0x002000h<br>0x003FFEh<br>0x004000h<br>0x0057FEh           GS = 11008 IW         0x0157FEh<br>0x0157FEh | VS = 256 IW         0x000000h<br>0x0001FEh<br>0x000200h           BS = 768 IW         0x0007FEh<br>0x000800h           GS = 10240 IW         0x003FFEh<br>0x004000h           0x00157FEh         0x00157FEh | VS = 256 IW         0x00000h<br>0x0001FEh<br>0x000200h<br>0x0007FEh<br>0x000800h           BS = 3840 IW         0x000200h<br>0x001FFEh<br>0x000800h           GS = 7168 IW         0x003FFEh<br>0x004000h           0x0057FEh         0x0057FEh           0x0057FEh         0x0157FEh | VS = 256 IW         0x00000h<br>0x0001FEh<br>0x000200h<br>0x0007FEh<br>0x00080h<br>0x001FFEh<br>0x00200h           GS = 3072 IW         0x003FFEh<br>0x00400h<br>0x0057FEh           0x0157FEh |  |

| TABLE 26-2 | INSTRUCTION SET OVERVIEW | (CONTINUED) |  |
|------------|--------------------------|-------------|--|
|            |                          |             |  |

| Base<br>Instr<br># Assembly<br>Mnemonic |        |        | Assembly Syntax | Description                                       | # of<br>Words | # of<br>Cycles | Status Flags<br>Affected |
|-----------------------------------------|--------|--------|-----------------|---------------------------------------------------|---------------|----------------|--------------------------|
| 35                                      | INC    | INC    | f               | f = f + 1                                         | 1             | 1              | C,DC,N,OV,Z              |
|                                         |        | INC    | f,WREG          | WREG = f + 1                                      | 1             | 1              | C,DC,N,OV,Z              |
|                                         |        | INC    | Ws,Wd           | Wd = Ws + 1                                       | 1             | 1              | C,DC,N,OV,Z              |
| 36                                      | INC2   | INC2   | f               | f = f + 2                                         | 1             | 1              | C,DC,N,OV,Z              |
|                                         |        | INC2   | f,WREG          | WREG = f + 2                                      | 1             | 1              | C,DC,N,OV,Z              |
|                                         |        | INC2   | Ws,Wd           | Wd = Ws + 2                                       | 1             | 1              | C,DC,N,OV,Z              |
| 37                                      | IOR    | IOR    | f               | f = f .IOR. WREG                                  | 1             | 1              | N,Z                      |
|                                         |        | IOR    | f,WREG          | WREG = f .IOR. WREG                               | 1             | 1              | N,Z                      |
|                                         |        | IOR    | #lit10,Wn       | Wd = lit10 .IOR. Wd                               | 1             | 1              | N,Z                      |
|                                         |        | IOR    | Wb,Ws,Wd        | Wd = Wb .IOR. Ws                                  | 1             | 1              | N,Z                      |
|                                         |        | IOR    | Wb,#lit5,Wd     | Wd = Wb .IOR. lit5                                | 1             | 1              | N,Z                      |
| 38                                      | LNK    | LNK    | #lit14          | Link Frame Pointer                                | 1             | 1              | None                     |
| 39                                      | LSR    | LSR    | f               | f = Logical Right Shift f                         | 1             | 1              | C,N,OV,Z                 |
|                                         |        | LSR    | f,WREG          | WREG = Logical Right Shift f                      | 1             | 1              | C,N,OV,Z                 |
|                                         |        | LSR    | Ws,Wd           | Wd = Logical Right Shift Ws                       | 1             | 1              | C,N,OV,Z                 |
|                                         |        | LSR    | Wb,Wns,Wnd      | Wnd = Logical Right Shift Wb by Wns               | 1             | 1              | N,Z                      |
|                                         |        | LSR    | Wb,#lit5,Wnd    | Wnd = Logical Right Shift Wb by lit5              | 1             | 1              | N,Z                      |
| 40                                      | MOV    | MOV    | f,Wn            | Move f to Wn                                      | 1             | 1              | None                     |
|                                         |        | MOV    | f               | Move f to f                                       | 1             | 1              | None                     |
|                                         |        | MOV    | f,WREG          | Move f to WREG                                    | 1             | 1              | N,Z                      |
|                                         |        | MOV    | #lit16,Wn       | Move 16-bit literal to Wn                         | 1             | 1              | None                     |
|                                         |        | MOV.b  | #lit8,Wn        | Move 8-bit literal to Wn                          | 1             | 1              | None                     |
|                                         |        | MOV    | Wn,f            | Move Wn to f                                      | 1             | 1              | None                     |
|                                         |        | MOV    | Wso,Wdo         | Move Ws to Wd                                     | 1             | 1              | None                     |
|                                         |        | MOV    | WREG, f         | Move WREG to f                                    | 1             | 1              | None                     |
|                                         |        | MOV.D  | Wns,Wd          | Move Double from W(ns):W(ns + 1) to Wd            | 1             | 2              | None                     |
|                                         |        | MOV.D  | Ws, Wnd         | Move Double from Ws to W(nd + 1):W(nd)            | 1             | 2              | None                     |
| 41                                      | MUL    | MUL.SS | Wb,Ws,Wnd       | {Wnd + 1, Wnd} = signed(Wb) * signed(Ws)          | 1             | 1              | None                     |
|                                         |        | MUL.SU | Wb,Ws,Wnd       | {Wnd + 1, Wnd} = signed(Wb) * unsigned(Ws)        | 1             | 1              | None                     |
|                                         |        | MUL.US | Wb,Ws,Wnd       | {Wnd + 1, Wnd} = unsigned(Wb) * signed(Ws)        | 1             | 1              | None                     |
|                                         |        | MUL.UU | Wb,Ws,Wnd       | {Wnd + 1, Wnd} = unsigned(Wb) *<br>unsigned(Ws)   | 1             | 1              | None                     |
|                                         |        | MUL.SU | Wb,#lit5,Wnd    | {Wnd + 1, Wnd} = signed(Wb) * unsigned(lit5)      | 1             | 1              | None                     |
|                                         |        | MUL.UU | Wb,#lit5,Wnd    | {Wnd + 1, Wnd} = unsigned(Wb) *<br>unsigned(lit5) | 1             | 1              | None                     |
|                                         |        | MUL    | f               | W3:W2 = f * WREG                                  | 1             | 1              | None                     |
| 42                                      | NEG    | NEG    | f               | $f = \overline{f} + 1$                            | 1             | 1              | C,DC,N,OV,Z              |
|                                         |        | NEG    | f,WREG          | WREG = $\overline{f}$ + 1                         | 1             | 1              | C,DC,N,OV,Z              |
|                                         |        | NEG    | Ws,Wd           | $Wd = \overline{Ws} + 1$                          | 1             | 1              | C,DC,N,OV,Z              |
| 43                                      | NOP    | NOP    |                 | No Operation                                      | 1             | 1              | None                     |
|                                         |        | NOPR   |                 | No Operation                                      | 1             | 1              | None                     |
| 44                                      | POP    | POP    | f               | Pop f from Top-of-Stack (TOS)                     | 1             | 1              | None                     |
|                                         |        | POP    | Wdo             | Pop from Top-of-Stack (TOS) to Wdo                | 1             | 1              | None                     |
|                                         |        | POP.D  | Wnd             | Pop from Top-of-Stack (TOS) to                    | 1             | 2              | None                     |
|                                         |        | 101.0  | ma              | W(nd):W(nd + 1)                                   | •             | -              | 10110                    |
|                                         |        | POP.S  |                 | Pop Shadow Registers                              | 1             | 1              | All                      |
| 45                                      | PUSH   | PUSH   | f               | Push f to Top-of-Stack (TOS)                      | 1             | 1              | None                     |
|                                         |        | PUSH   | Wso             | Push Wso to Top-of-Stack (TOS)                    | 1             | 1              | None                     |
|                                         |        | PUSH.D | Wns             | Push W(ns):W(ns + 1) to Top-of-Stack (TOS)        | 1             | 2              | None                     |
|                                         |        | PUSH.S |                 | Push Shadow Registers                             | 1             | 1              | None                     |
| 46                                      | PWRSAV | PWRSAV | #lit1           | Go into Sleep or Idle mode                        | 1             | 1              | WDTO,Sleep               |
| 47                                      | RCALL  | RCALL  | Expr            | Relative Call                                     | 1             | 2              | None                     |
|                                         |        | RCALL  | Wn              | Computed Call                                     | 1             | 2              | None                     |

| TABLE 28-32: | SPIX SLAVE MODE (FULL-DUPLEX, CKE = 1, CKP = 0, SMP = 0) TIMING |
|--------------|-----------------------------------------------------------------|
|              | REQUIREMENTS                                                    |

|              |                       |                                                               | 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<br>No. | Symbol                | Characteristic <sup>(1)</sup>                                 | Min                                                                                                                                                                                      | Тур <sup>(2)</sup> | Max | Units | Conditions                    |  |
| SP70         | TscP                  | Maximum SCK Input Frequency                                   | —                                                                                                                                                                                        | _                  | 15  | MHz   | See Note 3                    |  |
| SP72         | TscF                  | SCKx Input Fall Time                                          | —                                                                                                                                                                                        | _                  | —   | ns    | See parameter DO32 and Note 4 |  |
| SP73         | TscR                  | SCKx Input Rise Time                                          | —                                                                                                                                                                                        |                    |     | ns    | See parameter DO31 and Note 4 |  |
| SP30         | TdoF                  | SDOx Data Output Fall Time                                    | —                                                                                                                                                                                        |                    | —   | ns    | See parameter DO32 and Note 4 |  |
| SP31         | TdoR                  | SDOx Data Output Rise Time                                    | —                                                                                                                                                                                        | _                  | —   | ns    | See parameter DO31 and Note 4 |  |
| SP35         | TscH2doV,<br>TscL2doV | SDOx Data Output Valid after<br>SCKx Edge                     | —                                                                                                                                                                                        | 6                  | 20  | ns    | —                             |  |
| SP36         | TdoV2scH,<br>TdoV2scL | SDOx Data Output Setup to<br>First SCKx Edge                  | 30                                                                                                                                                                                       | _                  | —   | ns    | —                             |  |
| SP40         | TdiV2scH,<br>TdiV2scL | Setup Time of SDIx Data Input to SCKx Edge                    | 30                                                                                                                                                                                       | _                  | —   | ns    | —                             |  |
| SP41         | TscH2diL,<br>TscL2diL | Hold Time of SDIx Data Input to SCKx Edge                     | 30                                                                                                                                                                                       | _                  | _   | ns    | —                             |  |
| SP50         | TssL2scH,<br>TssL2scL | $\overline{SSx} \downarrow $ to SCKx $\uparrow$ or SCKx Input | 120                                                                                                                                                                                      |                    | —   | ns    | _                             |  |
| SP51         | TssH2doZ              | SSx                                                           | 10                                                                                                                                                                                       | _                  | 50  | ns    | —                             |  |
| SP52         | TscH2ssH<br>TscL2ssH  | SSx after SCKx Edge                                           | 1.5 Tcy + 40                                                                                                                                                                             | _                  | _   | ns    | See Note 4                    |  |
| SP60         | TssL2doV              | SDOx Data Output Valid after<br>SSx Edge                      | —                                                                                                                                                                                        | _                  | 50  | ns    | —                             |  |

**Note 1:** These parameters are characterized, but are not tested in manufacturing.

**2:** Data in "Typ" column is at 3.3V, 25°C unless otherwise stated.

**3:** The minimum clock period for SCKx is 66.7 ns. Therefore, the SCK clock generated by the Master must not violate this specification.

**4:** Assumes 50 pF load on all SPIx pins.

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

## TABLE 29-7: DC CHARACTERISTICS: PROGRAM MEMORY

| DC CHARACTERISTICS |        |                               | Standard Operating Conditions: 3.0V to 3.6V(unless otherwise stated)Operating temperature-40°C ≤TA ≤+150°C for High Temperature |     |     |       |                                                                  |
|--------------------|--------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------|------------------------------------------------------------------|
| Param<br>No.       | Symbol | Characteristic <sup>(1)</sup> | Min                                                                                                                             | Тур | Мах | Units | Conditions                                                       |
|                    |        | Program Flash Memory          |                                                                                                                                 |     |     |       |                                                                  |
| HD130              | Eр     | Cell Endurance                | 10,000                                                                                                                          | _   | _   | E/W   | -40° C to +150° C <sup>(2)</sup>                                 |
| HD134              | TRETD  | Characteristic Retention      | 20                                                                                                                              | _   | _   | Year  | 1000 E/W cycles or less and no other specifications are violated |

**Note 1:** These parameters are assured by design, but are not characterized or tested in manufacturing.

**2:** Programming of the Flash memory is allowed up to 150°C.

NOTES:

# 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 |  |  |  |
|------------------------|------------------|----------|----------|-------------|--|--|--|
| Dimensio               | Dimension Limits |          |          |             |  |  |  |
| Number of Pins         | Ν                | 28       |          |             |  |  |  |
| Pitch                  | е                |          | 0.65 BSC |             |  |  |  |
| Overall Height         | А                | 0.80     | 0.90     | 1.00        |  |  |  |
| Standoff               | A1               | 0.00     | 0.02     | 0.05        |  |  |  |
| Contact Thickness      | A3               | 0.20 REF |          |             |  |  |  |
| Overall Width          | E                | 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

NOTES: