# E·XFL



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                      | 32MHz                                                                         |
| Connectivity               | I <sup>2</sup> C, PMP, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, LVD, POR, PWM, WDT                                    |
| Number of I/O              | 21                                                                            |
| Program Memory Size        | 32KB (11K x 24)                                                               |
| Program Memory Type        | FLASH                                                                         |
| EEPROM Size                | -                                                                             |
| RAM Size                   | 8K x 8                                                                        |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 3.6V                                                                     |
| Data Converters            | A/D 10x10b                                                                    |
| Oscillator Type            | Internal                                                                      |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                            |
| Mounting Type              | Through Hole                                                                  |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                       |
| Supplier Device Package    | 28-SPDIP                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic24fj32ga002-e-sp |

Email: info@E-XFL.COM

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

# TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

#### Most Current Data Sheet

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

#### http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Web site; http://www.microchip.com
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

#### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

#### TABLE 4-8: OUTPUT COMPARE REGISTER MAP

|              |      |        | •••••  |        | LOIOI  |        |        |          |           |             |          |       |       |        |       |       |       |               |
|--------------|------|--------|--------|--------|--------|--------|--------|----------|-----------|-------------|----------|-------|-------|--------|-------|-------|-------|---------------|
| File<br>Name | Addr | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9    | Bit 8     | Bit 7       | Bit 6    | Bit 5 | Bit 4 | Bit 3  | Bit 2 | Bit 1 | Bit 0 | All<br>Resets |
| OC1RS        | 0180 |        |        |        |        |        |        | Output 0 | Compare 1 | Secondary   | Register |       |       |        |       |       |       | FFFF          |
| OC1R         | 0182 |        |        |        |        |        |        | Οι       | tput Comp | are 1 Regis | ter      |       |       |        |       |       |       | FFFF          |
| OC1CON       | 0184 | _      | —      | OCSIDL | _      | _      | —      | —        | _         | _           | —        | —     | OCFLT | OCTSEL | OCM2  | OCM1  | OCM0  | 0000          |
| OC2RS        | 0186 |        |        |        |        |        |        | Output 0 | Compare 2 | Secondary   | Register |       |       |        |       |       |       | FFFF          |
| OC2R         | 0188 |        |        |        |        |        |        | Οι       | tput Comp | are 2 Regis | ter      |       |       |        |       |       |       | FFFF          |
| OC2CON       | 018A | _      | _      | OCSIDL | _      | _      | _      | _        | _         | _           | _        | _     | OCFLT | OCTSEL | OCM2  | OCM1  | OCM0  | 0000          |
| OC3RS        | 018C |        |        |        |        |        |        | Output 0 | Compare 3 | Secondary   | Register |       |       |        |       |       |       | FFFF          |
| OC3R         | 018E |        |        |        |        |        |        | Οι       | tput Comp | are 3 Regis | ter      |       |       |        |       |       |       | FFFF          |
| OC3CON       | 0190 | _      | _      | OCSIDL | _      | _      | _      | _        | _         | _           | _        | _     | OCFLT | OCTSEL | OCM2  | OCM1  | OCM0  | 0000          |
| OC4RS        | 0192 |        |        |        |        |        |        | Output 0 | Compare 4 | Secondary   | Register |       |       |        |       |       |       | FFFF          |
| OC4R         | 0194 |        |        |        |        |        |        | Οι       | tput Comp | are 4 Regis | ter      |       |       |        |       |       |       | FFFF          |
| OC4CON       | 0196 | _      | _      | OCSIDL | _      | _      | _      | _        | _         | _           | _        | _     | OCFLT | OCTSEL | OCM2  | OCM1  | OCM0  | 0000          |
| OC5RS        | 0198 |        |        |        |        |        |        | Output ( | Compare 5 | Secondary   | Register |       |       |        |       |       |       | FFFF          |
| OC5R         | 019A |        |        |        |        |        |        | Οι       | tput Comp | are 5 Regis | ter      |       |       |        |       |       |       | FFFF          |
| OC5CON       | 019C | _      | _      | OCSIDL | _      | _      | —      | —        | —         | _           | —        | —     | OCFLT | OCTSEL | OCM2  | OCM1  | OCM0  | 0000          |

**Legend:** — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

### TABLE 4-9: I<sup>2</sup>C<sup>™</sup> REGISTER MAP

|              | -    |         |        |         |        |        |        |        |       |       |       |            |             |              |       |       |       |               |
|--------------|------|---------|--------|---------|--------|--------|--------|--------|-------|-------|-------|------------|-------------|--------------|-------|-------|-------|---------------|
| File<br>Name | Addr | Bit 15  | Bit 14 | Bit 13  | Bit 12 | Bit 11 | Bit 10 | Bit 9  | Bit 8 | Bit 7 | Bit 6 | Bit 5      | Bit 4       | Bit 3        | Bit 2 | Bit 1 | Bit 0 | All<br>Resets |
| I2C1RCV      | 0200 | _       |        | —       | _      | _      | _      | —      | —     |       |       |            | I2C1 Recei  | ve Register  |       |       |       | 0000          |
| I2C1TRN      | 0202 | _       | _      | _       | _      | _      | _      | _      | _     |       |       |            | I2C1 Transr | nit Register | r     |       |       | OOFF          |
| I2C1BRG      | 0204 | _       | _      | _       | _      | _      | _      | _      |       |       |       | Baud Rate  | Generator   | Register 1   |       |       |       | 0000          |
| I2C1CON      | 0206 | I2CEN   | _      | I2CSIDL | SCLREL | IPMIEN | A10M   | DISSLW | SMEN  | GCEN  | STREN | ACKDT      | ACKEN       | RCEN         | PEN   | RSEN  | SEN   | 1000          |
| I2C1STAT     | 0208 | ACKSTAT | TRSTAT | _       | _      | _      | BCL    | GCSTAT | ADD10 | IWCOL | I2COV | D/A        | Р           | S            | R/W   | RBF   | TBF   | 0000          |
| I2C1ADD      | 020A | _       | _      | _       | _      | _      | _      |        |       |       |       | I2C1 Addre | ss Register |              |       |       |       | 0000          |
| I2C1MSK      | 020C | _       | _      | _       | _      | _      | _      | AMSK9  | AMSK8 | AMSK7 | AMSK6 | AMSK5      | AMSK4       | AMSK3        | AMSK2 | AMSK1 | AMSK0 | 0000          |
| I2C2RCV      | 0210 | _       | —      | _       | _      | _      | _      | _      | _     |       |       |            | I2C2 Receiv | ve Register  |       |       |       | 0000          |
| I2C2TRN      | 0212 | _       | —      | _       | _      | _      | _      | _      | _     |       |       |            | I2C2 Transr | nit Register | r     |       |       | OOFF          |
| I2C2BRG      | 0214 | _       | —      | _       | _      | _      | _      | _      |       |       |       | Baud Rate  | Generator   | Register 2   |       |       |       | 0000          |
| I2C2CON      | 0216 | I2CEN   | —      | I2CSIDL | SCLREL | IPMIEN | A10M   | DISSLW | SMEN  | GCEN  | STREN | ACKDT      | ACKEN       | RCEN         | PEN   | RSEN  | SEN   | 1000          |
| I2C2STAT     | 0218 | ACKSTAT | TRSTAT | _       | _      | _      | BCL    | GCSTAT | ADD10 | IWCOL | I2COV | D/A        | Р           | S            | R/W   | RBF   | TBF   | 0000          |
| I2C2ADD      | 021A | _       |        | _       | _      | _      | _      |        | •     |       | •     | I2C2 Addre | ss Register |              | •     | •     | •     | 0000          |
| I2C2MSK      | 021C | _       |        | _       | _      | _      | —      | AMSK9  | AMSK8 | AMSK7 | AMSK6 | AMSK5      | AMSK4       | AMSK3        | AMSK2 | AMSK1 | AMSK0 | 0000          |

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

| R/SO-0            | R/W-0                                                                                                    | R/W-0                                                                                | U-0                                                                                     | U-0                                                                     | U-0                               | U-0                            | U-0                            |
|-------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------|--------------------------------|--------------------------------|
| WR                | WREN                                                                                                     | WRERR                                                                                | —                                                                                       | —                                                                       | —                                 | —                              | —                              |
| bit 15            |                                                                                                          |                                                                                      |                                                                                         |                                                                         |                                   |                                | bit 8                          |
|                   |                                                                                                          |                                                                                      |                                                                                         | DAALO                                                                   | DAMA                              | DAMA                           | DAMO                           |
| U-0               | R/W-0                                                                                                    | U-0                                                                                  | U-0                                                                                     | R/W-0<br>NVMOP3 <sup>(1)</sup>                                          | R/W-0<br>NVMOP2 <sup>(1)</sup>    | R/W-0<br>NVMOP1 <sup>(1)</sup> | R/W-0<br>NVMOP0 <sup>(1)</sup> |
|                   | ERASE                                                                                                    | —                                                                                    | —                                                                                       | NVMOP3                                                                  | NVMOP207                          | NVMOP1**                       |                                |
| bit 7             |                                                                                                          |                                                                                      |                                                                                         |                                                                         |                                   |                                | bit                            |
| Legend:           |                                                                                                          | SO = Settable                                                                        | Only bit                                                                                |                                                                         |                                   |                                |                                |
| R = Reada         | able bit                                                                                                 | W = Writable                                                                         | bit                                                                                     | U = Unimplem                                                            | nented bit, read                  | as '0'                         |                                |
| -n = Value        | at POR                                                                                                   | '1' = Bit is set                                                                     |                                                                                         | '0' = Bit is clea                                                       | ared                              | x = Bit is unkr                | iown                           |
| bit 14<br>bit 13  | 0 = Program<br>WREN: Write<br>1 = Enables<br>0 = Inhibits F<br>WRERR: Writ<br>1 = An impro-<br>automatic | Flash program/<br>lash program/e<br>te Sequence E<br>oper program<br>cally on any se | tion is complet<br>erase operation<br>rror Flag bit<br>or erase seq<br>t attempt of the | e and inactive<br>ns<br>is<br>uence attempt<br>WR bit)                  | or terminatio                     | n has occurre                  | ed (bit is s                   |
| 1 1 40 7          |                                                                                                          | ram or erase o                                                                       |                                                                                         | leted normally                                                          |                                   |                                |                                |
| bit 12-7<br>bit 6 | =                                                                                                        | ted: Read as '<br>e/Program Ena                                                      |                                                                                         |                                                                         |                                   |                                |                                |
| DIL O             | 1 = Performs                                                                                             | the erase ope                                                                        | ration specified                                                                        | l by the NVMOI<br>fied by the NVM                                       |                                   |                                |                                |
| bit 5-4           | Unimplemen                                                                                               | ted: Read as '                                                                       | )'                                                                                      |                                                                         |                                   |                                |                                |
| bit 3-0           | NVMOP<3:0>                                                                                               | -: NVM Operat                                                                        | ion Select bits <sup>(</sup>                                                            | 1)                                                                      |                                   |                                |                                |
|                   | 0011 = Memo<br>0010 = Memo                                                                               | ory word progra                                                                      | m operation (E<br>operation (ER                                                         | SE = 1) or no o<br>ERASE = 0) or 1<br>ASE = 1) or no<br>RASE = 0) or no | no operation (E<br>operation (ER/ | RASE = 1)<br>ASE = 0)          |                                |
| Note 1:           | All other combina                                                                                        | tions of NVMO                                                                        | P<3:0> are uni                                                                          | implemented.                                                            |                                   |                                |                                |
| 2:                | Available in ICSP                                                                                        |                                                                                      |                                                                                         |                                                                         |                                   |                                |                                |

#### REGISTER 5-1: NVMCON: FLASH MEMORY CONTROL REGISTER

# **REGISTER 6-1: RCON: RESET CONTROL REGISTER<sup>(1)</sup> (CONTINUED)**

- bit 2 IDLE: Wake-up from Idle Flag bit 1 = Device has been in Idle mode
  - 0 = Device has not been in Idle mode
- bit 1 BOR: Brown-out Reset Flag bit
  - 1 = A Brown-out Reset has occurred (note that BOR is also set after a Power-on Reset)
  - 0 = A Brown-out Reset has not occurred
- bit 0 **POR:** Power-on Reset Flag bit
  - 1 = A Power-on Reset has occurred
  - 0 = A Power-on Reset has not occurred
- **Note 1:** All of the Reset status bits may be set or cleared in software. Setting one of these bits in software does not cause a device Reset.
  - 2: If the FWDTEN Configuration bit is '1' (unprogrammed), the WDT is always enabled, regardless of the SWDTEN bit setting.

| Flag Bit          | Setting Event                                     | Clearing Event          |
|-------------------|---------------------------------------------------|-------------------------|
| TRAPR (RCON<15>)  | Trap Conflict Event                               | POR                     |
| IOPUWR (RCON<14>) | Illegal Opcode or Uninitialized W Register Access | POR                     |
| CM (RCON<9>)      | Configuration Mismatch Reset                      | POR                     |
| EXTR (RCON<7>)    | MCLR Reset                                        | POR                     |
| SWR (RCON<6>)     | RESET Instruction                                 | POR                     |
| WDTO (RCON<4>)    | WDT Time-out                                      | PWRSAV Instruction, POR |
| SLEEP (RCON<3>)   | PWRSAV #SLEEP Instruction                         | POR                     |
| IDLE (RCON<2>)    | PWRSAV #IDLE Instruction                          | POR                     |
| BOR (RCON<1>)     | POR, BOR                                          | —                       |
| POR (RCON<0>)     | POR                                               | —                       |

#### TABLE 6-1: RESET FLAG BIT OPERATION

**Note:** All Reset flag bits may be set or cleared by the user software.

NOTES:

| U-0          | U-0           | R/W-0                             | R/W-0            | R/W-0             | R/W-0           | R/W-0           | R/W-0  |
|--------------|---------------|-----------------------------------|------------------|-------------------|-----------------|-----------------|--------|
| _            | —             | AD1IF                             | U1TXIF           | U1RXIF            | SPI1IF          | SPF1IF          | T3IF   |
| 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  |
| T2IF         | OC2IF         | IC2IF                             | _                | T1IF              | OC1IF           | IC1IF           | INTOIF |
| bit 7        | 002li         | 10211                             |                  |                   | 00111           | 10111           | bit    |
| Legend:      |               |                                   |                  |                   |                 |                 |        |
| R = Readab   | le bit        | W = Writable                      | bit              | U = Unimplem      | nented bit. rea | d as '0'        |        |
| -n = Value a | t POR         | '1' = Bit is set                  |                  | '0' = Bit is clea |                 | x = Bit is unkn | iown   |
|              |               |                                   |                  |                   |                 |                 |        |
| bit 15-14    | Unimpleme     | nted: Read as '                   | 0'               |                   |                 |                 |        |
| bit 13       | AD1IF: A/D    | Conversion Cor                    | nplete Interrup  | t Flag Status bit |                 |                 |        |
|              | 1 = Interrupt | request has oc<br>request has no  | curred           | U                 |                 |                 |        |
| bit 12       | •             | RT1 Transmitte                    |                  | Status bit        |                 |                 |        |
|              | 1 = Interrupt | request has oc                    | curred           |                   |                 |                 |        |
| L:1 4 4      | •             | request has no                    |                  |                   |                 |                 |        |
| oit 11       |               | RT1 Receiver li<br>request has oc |                  |                   |                 |                 |        |
|              |               | request has no                    |                  |                   |                 |                 |        |
| bit 10       | -             | 1 Event Interrup                  |                  | it                |                 |                 |        |
|              | 1 = Interrupt | request has oc<br>request has no  | curred           |                   |                 |                 |        |
| bit 9        |               | 1 Fault Interrup                  |                  | it                |                 |                 |        |
| bit 0        |               | request has oc                    | •                | it i              |                 |                 |        |
|              | •             | request has no                    |                  |                   |                 |                 |        |
| bit 8        | T3IF: Timer3  | B Interrupt Flag                  | Status bit       |                   |                 |                 |        |
|              |               | request has oc<br>request has no  |                  |                   |                 |                 |        |
| bit 7        | T2IF: Timer2  | 2 Interrupt Flag                  | Status bit       |                   |                 |                 |        |
|              | •             | request has oc                    |                  |                   |                 |                 |        |
| hit C        | •             | request has no                    |                  | nt Flag Status k  | .:+             |                 |        |
| bit 6        | -             | out Compare Ch<br>request has oc  |                  | pi riag Status i  | JIL             |                 |        |
|              | •             | request has no                    |                  |                   |                 |                 |        |
| bit 5        | IC2IF: Input  | Capture Chann                     | el 2 Interrupt F | lag Status bit    |                 |                 |        |
|              | •             | request has oc<br>request has no  |                  |                   |                 |                 |        |
| bit 4        | -             | nted: Read as '                   |                  |                   |                 |                 |        |
| bit 3        | -             | Interrupt Flag                    |                  |                   |                 |                 |        |
|              |               | request has oc                    |                  |                   |                 |                 |        |
|              |               | request has no                    |                  |                   |                 |                 |        |
| bit 2        | -             | out Compare Ch                    |                  | pt Flag Status b  | pit             |                 |        |
|              |               | request has oc                    |                  |                   |                 |                 |        |
|              |               | request has no                    |                  |                   |                 |                 |        |

### REGISTER 7-5: IFS0: INTERRUPT FLAG STATUS REGISTER 0

| U-0            | U-0              | R/W-0                             | R/W-0             | R/W-0             | R/W-0           | R/W-0           | R/W-0                 |
|----------------|------------------|-----------------------------------|-------------------|-------------------|-----------------|-----------------|-----------------------|
| _              | _                | AD1IE                             | U1TXIE            | U1RXIE            | SPI1IE          | SPF1IE          | T3IE                  |
| bit 15         |                  |                                   |                   | •                 |                 |                 | bit                   |
|                |                  |                                   |                   |                   |                 |                 |                       |
| R/W-0          | R/W-0            | R/W-0                             | U-0               | R/W-0             | R/W-0           | R/W-0           | R/W-0                 |
| T2IE           | OC2IE            | IC2IE                             | —                 | T1IE              | OC1IE           | IC1IE           | INT0IE <sup>(1)</sup> |
| bit 7          |                  |                                   |                   |                   |                 |                 | bit                   |
| Legend:        |                  |                                   |                   |                   |                 |                 |                       |
| R = Readable   | e bit            | W = Writable                      | bit               | U = Unimplem      | ented bit, read | l as '0'        |                       |
| -n = Value at  | POR              | '1' = Bit is set                  |                   | '0' = Bit is clea | red             | x = Bit is unkn | iown                  |
|                |                  |                                   |                   |                   |                 |                 |                       |
| bit 15-14      | -                | ted: Read as '                    |                   |                   |                 |                 |                       |
| bit 13         |                  |                                   | nplete Interrup   | t Enable bit      |                 |                 |                       |
|                | •                | equest is enab<br>equest is not e |                   |                   |                 |                 |                       |
| bit 12         | -                | -                                 | r Interrupt Enal  | hle hit           |                 |                 |                       |
|                |                  | equest is enab                    | •                 |                   |                 |                 |                       |
|                |                  | equest is not e                   |                   |                   |                 |                 |                       |
| bit 11         | U1RXIE: UAR      | RT1 Receiver In                   | nterrupt Enable   | e bit             |                 |                 |                       |
|                |                  | equest is enab<br>equest is not e |                   |                   |                 |                 |                       |
| bit 10         | -                | -                                 | olete Interrupt I | Enable bit        |                 |                 |                       |
|                |                  | equest is enab                    | •                 |                   |                 |                 |                       |
|                | •                | equest is not e                   |                   |                   |                 |                 |                       |
| bit 9          |                  | Fault Interrup                    |                   |                   |                 |                 |                       |
|                |                  | equest is enab<br>equest is not e |                   |                   |                 |                 |                       |
| bit 8          | -                | Interrupt Enab                    |                   |                   |                 |                 |                       |
|                |                  | equest is enab                    |                   |                   |                 |                 |                       |
|                | 0 = Interrupt r  | equest is not e                   | nabled            |                   |                 |                 |                       |
| bit 7          |                  | Interrupt Enab                    |                   |                   |                 |                 |                       |
|                | •                | equest is enab                    |                   |                   |                 |                 |                       |
| bit 6          | •                | equest is not e                   | annel 2 Interru   | unt Enable bit    |                 |                 |                       |
|                | -                | equest is enab                    |                   |                   |                 |                 |                       |
|                |                  | equest is not e                   |                   |                   |                 |                 |                       |
| bit 5          | IC2IE: Input C   | Capture Chann                     | el 2 Interrupt E  | nable bit         |                 |                 |                       |
|                | •                | equest is enab                    |                   |                   |                 |                 |                       |
| L:1 1          | -                | equest is not e                   |                   |                   |                 |                 |                       |
| bit 4<br>bit 3 | -                | ted: Read as '                    |                   |                   |                 |                 |                       |
| UIL J          | I IIE. IIIIief I | Interrupt Enab                    |                   |                   |                 |                 |                       |
|                | 1 = Interrupt r  | equest is enab                    | led               |                   |                 |                 |                       |

#### REGISTER 7-10: IEC0: INTERRUPT ENABLE CONTROL REGISTER 0

**Note 1:** If INTxIE = 1, this external interrupt input must be configured to an available RPn pin. See Section 10.4 "Peripheral Pin Select (PPS)" for more information.

|                    | R/W-1                                                                                                                                                                | R/W-0                                                                                                                                                                    | R/W-0                                                                                                  | U-0                                | R/W-1            | R/W-0           | R/W-0  |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------------|------------------|-----------------|--------|
|                    | T4IP2                                                                                                                                                                | T4IP1                                                                                                                                                                    | T4IP0                                                                                                  | _                                  | OC4IP2           | OC4IP1          | OC4IP0 |
| bit 15             |                                                                                                                                                                      |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 | bit 8  |
|                    |                                                                                                                                                                      |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 |        |
| U-0                | R/W-1                                                                                                                                                                | R/W-0                                                                                                                                                                    | R/W-0                                                                                                  | U-0                                | U-0              | U-0             | U-0    |
| <br>bit 7          | OC3IP2                                                                                                                                                               | OC3IP1                                                                                                                                                                   | OC3IP0                                                                                                 | _                                  | _                | _               | bit (  |
|                    |                                                                                                                                                                      |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 | Ditt   |
| Legend:            |                                                                                                                                                                      |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 |        |
| R = Readab         | ole bit                                                                                                                                                              | W = Writable                                                                                                                                                             | bit                                                                                                    | U = Unimplen                       | nented bit, read | d as '0'        |        |
| -n = Value a       | at POR                                                                                                                                                               | '1' = Bit is set                                                                                                                                                         |                                                                                                        | '0' = Bit is clea                  | ared             | x = Bit is unkr | nown   |
|                    |                                                                                                                                                                      |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 |        |
| bit 15             | Unimplemen                                                                                                                                                           | ted: Read as '                                                                                                                                                           | 0'                                                                                                     |                                    |                  |                 |        |
| bit 14-12          | <b>T4IP&lt;2:0&gt;:</b> ⊺i                                                                                                                                           | imer4 Interrupt                                                                                                                                                          | Priority bits                                                                                          |                                    |                  |                 |        |
|                    | 111 = Interrup                                                                                                                                                       | pt is Priority 7 (                                                                                                                                                       | highest priority                                                                                       | / interrupt)                       |                  |                 |        |
|                    | •                                                                                                                                                                    |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 |        |
|                    | •                                                                                                                                                                    |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 |        |
|                    | •                                                                                                                                                                    |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 |        |
|                    | •<br>001 = Interrup                                                                                                                                                  | pt is Priority 1                                                                                                                                                         |                                                                                                        |                                    |                  |                 |        |
|                    |                                                                                                                                                                      | pt is Priority 1<br>pt source is dis                                                                                                                                     | abled                                                                                                  |                                    |                  |                 |        |
| bit 11             | 000 = Interru                                                                                                                                                        |                                                                                                                                                                          |                                                                                                        |                                    |                  |                 |        |
| bit 11<br>bit 10-8 | 000 = Interrup<br>Unimplemen                                                                                                                                         | pt source is dis<br>ted: Read as '                                                                                                                                       | 0'                                                                                                     | Interrupt Priorit                  | / bits           |                 |        |
|                    | 000 = Interru<br>Unimplemen<br>OC4IP<2:0>:                                                                                                                           | pt source is dis<br>ted: Read as '                                                                                                                                       | <sup>0'</sup><br>are Channel 4                                                                         | • •                                | / bits           |                 |        |
|                    | 000 = Interru<br>Unimplemen<br>OC4IP<2:0>:                                                                                                                           | pt source is dis<br><b>ted:</b> Read as '<br>Output Compa                                                                                                                | <sup>0'</sup><br>are Channel 4                                                                         | • •                                | / bits           |                 |        |
|                    | 000 = Interru<br>Unimplemen<br>OC4IP<2:0>:                                                                                                                           | pt source is dis<br><b>ted:</b> Read as '<br>Output Compa                                                                                                                | <sup>0'</sup><br>are Channel 4                                                                         | • •                                | / bits           |                 |        |
|                    | 000 = Interru<br>Unimplemen<br>OC4IP<2:0>:                                                                                                                           | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (                                                                                                 | <sup>0'</sup><br>are Channel 4                                                                         | • •                                | y bits           |                 |        |
|                    | 000 = Interrup<br>Unimplement<br>OC4IP<2:0>:<br>111 = Interrup                                                                                                       | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (                                                                                                 | <sup>0'</sup><br>are Channel 4<br>highest priority                                                     | • •                                | / bits           |                 |        |
|                    | 000 = Interrup<br>Unimplemen<br>OC4IP<2:0>:<br>111 = Interrup                                                                                                        | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (<br>pt is Priority 1                                                                             | <sub>0</sub> '<br>are Channel 4<br>highest priority<br>abled                                           | • •                                | / bits           |                 |        |
| bit 10-8           | 000 = Interrup<br>Unimplement<br>OC4IP<2:0>:<br>111 = Interrup                                                                                                       | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (<br>pt is Priority 1<br>pt source is dis<br>ted: Read as '                                       | <sup>0'</sup><br>are Channel 4<br>highest priority<br>abled<br>0'                                      | • •                                |                  |                 |        |
| bit 10-8<br>bit 7  | 000 = Interrup<br>Unimplement<br>OC4IP<2:0>:<br>111 = Interrup<br>001 = Interrup<br>000 = Interrup<br>Unimplement<br>OC3IP<2:0>:                                     | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (<br>pt is Priority 1<br>pt source is dis<br>ted: Read as '                                       | <sup>0'</sup><br>are Channel 4<br>highest priority<br>abled<br><sup>0'</sup><br>are Channel 3          | y interrupt)<br>Interrupt Priority |                  |                 |        |
| bit 10-8<br>bit 7  | 000 = Interrup<br>Unimplement<br>OC4IP<2:0>:<br>111 = Interrup<br>001 = Interrup<br>000 = Interrup<br>Unimplement<br>OC3IP<2:0>:                                     | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (<br>pt is Priority 1<br>pt source is dis<br>ted: Read as '<br>Output Compa                       | <sup>0'</sup><br>are Channel 4<br>highest priority<br>abled<br><sup>0'</sup><br>are Channel 3          | y interrupt)<br>Interrupt Priority |                  |                 |        |
| bit 10-8<br>bit 7  | 000 = Interrup<br>Unimplement<br>OC4IP<2:0>:<br>111 = Interrup<br>001 = Interrup<br>000 = Interrup<br>Unimplement<br>OC3IP<2:0>:                                     | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (<br>pt is Priority 1<br>pt source is dis<br>ted: Read as '<br>Output Compa                       | <sup>0'</sup><br>are Channel 4<br>highest priority<br>abled<br><sup>0'</sup><br>are Channel 3          | y interrupt)<br>Interrupt Priority |                  |                 |        |
| bit 10-8<br>bit 7  | 000 = Interrup<br>Unimplement<br>OC4IP<2:0>:<br>111 = Interrup<br>001 = Interrup<br>000 = Interrup<br>Unimplement<br>OC3IP<2:0>:                                     | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (<br>pt is Priority 1<br>pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 ( | <sup>0'</sup><br>are Channel 4<br>highest priority<br>abled<br><sup>0'</sup><br>are Channel 3          | y interrupt)<br>Interrupt Priority |                  |                 |        |
| bit 10-8<br>bit 7  | 000 = Interrup<br>Unimplement<br>OC4IP<2:0>:<br>111 = Interrup<br>001 = Interrup<br>000 = Interrup<br>Unimplement<br>OC3IP<2:0>:<br>111 = Interrup<br>001 = Interrup | pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 (<br>pt is Priority 1<br>pt source is dis<br>ted: Read as '<br>Output Compa<br>pt is Priority 7 ( | <sup>0'</sup><br>are Channel 4<br>highest priority<br>abled<br>0'<br>are Channel 3<br>highest priority | y interrupt)<br>Interrupt Priority |                  |                 |        |

#### REGISTER 7-21: IPC6: INTERRUPT PRIORITY CONTROL REGISTER 6

REGISTER 7-25: IPC10: INTERRUPT PRIORITY CONTROL REGISTER 10

| U-0           | U-0           | U-0                | U-0              | U-0                | U-0              | U-0             | U-0   |
|---------------|---------------|--------------------|------------------|--------------------|------------------|-----------------|-------|
| _             | —             |                    |                  | —                  | —                | —               | _     |
| bit 15        |               |                    |                  |                    |                  |                 | bit 8 |
|               |               |                    |                  |                    |                  |                 |       |
| U-0           | R/W-1         | R/W-0              | R/W-0            | U-0                | U-0              | U-0             | U-0   |
| _             | OC5IP2        | OC5IP1             | OC5IP0           | —                  | —                | —               | —     |
| bit 7         |               |                    |                  | ·                  |                  |                 | bit 0 |
|               |               |                    |                  |                    |                  |                 |       |
| Legend:       |               |                    |                  |                    |                  |                 |       |
| R = Readable  | e bit         | W = Writable       | bit              | U = Unimplen       | nented bit, read | l as '0'        |       |
| -n = Value at | POR           | '1' = Bit is set   |                  | '0' = Bit is clea  | ared             | x = Bit is unkr | iown  |
|               |               |                    |                  |                    |                  |                 |       |
| bit 15-7      | Unimplemen    | ted: Read as '     | 0'               |                    |                  |                 |       |
| bit 6-4       | OC5IP<2:0>:   | Output Compa       | are Channel 5 I  | Interrupt Priority | y bits           |                 |       |
|               | 111 = Interru | pt is Priority 7 ( | highest priority | / interrupt)       |                  |                 |       |
|               | •             |                    |                  |                    |                  |                 |       |
|               | •             |                    |                  |                    |                  |                 |       |
|               | •             |                    |                  |                    |                  |                 |       |
|               | 001 = Interru |                    |                  |                    |                  |                 |       |
|               | 000 = Interru | pt source is dis   | abled            |                    |                  |                 |       |
|               |               |                    |                  |                    |                  |                 |       |

bit 3-0 Unimplemented: Read as '0'

#### REGISTER 7-26: IPC11: INTERRUPT PRIORITY CONTROL REGISTER 11

| U-0          | U-0           | U-0                | U-0              | U-0               | U-0              | U-0                | U-0   |  |
|--------------|---------------|--------------------|------------------|-------------------|------------------|--------------------|-------|--|
| _            | —             | —                  | —                | —                 | —                | —                  | —     |  |
| bit 15       |               |                    |                  |                   |                  |                    | bit 8 |  |
|              |               |                    |                  |                   |                  |                    |       |  |
| U-0          | R/W-1         | R/W-0              | R/W-0            | U-0               | U-0              | U-0                | U-0   |  |
| _            | PMPIP2        | PMPIP1             | PMPIP0           | —                 | —                | —                  |       |  |
| bit 7        |               |                    |                  |                   |                  |                    | bit 0 |  |
|              |               |                    |                  |                   |                  |                    |       |  |
| Legend:      |               |                    |                  |                   |                  |                    |       |  |
| R = Readab   | le bit        | W = Writable       | bit              | U = Unimplem      | nented bit, read | l as '0'           |       |  |
| -n = Value a | t POR         | '1' = Bit is set   |                  | '0' = Bit is clea | ared             | x = Bit is unknown |       |  |
|              |               |                    |                  |                   |                  |                    |       |  |
| bit 15-7     | Unimplemen    | ted: Read as '0    | )'               |                   |                  |                    |       |  |
| bit 6-4      | PMPIP<2:0>    | : Parallel Maste   | r Port Interrupt | t Priority bits   |                  |                    |       |  |
|              | 111 = Interru | pt is Priority 7 ( | highest priority | interrupt)        |                  |                    |       |  |
|              | •             |                    |                  |                   |                  |                    |       |  |
|              | •             |                    |                  |                   |                  |                    |       |  |
|              | •             |                    |                  |                   |                  |                    |       |  |
|              | 001 = Interru | pt is Priority 1   |                  |                   |                  |                    |       |  |
|              | 000 = Interru | pt source is dis   | abled            |                   |                  |                    |       |  |
| bit 3-0      | Unimplemen    | ted: Read as '     | )'               |                   |                  |                    |       |  |
|              |               |                    |                  |                   |                  |                    |       |  |

#### REGISTER 8-1: OSCCON: OSCILLATOR CONTROL REGISTER (CONTINUED)

| bit 7                   | CLKLOCK: Clock Selection Lock Enable bit                                                                                                                                                                                                                                                                                                                                          |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | <u>If FSCM is enabled (FCKSM1 = 1):</u>                                                                                                                                                                                                                                                                                                                                           |
|                         | 1 = Clock and PLL selections are locked                                                                                                                                                                                                                                                                                                                                           |
|                         | 0 = Clock and PLL selections are not locked and may be modified by setting the OSWEN bit                                                                                                                                                                                                                                                                                          |
|                         | <u>If FSCM is disabled (FCKSM1 = 0):</u>                                                                                                                                                                                                                                                                                                                                          |
|                         | Clock and PLL selections are never locked and may be modified by setting the OSWEN bit.                                                                                                                                                                                                                                                                                           |
| bit 6                   | IOLOCK: I/O Lock Enable bit <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                        |
|                         | 1 = I/O lock is active                                                                                                                                                                                                                                                                                                                                                            |
|                         | 0 = I/O lock is not active                                                                                                                                                                                                                                                                                                                                                        |
| bit 5                   | LOCK: PLL Lock Status bit <sup>(3)</sup>                                                                                                                                                                                                                                                                                                                                          |
|                         | 1 = PLL module is in lock or PLL module start-up timer is satisfied                                                                                                                                                                                                                                                                                                               |
|                         | 0 = PLL module is out of lock, PLL start-up timer is running or PLL is disabled                                                                                                                                                                                                                                                                                                   |
|                         |                                                                                                                                                                                                                                                                                                                                                                                   |
| bit 4                   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                        |
| bit 4<br>bit 3          | <b>CF:</b> Clock Fail Detect bit                                                                                                                                                                                                                                                                                                                                                  |
|                         | •                                                                                                                                                                                                                                                                                                                                                                                 |
|                         | CF: Clock Fail Detect bit                                                                                                                                                                                                                                                                                                                                                         |
|                         | <b>CF:</b> Clock Fail Detect bit<br>1 = FSCM has detected a clock failure                                                                                                                                                                                                                                                                                                         |
| bit 3                   | <ul> <li>CF: Clock Fail Detect bit</li> <li>1 = FSCM has detected a clock failure</li> <li>0 = No clock failure has been detected</li> </ul>                                                                                                                                                                                                                                      |
| bit 3<br>bit 2          | <ul> <li>CF: Clock Fail Detect bit</li> <li>1 = FSCM has detected a clock failure</li> <li>0 = No clock failure has been detected</li> <li>Unimplemented: Read as '0'</li> </ul>                                                                                                                                                                                                  |
| bit 3<br>bit 2          | CF: Clock Fail Detect bit<br>1 = FSCM has detected a clock failure<br>0 = No clock failure has been detected<br>Unimplemented: Read as '0'<br>SOSCEN: 32 kHz Secondary Oscillator (SOSC) Enable bit                                                                                                                                                                               |
| bit 3<br>bit 2          | <ul> <li>CF: Clock Fail Detect bit</li> <li>1 = FSCM has detected a clock failure</li> <li>0 = No clock failure has been detected</li> <li>Unimplemented: Read as '0'</li> <li>SOSCEN: 32 kHz Secondary Oscillator (SOSC) Enable bit</li> <li>1 = Enables Secondary Oscillator</li> </ul>                                                                                         |
| bit 3<br>bit 2<br>bit 1 | <ul> <li>CF: Clock Fail Detect bit</li> <li>1 = FSCM has detected a clock failure</li> <li>0 = No clock failure has been detected</li> <li>Unimplemented: Read as '0'</li> <li>SOSCEN: 32 kHz Secondary Oscillator (SOSC) Enable bit</li> <li>1 = Enables Secondary Oscillator</li> <li>0 = Disables Secondary Oscillator</li> </ul>                                              |
| bit 3<br>bit 2<br>bit 1 | <ul> <li>CF: Clock Fail Detect bit</li> <li>1 = FSCM has detected a clock failure</li> <li>0 = No clock failure has been detected</li> <li>Unimplemented: Read as '0'</li> <li>SOSCEN: 32 kHz Secondary Oscillator (SOSC) Enable bit</li> <li>1 = Enables Secondary Oscillator</li> <li>0 = Disables Secondary Oscillator</li> <li>OSWEN: Oscillator Switch Enable bit</li> </ul> |

Note 1: Reset values for these bits are determined by the FNOSCx Configuration bits.

- 2: The state of the IOLOCK bit can only be changed once an unlocking sequence has been executed. In addition, if the IOL1WAY Configuration bit is '1' once the IOLOCK bit is set, it cannot be cleared.
- 3: Also resets to '0' during any valid clock switch or whenever a non-PLL Clock mode is selected.

### 10.0 I/O PORTS

Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information, refer to the *"PIC24F Family Reference Manual"*, *"I/O* Ports with Peripheral Pin Select (PPS)" (DS39711).

All of the device pins (except VDD, VSS, MCLR and OSCI/CLKI) are shared between the peripherals and the Parallel I/O (PIO) ports. All I/O input ports feature Schmitt Trigger inputs for improved noise immunity.

### 10.1 Parallel I/O (PIO) Ports

A Parallel I/O port that shares a pin with a peripheral is, in general, subservient to the peripheral. The peripheral's output buffer data and control signals are provided to a pair of multiplexers. The multiplexers select whether the peripheral or the associated port has ownership of the output data and control signals of the I/O pin. The logic also prevents "loop through", in which a port's digital output can drive the input of a peripheral that shares the same pin. Figure 10-1 shows how ports are shared with other peripherals and the associated I/O pin to which they are connected. When a peripheral is enabled and the peripheral is actively driving an associated pin, the use of the pin as a general purpose output pin is disabled. The I/O pin may be read, but the output driver for the parallel port bit will be disabled. If a peripheral is enabled, but the peripheral is not actively driving a pin, that pin may be driven by a port.

All port pins have three registers directly associated with their operation as digital I/O. The Data Direction register (TRISx) determines whether the pin is an input or an output. If the data direction bit is a '1', then the pin is an input. All port pins are defined as inputs after a Reset. Reads from the Output Latch register (LATx), read the latch. Writes to the latch, write the latch. Reads from the port (PORTx), read the port pins, while writes to the port pins, write the latch.

Any bit and its associated data and control registers that are not valid for a particular device will be disabled. That means the corresponding LATx and TRISx registers and the port pin will read as zeros.

When a pin is shared with another peripheral or function that is defined as an input only, it is nevertheless, regarded as a dedicated port because there is no other competing source of outputs.



#### FIGURE 10-1: BLOCK DIAGRAM OF A TYPICAL SHARED PORT STRUCTURE

| U-0                 | U-0                                    | U-0              | R/W-0                                  | R/W-0                 | R/W-0                  | R/W-0            | R/W-0              |
|---------------------|----------------------------------------|------------------|----------------------------------------|-----------------------|------------------------|------------------|--------------------|
| _                   | _                                      | _                | DISSCK <sup>(1)</sup>                  | DISSDO <sup>(2)</sup> | MODE16                 | SMP              | CKE <sup>(3)</sup> |
| bit 15              |                                        |                  |                                        |                       |                        |                  | bit                |
|                     |                                        |                  |                                        |                       |                        |                  |                    |
| R/W-0               |                                        | R/W-0            | R/W-0                                  | R/W-0                 | R/W-0                  | R/W-0            | R/W-0              |
| SSEN <sup>(4)</sup> | ) CKP                                  | MSTEN            | SPRE2                                  | SPRE1                 | SPRE0                  | PPRE1            | PPRE0              |
| bit 7               |                                        |                  |                                        |                       |                        |                  | bit                |
| Legend:             |                                        |                  |                                        |                       |                        |                  |                    |
| R = Reada           | able bit                               | W = Writable     | bit                                    | U = Unimplem          | nented bit, read       | as '0'           |                    |
| -n = Value          | at POR                                 | '1' = Bit is set |                                        | '0' = Bit is clea     |                        | x = Bit is unkn  | iown               |
|                     |                                        |                  | -                                      |                       |                        |                  | -                  |
| bit 15-13           | Unimplemen                             | ted: Read as '   | 0'                                     |                       |                        |                  |                    |
| bit 12              | DISSCK: Disa                           | ables SCKx Pi    | n bit (SPI Maste                       | er modes only)        | (1)                    |                  |                    |
|                     |                                        |                  | abled; pin funct                       | ions as I/O           |                        |                  |                    |
|                     |                                        | SPI clock is en  |                                        |                       |                        |                  |                    |
| bit 11              |                                        | ables SDOx Pi    |                                        |                       |                        |                  |                    |
|                     |                                        |                  | y the module; p                        | in functions as       | I/O                    |                  |                    |
| bit 10              |                                        | n is controlled  | •                                      | at hit                |                        |                  |                    |
|                     |                                        | -                | unication Seleo                        |                       |                        |                  |                    |
|                     |                                        | ication is byte- | , ,                                    |                       |                        |                  |                    |
| bit 9               |                                        | ata Input Sam    |                                        |                       |                        |                  |                    |
|                     | Master mode:                           |                  |                                        |                       |                        |                  |                    |
|                     |                                        |                  | t end of data ou                       |                       |                        |                  |                    |
|                     | -                                      | a is sampled a   | t middle of data                       | output time           |                        |                  |                    |
|                     | <u>Slave mode:</u>                     | cleared when     | SPIx is used in                        | Slave mode            |                        |                  |                    |
| bit 8               |                                        | lock Edge Sele   |                                        |                       |                        |                  |                    |
| bit 0               |                                        | •                |                                        | n from active c       | lock state to Idl      | e clock state (s | see bit 6)         |
|                     |                                        |                  |                                        |                       | ck state to active     |                  |                    |
| bit 7               | SSEN: Slave                            | Select Enable    | bit (Slave mode                        | ∋) <sup>(4)</sup>     |                        |                  |                    |
|                     |                                        | s used for Slav  |                                        |                       |                        |                  |                    |
|                     | 0 = SSx pin i                          | s not used by    | he module; pin                         | is controlled by      | y port function        |                  |                    |
| bit 6               |                                        | olarity Select   |                                        |                       |                        |                  |                    |
|                     |                                        |                  | s a high level; a<br>s a low level; ac |                       |                        |                  |                    |
| bit 5               |                                        | ter Mode Enat    | -                                      |                       | lignievei              |                  |                    |
| DIUD                | 1 = Master m                           |                  | ne bit                                 |                       |                        |                  |                    |
|                     | 0 = Slave mo                           |                  |                                        |                       |                        |                  |                    |
| Note 1:             | If DISSCK = 0, So<br>Select (PPS)" for |                  |                                        | available RPn         | pin. See <b>Sectio</b> | on 10.4 "Perip   | heral Pin          |
| 2:                  | If DISSDO = 0, S<br>Select (PPS)" for  | DOx must be o    | configured to an                       | available RPn         | pin. See <b>Secti</b>  | on 10.4 "Perip   | oheral Pin         |
| 3:                  | The CKE bit is no SPI modes (FRM       | EN = 1).         |                                        |                       |                        |                  |                    |
| 4:                  | If SSEN = 1, SSx<br>(PPS)" for more i  |                  | gured to an ava                        | ilable RPn pin.       | See Section 1          | 0.4 "Peripher    | al Pin Selec       |

| R/W-0                | U-0                                 | R/W-0                                                                | R/W-0               | R/W-0                             | U-0                         | R/W-0 <sup>(3)</sup> | R/W-0 <sup>(3)</sup> |
|----------------------|-------------------------------------|----------------------------------------------------------------------|---------------------|-----------------------------------|-----------------------------|----------------------|----------------------|
| UARTEN <sup>(1</sup> | ) _                                 | USIDL                                                                | IREN <sup>(2)</sup> | RTSMD                             | _                           | UEN1                 | UEN0                 |
| bit 15               |                                     |                                                                      |                     | ·                                 |                             | •                    | bit 8                |
|                      |                                     |                                                                      | <b>D</b> 444 A      | <b>D M M</b>                      | <b>D</b> 444 0              | <b>D</b> 444 A       | <b>D</b> 444 0       |
| R/C-0, HC            |                                     | R/W-0, HC                                                            | R/W-0               | R/W-0                             | R/W-0                       | R/W-0                | R/W-0                |
| WAKE                 | LPBACK                              | ABAUD                                                                | RXINV               | BRGH                              | PDSEL1                      | PDSEL0               | STSEL                |
| bit 7                |                                     |                                                                      |                     |                                   |                             |                      | bit 0                |
| Legend:              |                                     | C = Clearable                                                        | hit                 | HC = Hardwa                       | are Clearable bi            | t                    |                      |
| R = Readat           | ole hit                             | W = Writable b                                                       |                     |                                   | mented bit, read            |                      |                      |
| -n = Value a         |                                     | '1' = Bit is set                                                     | it.                 | '0' = Bit is cle                  |                             |                      |                      |
| -n = value a         | al POR                              | I = BILIS SEL                                                        |                     | 0 = Bit is cle                    | ared                        | x = Bit is unkn      | IOWN                 |
| bit 15               |                                     | ARTx Enable bit <sup>(</sup>                                         | 1)                  |                                   |                             |                      |                      |
| bit io               |                                     | s enabled; all UA                                                    |                     | e controlled by                   | UARTx as defin              | ed by UEN<1.         | )>                   |
|                      |                                     | s disabled; all UA                                                   |                     |                                   |                             |                      |                      |
| bit 14               |                                     | ted: Read as '0                                                      |                     |                                   |                             |                      |                      |
| bit 13               | USIDL: UAR                          | Tx Stop in Idle M                                                    | ode bit             |                                   |                             |                      |                      |
|                      | 1 = Discontir                       | nues module ope                                                      | ration when         | device enters le                  | dle mode                    |                      |                      |
|                      |                                     | es module operation                                                  |                     |                                   |                             |                      |                      |
| bit 12               | IREN: IrDA®                         | Encoder and De                                                       | coder Enabl         | e bit <sup>(2)</sup>              |                             |                      |                      |
|                      |                                     | oder and decode                                                      |                     |                                   |                             |                      |                      |
| bit 11               |                                     | de Selection for I                                                   |                     |                                   |                             |                      |                      |
| 2                    | $1 = \overline{\text{UxRTS}} p$     | oin in Simplex mo<br>oin in Flow Contr                               | ode                 |                                   |                             |                      |                      |
| bit 10               | •                                   | ted: Read as '0                                                      |                     |                                   |                             |                      |                      |
| bit 9-8              | •                                   | JARTx Enable bi                                                      |                     |                                   |                             |                      |                      |
|                      | 10 = UxTX, U<br>01 = UxTX, U        | JxRX and BCLK<br>JxRX, UxCTS ar<br>JxRX and UxRT<br>nd UxRX pins are | d UxRTS pins are er | ns are enabled<br>habled and used | and used<br>d; UxCTS pin is | controlled by F      | ORT latches          |
| bit 7                | WAKE: Wake                          | e-up on Start Bit                                                    | Detect Durin        | g Sleep Mode I                    | Enable bit                  |                      |                      |
|                      | hardware                            | vill continue to sa<br>e on following ris                            | -                   | RX pin; interrup                  | t is generated o            | n falling edge, b    | it is cleared in     |
| hit C                |                                     | -up is enabled                                                       | Mada Salaat         | hit                               |                             |                      |                      |
| bit 6                |                                     | ARTx Loopback  <br>Loopback mode                                     |                     | DIL                               |                             |                      |                      |
|                      |                                     | k mode is disabl                                                     |                     |                                   |                             |                      |                      |
| bit 5                |                                     | o-Baud Enable b                                                      |                     |                                   |                             |                      |                      |
|                      | cleared i                           | baud rate meas<br>n hardware upor                                    | n completion        |                                   | ter – requires re           | ception of a Sy      | nc field (55h);      |
|                      | 0 = Baud rat                        | e measurement                                                        | is disabled o       | r completed                       |                             |                      |                      |
|                      | f UARTEN = 1, t<br>Section 10.4 "Pe |                                                                      |                     |                                   |                             | vailable RPn p       | in. See              |
|                      | This feature is or                  | -                                                                    |                     |                                   |                             |                      |                      |
|                      | Bit availability de                 | -                                                                    |                     |                                   |                             |                      |                      |

#### REGISTER 17-1: UXMODE: UARTX MODE REGISTER

**3:** Bit availability depends on pin availability.

| R-0<br>IBF<br>bit 15<br>R-1<br>OBE<br>bit 7<br>Legend: | R/W-0, HS<br>IBOV<br>R/W-0, HS<br>OBUF                                                                                                                              | U-0<br>—<br>U-0<br>—                  | U-0<br>—<br>U-0<br>— | R-0<br>IB3F<br>R-1<br>OB3E         | R-0<br>IB2F<br>R-1<br>OB2E | R-0<br>IB1F<br>R-1 | R-0<br>IB0F<br>bit 8<br>R-1 |  |
|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------|------------------------------------|----------------------------|--------------------|-----------------------------|--|
| R-1<br>OBE<br>bit 7                                    | R/W-0, HS                                                                                                                                                           | U-0<br>—                              | U-0<br>—             | R-1                                | R-1                        | R-1                | bit 8                       |  |
| OBE<br>bit 7                                           | ,                                                                                                                                                                   | U-0<br>—                              | U-0                  | 1                                  |                            |                    | R-1                         |  |
| OBE<br>bit 7                                           | ,                                                                                                                                                                   | <u> </u>                              | <u> </u>             | 1                                  |                            |                    | R-1                         |  |
| bit 7                                                  |                                                                                                                                                                     | —                                     | —                    | OB3E                               | OB2E                       |                    | 0000                        |  |
|                                                        |                                                                                                                                                                     |                                       |                      |                                    |                            | OB1E               | OB0E<br>bit 0               |  |
| l ogond:                                               |                                                                                                                                                                     |                                       |                      |                                    |                            |                    | DILC                        |  |
| Legenu.                                                |                                                                                                                                                                     | HS = Hardwar                          | e Settable bit       |                                    |                            |                    |                             |  |
| R = Readabl                                            | le bit                                                                                                                                                              | W = Writable b                        | bit                  | U = Unimplem                       | ented bit, read            | l as '0'           |                             |  |
| -n = Value at                                          | POR                                                                                                                                                                 | '1' = Bit is set                      |                      | '0' = Bit is clea                  | ired                       | x = Bit is unkno   | own                         |  |
| bit 14                                                 | 0 = Some or a                                                                                                                                                       |                                       | le Input Buffer      | ull<br>r registers are ei          | mpty                       |                    |                             |  |
| bit 14                                                 | IBOV: Input B                                                                                                                                                       | uffer Overflow                        | Status bit           |                                    |                            |                    |                             |  |
|                                                        | 1 = A write at 0 = No overflo                                                                                                                                       |                                       | nput Byte regi       | ister occurred (n                  | nust de cleare             | a in software)     |                             |  |
| bit 13-12                                              | Unimplement                                                                                                                                                         | ted: Read as '0                       | ,                    |                                    |                            |                    |                             |  |
| bit 11-8                                               | <ul> <li>IB3F:IB0F: Input Buffer x Status Full bits</li> <li>1 = Input Buffer x contains data that has not been read (reading buffer will clear this bit</li> </ul> |                                       |                      | vill clear this bit)               |                            |                    |                             |  |
|                                                        |                                                                                                                                                                     | fer x does not c                      |                      |                                    | <b>J</b>                   | ,                  |                             |  |
| bit 7                                                  | OBE: Output Buffer Empty Status bit                                                                                                                                 |                                       |                      |                                    |                            |                    |                             |  |
|                                                        |                                                                                                                                                                     | ble Output Buffe<br>all of the readal |                      | e empty<br>ffer registers are      | e full                     |                    |                             |  |
| bit 6                                                  | OBUF: Output Buffer Underflow Status bit                                                                                                                            |                                       |                      |                                    |                            |                    |                             |  |
|                                                        | 1 = A read oc<br>0 = No under                                                                                                                                       |                                       | empty Output         | t Byte register (r                 | nust be cleare             | d in software)     |                             |  |
| bit 5-4                                                | Unimplement                                                                                                                                                         | t <b>ed: Read as</b> '0               | ,                    |                                    |                            |                    |                             |  |
| bit 3-0                                                |                                                                                                                                                                     | Output Buffer x                       |                      |                                    |                            |                    |                             |  |
|                                                        |                                                                                                                                                                     |                                       |                      | to the buffer will not been transn |                            |                    |                             |  |

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

# 24.0 SPECIAL FEATURES

- Note: This data sheet summarizes the features of this group of PIC24F devices. It is not intended to be a comprehensive reference source. For more information, refer to the following sections of the *"PIC24F Family Reference Manual"*.
   **"Watchdog Timer (WDT)"** (DS39697)
   **"High-Level Device Integration"** (DS39719)
  - "Programming and Diagnostics" (DS39716)

PIC24FJ64GA004 family devices include several features intended to maximize application flexibility and reliability, and minimize cost through elimination of external components. These are:

- Flexible Configuration
- · Watchdog Timer (WDT)
- Code Protection
- · JTAG Boundary Scan Interface
- In-Circuit Serial Programming
- In-Circuit Emulation

### 24.1 Configuration Bits

The Configuration bits can be programmed (read as '0'), or left unprogrammed (read as '1'), to select various device configurations. These bits are mapped starting at program memory location, F80000h. A complete list of locations is shown in Table 24-1. A detailed explanation of the various bit functions is provided in Register 24-1 through Register 24-4.

Note that address, F80000h, is beyond the user program memory space. In fact, it belongs to the configuration memory space (800000h-FFFFFFh), which can only be accessed using table reads and table writes.

#### 24.1.1 CONSIDERATIONS FOR CONFIGURING PIC24FJ64GA004 FAMILY DEVICES

In PIC24FJ64GA004 family devices, the configuration bytes are implemented as volatile memory. This means that configuration data must be programmed each time the device is powered up. Configuration data is stored in the two words at the top of the on-chip program memory space, known as the Flash Configuration Words. Their specific locations are shown in Table 24-1. These are packed representations of the actual device Configuration bits, whose actual locations are distributed among five locations in configuration space. The configuration data is automatically loaded from the Flash Configuration Words to the proper Configuration registers during device Resets.

Note: Configuration data is reloaded on all types of device Resets.

#### TABLE 24-1: FLASH CONFIGURATION WORD LOCATIONS FOR PIC24FJ64GA004 FAMILY DEVICES

| Device      | Configuration Word<br>Addresses |         |  |
|-------------|---------------------------------|---------|--|
|             | 1                               | 2       |  |
| PIC24FJ16GA | 002BFEh                         | 002BFCh |  |
| PIC24FJ32GA | 0057FEh                         | 0057FCh |  |
| PIC24FJ48GA | 0083FEh                         | 0083FCh |  |
| PIC24FJ64GA | 00ABFEh                         | 00ABFCh |  |

When creating applications for these devices, users should always specifically allocate the location of the Flash Configuration Word for configuration data. This is to make certain that program code is not stored in this address when the code is compiled.

The Configuration bits are reloaded from the Flash Configuration Word on any device Reset.

The upper byte of both Flash Configuration Words in program memory should always be '1111 1111'. This makes them appear to be NOP instructions in the remote event that their locations are ever executed by accident. Since Configuration bits are not implemented in the corresponding locations, writing '1's to these locations has no effect on device operation.

#### TABLE 26-1: SYMBOLS USED IN OPCODE DESCRIPTIONS

| Field           | Description                                                                           |
|-----------------|---------------------------------------------------------------------------------------|
| #text           | Means literal defined by "text"                                                       |
| (text)          | Means "content of text"                                                               |
| [text]          | Means "the location addressed by text"                                                |
| { }             | Optional field or operation                                                           |
| <n:m></n:m>     | Register bit field                                                                    |
| .b              | Byte mode selection                                                                   |
| .d              | Double-Word mode selection                                                            |
| .S              | Shadow register select                                                                |
| .W              | Word mode selection (default)                                                         |
| bit4            | 4-bit bit selection field (used in word addressed instructions) $\in \{015\}$         |
| C, DC, N, OV, Z | MCU Status bits: Carry, Digit Carry, Negative, Overflow, Sticky Zero                  |
| Expr            | Absolute address, label or expression (resolved by the linker)                        |
| f               | File register address ∈ {0000h1FFFh}                                                  |
| lit1            | 1-bit unsigned literal ∈ {0,1}                                                        |
| lit4            | 4-bit unsigned literal ∈ {015}                                                        |
| lit5            | 5-bit unsigned literal ∈ {031}                                                        |
| lit8            | 8-bit unsigned literal ∈ {0255}                                                       |
| lit10           | 10-bit unsigned literal $\in$ {0255} for Byte mode, {0:1023} for Word mode            |
| lit14           | 14-bit unsigned literal ∈ {016384}                                                    |
| lit16           | 16-bit unsigned literal ∈ {065535}                                                    |
| lit23           | 23-bit unsigned literal ∈ {08388608}; LSB must be '0'                                 |
| None            | Field does not require an entry, may be blank                                         |
| PC              | Program Counter                                                                       |
| Slit10          | 10-bit signed literal ∈ {-512511}                                                     |
| Slit16          | 16-bit signed literal ∈ {-3276832767}                                                 |
| Slit6           | 6-bit signed literal $\in$ {-1616}                                                    |
| Wb              | Base W register $\in$ {W0W15}                                                         |
| Wd              | Destination W register $\in$ { Wd, [Wd], [Wd++], [Wd], [++Wd], [Wd] }                 |
| Wdo             | Destination W register $\in$ { Wnd, [Wnd], [Wnd++], [Wnd], [++Wnd], [Wnd], [Wnd+Wb] } |
| Wm,Wn           | Dividend, Divisor working register pair (direct addressing)                           |
| Wn              | One of 16 working registers ∈ {W0W15}                                                 |
| Wnd             | One of 16 destination working registers ∈ {W0W15}                                     |
| Wns             | One of 16 source working registers ∈ {W0W15}                                          |
| WREG            | W0 (working register used in file register instructions)                              |
| Ws              | Source W register ∈ { Ws, [Ws], [Ws++], [Ws], [++Ws], [Ws] }                          |
| Wso             | Source W register ∈ { Wns, [Wns], [Wns++], [Wns], [++Wns], [Wns], [Wns+Wb] }          |

# 28-Lead Plastic Quad Flat, No Lead Package (ML) – 6x6 mm Body [QFN] with 0.55 mm Contact Length

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                        | Units            |      | MILLIMETERS |      |  |
|------------------------|------------------|------|-------------|------|--|
|                        | Dimension Limits | MIN  | NOM         | MAX  |  |
| Number of Pins         | N                |      | 28          |      |  |
| Pitch                  | е                |      | 0.65 BSC    |      |  |
| Overall Height         | A                | 0.80 | 0.90        | 1.00 |  |
| Standoff               | A1               | 0.00 | 0.02        | 0.05 |  |
| Contact Thickness      | A3               |      | 0.20 REF    |      |  |
| Overall Width          | E                |      | 6.00 BSC    |      |  |
| Exposed Pad Width      | E2               | 3.65 | 3.70        | 4.20 |  |
| Overall Length         | D                |      | 6.00 BSC    |      |  |
| Exposed Pad Length     | D2               | 3.65 | 3.70        | 4.20 |  |
| Contact Width          | b                | 0.23 | 0.30        | 0.35 |  |
| Contact Length         | L                | 0.50 | 0.55        | 0.70 |  |
| Contact-to-Exposed Pad | K                | 0.20 | -           | _    |  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Package is saw singulated.

3. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-105B

### INDEX

| Α                                           |  |
|---------------------------------------------|--|
| A/D Converter                               |  |
| Analog Input Model                          |  |
| Transfer Function                           |  |
| AC Characteristics                          |  |
| A/D Conversion Requirements                 |  |
| A/D Specifications                          |  |
| CLKO and I/O Requirements                   |  |
| External Clock Requirements                 |  |
| Internal RC Accuracy                        |  |
| Internal RC Oscillator Specifications       |  |
| PLL Clock Specifications                    |  |
| Temperature and Voltage Specifications      |  |
| Additional Guidance for Family Applications |  |
| Assembler                                   |  |
| MPASM Assembler                             |  |

### В

| Block Diagrams                                |   |
|-----------------------------------------------|---|
| 10-Bit High-Speed A/D Converter               | 4 |
| 16-Bit Timer1 125                             | 5 |
| Accessing Program Memory with                 |   |
| Table Instructions45                          | 5 |
| Addressable Parallel Slave Port Example 174   | 4 |
| Addressing for Table Registers47              | 7 |
| CALL Stack Frame43                            | 3 |
| Comparator I/O Operating Modes203             | 3 |
| Comparator Voltage Reference 207              | 7 |
| CPU Programmer's Model25                      |   |
| CRC Module189                                 |   |
| CRC Shift Engine190                           | С |
| Data Access from Program Space                |   |
| Address Generation44                          |   |
| I <sup>2</sup> C Module 152                   | 2 |
| Input Capture x133                            |   |
| LCD Control Example, Byte Mode 176            |   |
| Legacy Parallel Slave Port Example174         |   |
| Load Conditions for Timing Specifications244  |   |
| MCLR Pin Connections18                        |   |
| On-Chip Regulator Connections 215             |   |
| Output Compare x138                           | 3 |
| Parallel EEPROM (Up to 11-Bit Address,        |   |
| 16-Bit Data)176                               | 3 |
| Parallel EEPROM (Up to 11-Bit Address,        |   |
| 8-Bit Data)176                                |   |
| Parallel Master Port (PMP) Module Overview    |   |
| PIC24F CPU Core                               |   |
| PIC24FJ64GA004 Family (General)10             | ) |
| PMP 8-Bit Multiplexed Addressing and          | _ |
| Data Application176                           |   |
| PMP Master Mode, Demultiplexed Addressing 174 | 1 |
| PMP Master Mode, Fully                        | _ |
| Multiplexed Addressing                        | С |
| PMP Master Mode, Partially                    | _ |
| Multiplexed Addressing                        |   |
| PMP Multiplexed Addressing Application        | C |
| PMP Partially Multiplexed                     | _ |
| Addressing Application                        |   |
| PSV Operation                                 |   |
| Real-Time Clock and Calendar (RTCC) 177       | ſ |

| Recommended Minimum Connections             | 17  |
|---------------------------------------------|-----|
| Reset System                                | 53  |
| Shared I/O Port Structure                   | 105 |
| Simplified UARTx Module                     | 159 |
| SPIx Master/Frame Master Connection         | 149 |
| SPIx Master/Frame Slave Connection          | 149 |
| SPIx Master/Slave Connection                |     |
| (Enhanced Buffer Mode)                      | 148 |
| SPIx Master/Slave Connection                |     |
| (Standard Mode)                             | 148 |
| SPIx Module (Enhanced Mode)                 | 143 |
| SPIx Module (Standard Mode)                 | 142 |
| SPIx Slave/Frame Master Connection          | 149 |
| SPIx Slave/Frame Slave Connection           | 149 |
| Suggested Placement of Oscillator Circuit   | 21  |
| System Clock                                | 95  |
| Timer2 and Timer4 (16-Bit Synchronous Mode) | 129 |
| Timer2/3 and Timer4/5 (32-Bit Mode)         | 128 |
| Timer3 and Timer5 (16-Bit Synchronous Mode) | 129 |
| Watchdog Timer (WDT)                        | 217 |
|                                             |     |

### С

| C Compilers                          |     |
|--------------------------------------|-----|
| MPLAB C18                            | 220 |
| Code Examples                        |     |
| Basic Clock Switching Example        | 101 |
| Configuring UART1 Input and Output   |     |
| Functions (PPS)                      | 110 |
| Erasing a Program Memory Block       | 50  |
| I/O Port Read/Write                  | 106 |
| Initiating a Programming Sequence    | 51  |
| Loading the Write Buffers            |     |
| Setting the RTCWREN Bit              |     |
| Single-Word Flash Programming        | 52  |
| Code Protection                      | 218 |
| Comparator Voltage Reference         |     |
| Configuring                          | 207 |
| Configuration Bits                   | 209 |
| Core Features                        | 7   |
| CPU                                  |     |
| Arithmetic Logic Unit (ALU)          | 27  |
| Control Registers                    | 26  |
| Core Registers                       | 25  |
| Programmer's Model                   | 23  |
| CRC                                  |     |
| Operation in Power Save Modes        | 190 |
| Setup Example                        | 189 |
| User Interface                       | 190 |
| Customer Change Notification Service | 273 |
| Customer Notification Service        | 273 |
| Customer Support                     | 273 |
| р                                    |     |

| D               |    |
|-----------------|----|
| Data Memory     |    |
| Address Space   | 31 |
| Memory Map      | 31 |
| Near Data Space | 32 |
| Organization    | 32 |
| SFR Space       | 32 |
| Software Stack  | 43 |
|                 |    |

|      | PADCFG1 (Pad Configuration Control)      | 173, 180 |
|------|------------------------------------------|----------|
|      | PMADDR (Parallel Port Address)           |          |
|      |                                          |          |
|      | PMAEN (Parallel Port Enable)             | 171      |
|      | PMCON (Parallel Port Control)            | 168      |
|      |                                          |          |
|      | PMMODE (Parallel Port Mode)              |          |
|      | PMSTAT (Parallel Port Status)            | 172      |
|      |                                          |          |
|      | RCFGCAL (RTCC Calibration                |          |
|      | and Configuration)                       | 179      |
|      |                                          |          |
|      | RCON (Reset Control)                     |          |
|      | RPINR0 (Peripheral Pin Select Input 0)   | 111      |
|      | RPINR1 (Peripheral Pin Select Input 1)   |          |
|      |                                          |          |
|      | RPINR11 (Peripheral Pin Select Input 11) | 114      |
|      | RPINR18 (Peripheral Pin Select Input 18) |          |
|      |                                          |          |
|      | RPINR19 (Peripheral Pin Select Input 19) | 115      |
|      | RPINR20 (Peripheral Pin Select Input 20) | 116      |
|      |                                          |          |
|      | RPINR21 (Peripheral Pin Select Input 21) |          |
|      | RPINR22 (Peripheral Pin Select Input 22) | 117      |
|      |                                          |          |
|      | RPINR23 (Peripheral Pin Select Input 23) |          |
|      | RPINR3 (Peripheral Pin Select Input 3)   | 112      |
|      | RPINR4 (Peripheral Pin Select Input 4)   |          |
|      |                                          |          |
|      | RPINR7 (Peripheral Pin Select Input 7)   | 113      |
|      | RPINR8 (Peripheral Pin Select Input 8)   |          |
|      |                                          |          |
|      | RPINR9 (Peripheral Pin Select Input 9)   |          |
|      | RPOR0 (Peripheral Pin Select Output 0)   | 118      |
|      | RPOR1 (Peripheral Pin Select Output 1)   | 110      |
|      |                                          |          |
|      | RPOR10 (Peripheral Pin Select Output 10) | 123      |
|      | RPOR11 (Peripheral Pin Select Output 11) | 123      |
|      |                                          |          |
|      | RPOR12 (Peripheral Pin Select Output 12) |          |
|      | RPOR2 (Peripheral Pin Select Output 2)   | 119      |
|      | RPOR3 (Peripheral Pin Select Output 3)   | 119      |
|      |                                          |          |
|      | RPOR4 (Peripheral Pin Select Output 4)   |          |
|      | RPOR5 (Peripheral Pin Select Output 5)   | 120      |
|      | RPOR6 (Peripheral Pin Select Output 6)   |          |
|      |                                          |          |
|      | RPOR7 (Peripheral Pin Select Output 7)   | 121      |
|      | RPOR8 (Peripheral Pin Select Output 8)   | 122      |
|      | RPOR9 (Peripheral Pin Select Output 9)   |          |
|      |                                          |          |
|      | SPIxCON1 (SPIx Control 1)                | 146      |
|      | SPIxCON2 (SPIx Control 2)                | 147      |
|      |                                          |          |
|      | SPIxSTAT (SPIx Status and Control)       |          |
|      | SR (ALU STATUS)                          | 26, 63   |
|      | T1CON (Timer1 Control)                   |          |
|      |                                          |          |
|      | TxCON (Timer2 and Timer4 Control)        | 130      |
|      | TyCON (Timer3 and Timer5 Control)        | 131      |
|      |                                          |          |
|      | UxMODE (UARTx Mode)                      |          |
|      | UxRXREG (UARTx Receive)                  | 166      |
|      | UxSTA (UARTx Status and Control)         |          |
|      |                                          |          |
|      | UxTXREG (UARTx Transmit)                 |          |
|      | WKDYHR (RTCC Weekday and Hours Value).   | 183      |
|      |                                          |          |
|      | YEAR (RTCC Year Value)                   | 102      |
| Rese | ets                                      |          |
|      | Brown-out Reset (BOR)                    | 53       |
|      |                                          |          |
|      | Clock Source Selection                   |          |
|      | Configuration Mismatch Reset (CM)        | 53       |
|      | Delay Times                              | 56       |
|      |                                          |          |
|      | Device Reset Times                       |          |
|      | Illegal Opcode Reset (IOPUWR)            | 53       |
|      | Master Clear Pin Reset (MCLR)            |          |
|      |                                          |          |
|      | Power-on Reset (POR)                     | 53       |
|      | RCON Flags Operation                     |          |
|      | SFR States                               |          |
|      |                                          |          |
|      | Software RESET Instruction (SWR)         |          |
|      | Trap Conflict Reset (TRAPR)              |          |
|      |                                          |          |
|      | Uninitialized W Register Reset (UWR)     |          |
|      | Watchdog Timer Reset (WDT)               | 53       |
|      |                                          |          |

| Revision History<br>RTCC | 267 |
|--------------------------|-----|
| Alarm Configuration      |     |
| Alarm Mask Settings      | 187 |
| Calibration              | 186 |
| Register Mapping         | 178 |
| Write Lock               | 178 |
|                          |     |

# S

| Serial Peripheral Interface. See SPI. |     |
|---------------------------------------|-----|
| SFR Space                             | 32  |
| Sleep Mode                            | 103 |
| Software Simulator (MPLAB SIM)        | 221 |
| Software Stack                        |     |
| Special Features                      | 8   |
| SPI                                   |     |
| Enhanced Buffer Master Mode Setup     | 143 |
| Enhanced Buffer Slave Mode Setup      | 143 |
| Standard Master Mode Setup            | 141 |
| Standard Slave Mode Setup             | 141 |
| т                                     |     |
| Timer1                                | 125 |
| Timer2/3 and Timer4/5                 | 127 |
| Timing Diagrams                       |     |
| CLKO and I/O                          |     |
| External Clock                        |     |

# U

| UART                                                   |
|--------------------------------------------------------|
| Baud Rate Generator (BRG) 160                          |
| Break and Sync Transmit Sequence 161                   |
| IrDA Support161                                        |
| Operation of UxCTS and UxRTS Control Pins 161          |
| Receiving in 8-Bit or 9-Bit Data Mode 161              |
| Transmitting in 8-Bit Data Mode 161                    |
| Transmitting in 9-Bit Data Mode 161                    |
| Universal Asynchronous Receiver Transmitter. See UART. |
| Unused I/Os                                            |

#### ۷

| VDDCORE/VCAP Pin            |     |
|-----------------------------|-----|
| Voltage Regulator (On-Chip) | 215 |
| and BOR                     | 215 |
| and POR                     | 216 |
| Low-Voltage Detection (LVD) | 215 |
| Standby Mode                | 216 |
| Tracking Mode               | 215 |
| Voltage Regulator Pins      | 19  |

#### W

| Watchdog Timer (WDT) |   |
|----------------------|---|
| Windowed Operation   |   |
| WWW Address          |   |
| WWW, On-Line Support | 6 |

## **PRODUCT IDENTIFICATION SYSTEM**

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

| Product Group<br>Pin Count<br>Tape and Reel Fi |                                                                                                                                   | <ul> <li>Examples:</li> <li>a) PIC24FJ32GA002-I/ML:<br/>General Purpose PIC24F, 32-Kbyte Program<br/>Memory, 28-Pin, Industrial Temp.,<br/>QFN Package.</li> <li>b) PIC24FJ64GA004-E/PT:<br/>General Purpose PIC24F, 64-Kbyte Program<br/>Memory, 44-Pin, Extended Temp.,<br/>TQFP Package.</li> </ul> |
|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Architecture                                   | 24 = 16-bit modified Harvard without DSP                                                                                          |                                                                                                                                                                                                                                                                                                        |
| Flash Memory Family                            | FJ = Flash program memory                                                                                                         |                                                                                                                                                                                                                                                                                                        |
| Product Group                                  | GA0 = General purpose microcontrollers                                                                                            |                                                                                                                                                                                                                                                                                                        |
| Pin Count                                      | 02 = 28-pin<br>04 = 44-pin                                                                                                        |                                                                                                                                                                                                                                                                                                        |
| Temperature Range                              | $E = -40^{\circ}C \text{ to } +125^{\circ}C \text{ (Extended)}$<br>I = -40^{\circ}C \text{ to } +85^{\circ}C \text{ (Industrial)} |                                                                                                                                                                                                                                                                                                        |
| Package                                        | SP = SPDIP<br>SO = SOIC<br>SS = SSOP<br>ML = QFN<br>PT = TQFP                                                                     |                                                                                                                                                                                                                                                                                                        |
| Pattern                                        | Three-digit QTP, SQTP, Code or Special Requirements<br>(blank otherwise)<br>ES = Engineering Sample                               |                                                                                                                                                                                                                                                                                                        |