



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             | Obsolete                                                                        |
| Core Processor             | MIPS32® M4K™                                                                    |
| Core Size                  | 32-Bit Single-Core                                                              |
| Speed                      | 40MHz                                                                           |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, PMP, SPI, UART/USART                            |
| Peripherals                | Brown-out Detect/Reset, DMA, I <sup>2</sup> S, POR, PWM, WDT                    |
| Number of I/O              | 35                                                                              |
| Program Memory Size        | 16KB (16K x 8)                                                                  |
| Program Memory Type        | FLASH                                                                           |
| EEPROM Size                |                                                                                 |
| RAM Size                   | 4K x 8                                                                          |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 3.6V                                                                     |
| Data Converters            | A/D 13x10b                                                                      |
| Oscillator Type            | Internal                                                                        |
| Operating Temperature      | -40°C ~ 105°C (TA)                                                              |
| Mounting Type              | Surface Mount                                                                   |
| Package / Case             | 44-VFTLA Exposed Pad                                                            |
| Supplier Device Package    | 44-VTLA (6x6)                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic32mx110f016dt-v-tl |
|                            |                                                                                 |

Email: info@E-XFL.COM

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

# 2.0 GUIDELINES FOR GETTING STARTED WITH 32-BIT MCUs

Note: This data sheet summarizes the features of the PIC32MX1XX/2XX 28/36/44-pin Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the documents listed in the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32).

# 2.1 Basic Connection Requirements

Getting started with the PIC32MX1XX/2XX 28/36/44pin Family of 32-bit Microcontrollers (MCUs) requires attention to a minimal set of device pin connections before proceeding with development. The following is a list of pin names, which must always be connected:

- All VDD and Vss pins (see 2.2 "Decoupling Capacitors")
- All AVDD and AVss pins, even if the ADC module is not used (see 2.2 "Decoupling Capacitors")
- VCAP pin (see 2.3 "Capacitor on Internal Voltage Regulator (VCAP)")
- MCLR pin (see 2.4 "Master Clear (MCLR) Pin")
- PGECx/PGEDx pins, used for In-Circuit Serial Programming™ (ICSP™) and debugging purposes (see **2.5** "ICSP Pins")
- OSC1 and OSC2 pins, when external oscillator source is used (see 2.7 "External Oscillator Pins")

The following pins may be required:

• VREF+/VREF- pins – used when external voltage reference for the ADC module is implemented

Note: The AVDD and AVss pins must be connected, regardless of ADC use and the ADC voltage reference source.

# 2.2 Decoupling Capacitors

The use of decoupling capacitors on power supply pins, such as VDD, VSS, AVDD and AVSS is required. See Figure 2-1.

Consider the following criteria when using decoupling capacitors:

- Value and type of capacitor: A value of 0.1  $\mu$ F (100 nF), 10-20V is recommended. The capacitor should be a low Equivalent Series Resistance (low-ESR) capacitor and have resonance frequency in the range of 20 MHz and higher. It is further recommended that ceramic capacitors be used.
- Placement on the printed circuit board: The decoupling capacitors should be placed as close to the pins as possible. It is recommended that the capacitors be placed on the same side of the board as the device. If space is constricted, the capacitor can be placed on another layer on the PCB using a via; however, ensure that the trace length from the pin to the capacitor is within one-quarter inch (6 mm) in length.
- Handling high frequency noise: If the board is experiencing high frequency noise, upward of tens of MHz, add a second ceramic-type capacitor in parallel to the above described decoupling capacitor. The value of the second capacitor can be in the range of 0.01  $\mu$ F to 0.001  $\mu$ F. Place this second capacitor next to the primary decoupling capacitor. In high-speed circuit designs, consider implementing a decade pair of capacitances as close to the power and ground pins as possible. For example, 0.1  $\mu$ F in parallel with 0.001  $\mu$ F.
- Maximizing performance: On the board layout from the power supply circuit, run the power and return traces to the decoupling capacitors first, and then to the device pins. This ensures that the decoupling capacitors are first in the power chain. Equally important is to keep the trace length between the capacitor and the power pins to a minimum thereby reducing PCB track inductance.



#### FIGURE 4-1: MEMORY MAP ON RESET FOR PIC32MX110/210 DEVICES (4 KB RAM, 16 KB FLASH)

### 9.1 DMA Control Registers

#### TABLE 9-1: DMA GLOBAL REGISTER MAP

| ess                         |           | Ċ,        |       |       |       |         |         |       |      | Bi       | ts        |      |      |      |      |      |           |      | s         |
|-----------------------------|-----------|-----------|-------|-------|-------|---------|---------|-------|------|----------|-----------|------|------|------|------|------|-----------|------|-----------|
| Virtual Address<br>(BF88_#) |           | Bit Range | 31/15 | 30/14 | 29/13 | 28/12   | 27/11   | 26/10 | 25/9 | 24/8     | 23/7      | 22/6 | 21/5 | 20/4 | 19/3 | 18/2 | 17/1      | 16/0 | All Reset |
| 2000                        | DMACON    | 31:16     | _     | _     | -     | —       | —       | _     | —    | —        | —         | -    | -    | _    | -    | -    | —         | _    | 0000      |
| 3000                        | DIVIACON  | 15:0      | ON    | —     | _     | SUSPEND | DMABUSY | —     | _    | —        | _         | —    | —    | —    | —    | —    | —         | _    | 0000      |
| 2010                        | DMASTAT   | 31:16     | -     | _     | —     | —       | —       | —     | —    | —        | _         | _    | _    | _    | _    | —    | —         | _    | 0000      |
| 3010                        | DIVIASTAT | 15:0      | -     | _     | —     | —       | —       | —     | —    | —        | _         | _    | _    | _    | RDWR | DI   | MACH<2:0> | .(2) | 0000      |
| 3020                        | DMAADDR   | 31:16     |       |       |       |         |         |       |      | DMAADD   | D-31:05   |      |      |      |      |      |           |      | 0000      |
| 3020                        | DIVIAADDR | 15:0      |       |       |       |         |         |       |      | DIVIAADL | vix~51.02 |      |      |      |      |      |           |      | 0000      |

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

Note 1: All registers in this table have corresponding CLR, SET and INV registers at its virtual address, plus an offset of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET and INV Registers" for more information.

#### TABLE 9-2: DMA CRC REGISTER MAP

| ess                         |                                 | â         |       |               | -     |       |              |           |      | В      | ts       |        | -      |      |      |      |           |      |            |
|-----------------------------|---------------------------------|-----------|-------|---------------|-------|-------|--------------|-----------|------|--------|----------|--------|--------|------|------|------|-----------|------|------------|
| Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14         | 29/13 | 28/12 | 27/11        | 26/10     | 25/9 | 24/8   | 23/7     | 22/6   | 21/5   | 20/4 | 19/3 | 18/2 | 17/1      | 16/0 | All Resets |
| 2020                        | DCRCCON                         | 31:16     | —     | _             | BYTO  | <1:0> | :0> WBO BITO |           |      |        |          |        |        | _    | 0000 |      |           |      |            |
| 3030                        | DURUUUN                         | 15:0      | —     | _             | —     |       |              | PLEN<4:0> |      |        | CRCEN    | CRCAPP | CRCTYP | —    | —    | C    | CRCCH<2:0 | >    | 0000       |
| 2040                        | DCRCDATA                        | 31:16     |       |               |       |       |              |           |      |        | TA<31:0> |        |        |      |      |      |           |      | 0000       |
| 3040                        | DURUDAIA                        | 15:0      |       |               |       |       |              |           |      | DURUDA | IA~51.02 |        |        |      |      |      |           |      | 0000       |
| 3050                        | DCRCXOR                         | 31:16     |       |               |       |       |              |           |      |        | D-21.05  |        |        |      |      |      |           |      | 0000       |
| 3050                        | DUNUAUR                         | 15:0      |       | DCRCXOR<31:0> |       |       |              |           |      |        |          |        |        |      |      |      |           |      |            |

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

Note 1: All registers in this table have corresponding CLR, SET and INV registers at their virtual addresses, plus offsets of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET and INV Registers" for more information.

# TABLE 9-3: DMA CHANNELS 0-3 REGISTER MAP (CONTINUED)

| ess                         |                                 | ē             |        |       |       |       | -      |       |      | Bi     | ts      |        |        |        |              |        |        |        | s          |
|-----------------------------|---------------------------------|---------------|--------|-------|-------|-------|--------|-------|------|--------|---------|--------|--------|--------|--------------|--------|--------|--------|------------|
| Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range     | 31/15  | 30/14 | 29/13 | 28/12 | 27/11  | 26/10 | 25/9 | 24/8   | 23/7    | 22/6   | 21/5   | 20/4   | 19/3         | 18/2   | 17/1   | 16/0   | All Resets |
| 3280                        | DCH2CPTR                        | 31:16         | —      | _     | _     | _     |        | _     |      | —      |         | _      | _      |        |              | _      | _      |        | 0000       |
| 5200                        | DONZOFIK                        | 15:0          |        |       |       |       |        |       |      | CHCPT  | R<15:0> |        |        |        |              |        |        |        | 0000       |
| 3290                        | DCH2DAT                         | 31:16         | _      | _     | —     | —     |        | _     |      | —      | _       | _      | —      | _      | —            | _      | _      |        | 0000       |
| 3290                        | DCHZDAI                         | 15:0          | _      |       |       |       |        |       |      |        |         |        |        |        | 0000         |        |        |        |            |
| 2240                        | DCH3CON                         | 31:16         | _      | _     | _     | _     | _      | _     | _    | _      | _       | _      | _      | _      | _            | _      | _      | _      | 0000       |
| 32A0                        | DCH3CON                         | 15:0          | CHBUSY |       |       |       |        |       |      |        |         |        |        | 0000   |              |        |        |        |            |
| 3280                        | DCH3ECON                        | 31:16         | —      |       |       |       |        |       |      |        |         |        | OOFF   |        |              |        |        |        |            |
| 5200                        |                                 | 15:0          |        |       |       | CHSIR | Q<7:0> |       |      |        | CFORCE  | CABORT | PATEN  | SIRQEN | AIRQEN       | _      | _      | _      | FF00       |
| 32C0                        | DCH3INT                         | 31:16         | —      | —     | —     | —     | -      | _     | -    | —      | CHSDIE  | CHSHIE | CHDDIE | CHDHIE | CHBCIE       | CHCCIE | CHTAIE | CHERIE | 0000       |
| 0200                        |                                 | 15:0          | —      |       |       | _     | —      | _     | —    | —      | CHSDIF  | CHSHIF | CHDDIF | CHDHIF | CHBCIF       | CHCCIF | CHTAIF | CHERIF | 0000       |
| 32D0                        | DCH3SSA                         | 31:16<br>15:0 |        |       |       |       |        |       |      | CHSSA  | <31:0>  |        |        |        |              |        |        |        | 0000       |
|                             |                                 | 31:16         |        |       |       |       |        |       |      |        |         |        |        |        |              |        |        |        | 0000       |
| 32E0                        | DCH3DSA                         | 15:0          |        |       |       |       |        |       |      | CHDSA  | <31:0>  |        |        |        |              |        |        |        | 0000       |
| 0050                        | DOI 100017                      | 31:16         |        | _     |       |       | _      | _     | _    |        |         |        |        |        |              | _      |        | _      | 0000       |
| 32FU                        | DCH3SSIZ                        | 15:0          |        |       |       |       |        |       |      | CHSSIZ | 2<15:0> |        |        |        |              |        |        |        | 0000       |
| 2200                        | DCH3DSIZ                        | 31:16         | —      | —     | —     | —     | _      | —     | _    | —      | _       | —      | —      | —      | —            | _      | —      | _      | 0000       |
| 3300                        | DCH3D3IZ                        | 15:0          |        |       |       |       |        |       |      | CHDSIZ | 2<15:0> |        |        |        |              |        |        |        | 0000       |
| 3310                        | DCH3SPTR                        | 31:16         | —      | _     | —     | _     |        |       |      | _      | —       |        | _      |        | _            |        |        |        | 0000       |
| 3310                        | DOI IJOF I K                    | 15:0          |        |       |       |       |        |       |      | CHSPTF | ۲<15:0> |        |        |        |              |        |        |        | 0000       |
| 3320                        | DCH3DPTR                        | 31:16         | —      | —     | —     | —     | _      | _     | _    | —      | _       | _      | —      | —      | —            | _      | —      | _      | 0000       |
| 0020                        |                                 | 15:0          |        |       |       |       |        |       |      | CHDPT  | R<15:0> |        |        |        |              |        |        |        | 0000       |
| 3330                        | <b>DCH3CSIZ</b>                 | 31:16         | —      | _     | —     | —     | —      | —     | —    | —      | —       | —      | —      | —      | —            | —      | —      | —      | 0000       |
|                             |                                 | 15:0          |        |       |       |       |        |       |      | CHCSIZ | 2<15:0> |        |        |        |              |        |        |        | 0000       |
| 3340                        | DCH3CPTR                        | 31:16         | _      | —     | —     | —     | _      | —     | _    | —      | _       | —      | —      | —      | —            | —      | —      | _      | 0000       |
|                             |                                 | 15:0          |        |       |       |       |        |       |      | CHCPT  | ≺<15:0> |        |        |        |              |        |        |        | 0000       |
| 3350                        | DCH3DAT                         | 31:16         | —      | _     | —     | _     | _      |       | —    | _      | _       | —      | —      | -      | —<br>T :7 0: | —      | —      | —      | 0000       |
| <u> </u>                    |                                 | 15:0          | —      | —     | —     | —     | —      | —     | —    | _      |         |        |        | CHPDA  | AT<7:0>      |        |        |        | 0000       |

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

Note 1: All registers in this table have corresponding CLR, SET and INV registers at their virtual addresses, plus offsets of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET and INV Registers" for more information.

| <b>NEGIST</b> | EGISTER 10-1. UTUTGIR. USB UTG INTERRUPT STATUS REGISTER |                   |                   |                   |                      |                   |                  |                  |  |  |  |  |
|---------------|----------------------------------------------------------|-------------------|-------------------|-------------------|----------------------|-------------------|------------------|------------------|--|--|--|--|
| Bit<br>Range  | Bit<br>31/23/15/7                                        | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3    | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
| 31:24         | U-0                                                      | U-0               | U-0               | U-0               | U-0                  | U-0               | U-0              | U-0              |  |  |  |  |
| 31.24         | -                                                        | —                 | —                 | -                 | -                    | —                 | -                | —                |  |  |  |  |
| 23:16         | U-0                                                      | U-0               | U-0               | U-0               | U-0                  | U-0               | U-0              | U-0              |  |  |  |  |
| 23.10         | -                                                        | —                 | —                 | -                 | U-0 U-0 U-0<br>— — — | —                 |                  |                  |  |  |  |  |
| 15:8          | U-0                                                      | U-0               | U-0               | U-0               | U-0                  | U-0               | U-0              | U-0              |  |  |  |  |
| 15.6          |                                                          | _                 | -                 |                   |                      | —                 |                  | —                |  |  |  |  |
| 7.0           | R/WC-0, HS                                               | R/WC-0, HS        | R/WC-0, HS        | R/WC-0, HS        | R/WC-0, HS           | R/WC-0, HS        | U-0              | R/WC-0, HS       |  |  |  |  |
| 7:0           | IDIF                                                     | T1MSECIF          | LSTATEIF          | ACTVIF            | SESVDIF              | SESENDIF          |                  | VBUSVDIF         |  |  |  |  |

# REGISTER 10-1: U1OTGIR: USB OTG INTERRUPT STATUS REGISTER

| Legend:           | WC = Write '1' to clear | HS = Hardware Settable b  | pit                |
|-------------------|-------------------------|---------------------------|--------------------|
| R = Readable bit  | W = Writable bit        | U = Unimplemented bit, re | ead as '0'         |
| -n = Value at POR | '1' = Bit is set        | '0' = Bit is cleared      | x = Bit is unknown |

bit 31-8 Unimplemented: Read as '0'

- bit 7 **IDIF:** ID State Change Indicator bit
  - 1 = A change in the ID state was detected
  - 0 = No change in the ID state was detected
- bit 6 T1MSECIF: 1 Millisecond Timer bit
  - 1 = 1 millisecond timer has expired
  - 0 = 1 millisecond timer has not expired

#### bit 5 LSTATEIF: Line State Stable Indicator bit

- 1 = USB line state has been stable for 1 ms, but different from last time
- 0 = USB line state has not been stable for 1 ms
- bit 4 ACTVIF: Bus Activity Indicator bit
  - 1 = Activity on the D+, D-, ID or VBUS pins has caused the device to wake-up
  - 0 = Activity has not been detected
- bit 3 SESVDIF: Session Valid Change Indicator bit
  - 1 = VBUS voltage has dropped below the session end level
  - 0 = VBUS voltage has not dropped below the session end level
- bit 2 SESENDIF: B-Device VBUS Change Indicator bit
  - 1 = A change on the session end input was detected
  - 0 = No change on the session end input was detected
- bit 1 Unimplemented: Read as '0'
- bit 0 VBUSVDIF: A-Device VBUS Change Indicator bit
  - 1 = A change on the session valid input was detected
  - 0 = No change on the session valid input was detected

#### REGISTER 10-8: U1EIR: USB ERROR INTERRUPT STATUS REGISTER (CONTINUED)

- bit 1 CRC5EF: CRC5 Host Error Flag bit<sup>(4)</sup>
  - 1 = Token packet rejected due to CRC5 error
  - 0 = Token packet accepted
  - EOFEF: EOF Error Flag bit<sup>(3,5)</sup>
  - 1 = An EOF error condition was detected
  - 0 = No EOF error condition was detected
- bit 0 PIDEF: PID Check Failure Flag bit
  - 1 = PID check failed
  - 0 = PID check passed
- **Note 1:** This type of error occurs when the module's request for the DMA bus is not granted in time to service the module's demand for memory, resulting in an overflow or underflow condition, and/or the allocated buffer size is not sufficient to store the received data packet causing it to be truncated.
  - **2:** This type of error occurs when more than 16-bit-times of Idle from the previous End-of-Packet (EOP) has elapsed.
  - **3:** This type of error occurs when the module is transmitting or receiving data and the SOF counter has reached zero.
  - 4: Device mode.
  - 5: Host mode.

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1                              | Bit<br>24/16/8/0 |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-----------------------------------------------|------------------|
| 21.24        | U-0                                           | U-0              |
| 31:24        |                   | _                 | —                 | —                 | _                 | —                 | _                                             | _                |
| 22:16        | U-0                                           | U-0              |
| 23:16        |                   | _                 | —                 | —                 |                   |                   | _                                             |                  |
| 15:0         | U-0                                           | U-0              |
| 15:8         |                   | —                 | —                 | —                 | —                 | -                 | —                                             | —                |
|              | R/W-0                                         | R/W-0            |
| 7:0          | BTSEE             | BMXEE             | DMAEE             | BTOEE             | DFN8EE            | CRC16EE           | CRC5EE <sup>(1)</sup><br>EOFEE <sup>(2)</sup> | PIDEE            |

#### REGISTER 10-9: U1EIE: USB ERROR INTERRUPT ENABLE REGISTER

#### Legend:

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

#### bit 31-8 Unimplemented: Read as '0'

|       | •                                                         |
|-------|-----------------------------------------------------------|
| bit 7 | BTSEE: Bit Stuff Error Interrupt Enable bit               |
|       | 1 = BTSEF interrupt is enabled                            |
|       | 0 = BTSEF interrupt is disabled                           |
| bit 6 | BMXEE: Bus Matrix Error Interrupt Enable bit              |
|       | 1 = BMXEF interrupt is enabled                            |
|       | 0 = BMXEF interrupt is disabled                           |
| bit 5 | DMAEE: DMA Error Interrupt Enable bit                     |
|       | 1 = DMAEF interrupt is enabled                            |
|       | 0 = DMAEF interrupt is disabled                           |
| bit 4 | BTOEE: Bus Turnaround Time-out Error Interrupt Enable bit |
|       | 1 = BTOEF interrupt is enabled                            |
|       | 0 = BTOEF interrupt is disabled                           |
| bit 3 | DFN8EE: Data Field Size Error Interrupt Enable bit        |
|       | 1 = DFN8EF interrupt is enabled                           |
|       | 0 = DFN8EF interrupt is disabled                          |

- bit 2 CRC16EE: CRC16 Failure Interrupt Enable bit
  - 1 = CRC16EF interrupt is enabled
  - 0 = CRC16EF interrupt is disabled
- bit 1 CRC5EE: CRC5 Host Error Interrupt Enable bit<sup>(1)</sup>
  - 1 = CRC5EF interrupt is enabled
  - 0 = CRC5EF interrupt is disabled
  - EOFEE: EOF Error Interrupt Enable bit<sup>(2)</sup>
  - 1 = EOF interrupt is enabled
  - 0 = EOF interrupt is disabled
- bit 0 PIDEE: PID Check Failure Interrupt Enable bit
  - 1 = PIDEF interrupt is enabled
  - 0 = PIDEF interrupt is disabled
- Note 1: Device mode.
  - 2: Host mode.

Note: For an interrupt to propagate the USBIF register, the UERRIE (U1IE<1>) bit must be set.

#### REGISTER 10-10: U1STAT: USB STATUS REGISTER

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| 31:24        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 31.24        |                   | —                 |                   |                   |                   | _                 | _                | —                |
| 23:16        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 23.10        | _                 | —                 |                   |                   |                   | _                 | _                | —                |
| 15:8         | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 15.0         | _                 | —                 |                   |                   |                   | _                 | _                | —                |
| 7:0          | R-x               | R-x               | R-x               | R-x               | R-x               | R-x               | U-0              | U-0              |
| 7.0          |                   | ENDP              | T<3:0>            |                   | DIR               | PPBI              |                  |                  |

#### Legend:

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

#### bit 31-8 Unimplemented: Read as '0'

- bit 7-4 **ENDPT<3:0>:** Encoded Number of Last Endpoint Activity bits (Represents the number of the Buffer Descriptor Table, updated by the last USB transfer.)
  - 1111 = Endpoint 15 1110 = Endpoint 14 . . 0001 = Endpoint 1 0000 = Endpoint 0
- bit 3 **DIR:** Last Buffer Descriptor Direction Indicator bit
  - 1 = Last transaction was a transmit (TX) transfer
    - 0 = Last transaction was a receive (RX) transfer
- bit 2 **PPBI:** Ping-Pong Buffer Descriptor Pointer Indicator bit
  - 1 = The last transaction was to the ODD Buffer Descriptor bank
  - 0 = The last transaction was to the EVEN Buffer Descriptor bank
- bit 1-0 Unimplemented: Read as '0'

**Note:** The U1STAT register is a window into a 4-byte FIFO maintained by the USB module. U1STAT value is only valid when the TRNIF (U1IR<3>) bit is active. Clearing the TRNIF bit advances the FIFO. Data in register is invalid when the TRNIF bit = 0.

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| 31:24        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |  |  |
| 31.24        | —                 | —                 | -                 | —                 | —                 | —                 | —                | —                |  |  |  |  |
| 22:16        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |  |  |
| 23:16        | —                 | —                 | -                 | —                 | —                 | —                 | —                | —                |  |  |  |  |
| 15:8         | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |  |  |
| 15.0         | —                 | —                 | -                 | —                 | —                 | —                 | —                | —                |  |  |  |  |
| 7:0          | U-0               | U-0               | U-0               | U-0               | U-0               | R-0               | R-0              | R-0              |  |  |  |  |
| 7.0          | —                 | —                 | _                 | —                 | —                 |                   | FRMH<2:0>        |                  |  |  |  |  |

#### REGISTER 10-14: U1FRMH: USB FRAME NUMBER HIGH REGISTER

#### Legend:

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

bit 31-3 Unimplemented: Read as '0'

bit 2-0 **FRMH<2:0>:** The Upper 3 bits of the Frame Numbers bits The register bits are updated with the current frame number whenever a SOF TOKEN is received.

#### Bit Bit Bit Bit Bit Bit Bit Bit Bit 30/22/14/6 27/19/11/3 26/18/10/2 25/17/9/1 24/16/8/0 Range 31/23/15/7 29/21/13/5 28/20/12/4 U-0 U-0 U-0 U-0 U-0 U-0 U-0 U-0 31:24 \_\_\_ \_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_ \_\_\_\_ U-0 U-0 U-0 U-0 U-0 U-0 U-0 U-0 23:16 \_\_\_\_ \_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_ U-0 U-0 U-0 U-0 U-0 U-0 U-0 U-0 15:8 \_ \_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_ \_\_\_\_ \_\_\_\_ R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 7:0 PID < 3:0 > (1)EP<3:0>

#### **REGISTER 10-15: U1TOK: USB TOKEN REGISTER**

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

#### bit 31-8 Unimplemented: Read as '0'

bit 7-4 **PID<3:0>:** Token Type Indicator bits<sup>(1)</sup>

1101 = SETUP (TX) token type transaction

- 1001 = IN (RX) token type transaction
- 0001 = OUT (TX) token type transaction

Note: All other values are reserved and must not be used.

bit 3-0 **EP<3:0>:** Token Command Endpoint Address bits The four bit value must specify a valid endpoint.

Note 1: All other values are reserved and must not be used.

# 11.4 Ports Control Registers

# TABLE 11-3: PORTA REGISTER MAP

| ess                         |                                 | 0         |       |       |       |       |       |                          |                       | Bits                    | 6                       |      |      |          |          |          |          |          | 6          |
|-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|--------------------------|-----------------------|-------------------------|-------------------------|------|------|----------|----------|----------|----------|----------|------------|
| Virtual Address<br>(BF88_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10                    | 25/9                  | 24/8                    | 23/7                    | 22/6 | 21/5 | 20/4     | 19/3     | 18/2     | 17/1     | 16/0     | All Resets |
| 6000                        | ANSELA                          | 31:16     | _     | —     | —     | —     | _     | _                        | _                     | _                       | —                       |      | _    | _        | _        | —        | —        | _        | 0000       |
|                             |                                 | 15:0      | _     | —     | —     | —     | —     | -                        |                       |                         | —                       | _    | —    | —        | _        | _        | ANSA1    | ANSA0    | 0003       |
| 6010                        | TRISA                           | 31:16     | _     | —     | —     | —     | —     | —                        |                       |                         | —                       | _    | —    |          | —        | _        | _        | —        | 0000       |
| 0010                        |                                 | 15:0      | —     | —     | —     | —     | _     | TRISA10 <sup>(2)</sup>   | TRISA9 <sup>(2)</sup> | TRISA8 <sup>(2)</sup>   | TRISA7 <sup>(2)</sup>   | _    | —    | TRISA4   | TRISA3   | TRISA2   | TRISA1   | TRISA0   | 079F       |
| 6020                        | PORTA                           | 31:16     | —     | —     | —     | —     | _     | —                        | —                     | _                       | —                       | _    | —    |          |          |          |          |          | 0000       |
| 0020                        |                                 | 15:0      | —     | —     | —     | —     | _     | RA10 <sup>(2)</sup>      | RA9 <sup>(2)</sup>    | RA8 <sup>(2)</sup>      | RA7 <sup>(2)</sup>      | _    | —    | RA4      | RA3      | RA2      | RA1      | RA0      | xxxx       |
| 6030                        | LATA                            | 31:16     | _     | —     | —     | —     | _     |                          | _                     | _                       | —                       | —    | —    | _        | _        | _        |          | _        | 0000       |
| 0000                        |                                 | 15:0      | —     | —     | —     | —     | —     | LATA10 <sup>(2)</sup>    | LATA9 <sup>(2)</sup>  | LATA8 <sup>(2)</sup>    | LATA7 <sup>(2)</sup>    | —    | —    | LATA4    | LATA3    | LATA2    | LATA1    | LATA0    | xxxx       |
| 6040                        | ODCA                            | 31:16     | —     | —     | —     | —     | —     | —                        |                       | _                       | —                       | —    | —    | —        |          | —        |          |          | 0000       |
| 0040                        | ODOA                            | 15:0      | —     | —     | —     | —     | —     | ODCA10 <sup>(2)</sup>    | ODCA9 <sup>(2)</sup>  | ODCA8 <sup>(2)</sup>    | ODCA7 <sup>(2)</sup>    | —    | —    | ODCA4    | ODCA3    | ODCA2    | ODCA1    | ODCA0    | 0000       |
| 6050                        | CNPUA                           | 31:16     | —     | —     | —     | —     | —     | —                        | _                     | _                       | —                       | —    | —    | —        |          | —        |          |          | 0000       |
| 0030                        | CINFUA                          | 15:0      | _     | _     | —     | —     | _     | CNPUA10 <sup>(2)</sup>   | CNPUA9 <sup>(2)</sup> | CNPUA8 <sup>(2)</sup>   | CNPUA7 <sup>(2)</sup>   | _    | —    | CNPUA4   | CNPUA3   | CNPUA2   | CNPUA1   | CNPUA0   | 0000       |
| 6060                        | CNPDA                           | 31:16     | —     | —     | —     | —     |       | _                        |                       |                         |                         | —    | —    |          |          | —        |          |          | 0000       |
| 0000                        | CINFDA                          | 15:0      | _     | _     | —     | —     | _     | CNPDA10 <sup>(2)</sup>   | CNPDA9 <sup>(2)</sup> | CNPDA8 <sup>(2)</sup>   | CNPDA7 <sup>(2)</sup>   | _    | —    | CNPDA4   | CNPDA3   | CNPDA2   | CNPDA1   | CNPDA0   | 0000       |
| 6070                        | CNCONA                          | 31:16     | —     | —     | —     | —     |       | _                        |                       | _                       | _                       | —    | —    |          |          | —        |          |          | 0000       |
| 0070                        | CINCONA                         | 15:0      | ON    | —     | SIDL  | —     | _     | _                        | _                     | _                       | —                       | _    | _    | _        | —        | —        | —        | —        | 0000       |
| 6080                        | CNENA                           | 31:16     | _     | —     | —     | —     | _     | _                        | _                     | _                       | —                       | _    | —    | —        | _        | _        | _        | _        | 0000       |
| 0000                        | CINEINA                         | 15:0      | _     | _     | —     | —     |       | CNIEA10 <sup>(2)</sup>   | CNIEA9 <sup>(2)</sup> | CNIEA8 <sup>(2)</sup>   | CNIEA7 <sup>(2)</sup>   |      |      | CNIEA4   | CNIEA3   | CNIEA2   | CNIEA1   | CNIEA0   | 0000       |
| 6000                        | CNISTATA                        | 31:16     | _     | _     | —     | —     |       |                          |                       |                         | _                       |      | _    |          |          | —        | _        |          | 0000       |
| 0090                        | CNSTATA                         | 15:0      | _     | _     | —     | —     |       | CNSTATA10 <sup>(2)</sup> | CNSTATA9(2)           | CNSTATA8 <sup>(2)</sup> | CNSTATA7 <sup>(2)</sup> |      |      | CNSTATA4 | CNSTATA3 | CNSTATA2 | CNSTATA1 | CNSTATA0 | 0000       |

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

Note 1: All registers in this table have corresponding CLR, SET and INV registers at their virtual addresses, plus offsets of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET and INV Registers" for more information.

2: This bit is only available on 44-pin devices.

| Bit<br>Range | Bit<br>31/23/15/7      | Bit<br>30/22/14/6  | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0      |
|--------------|------------------------|--------------------|-------------------|-------------------|-------------------|-------------------|------------------|-----------------------|
| 24.24        | R/W-0                  | R/W-0              | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0                 |
| 31:24        | FRMEN                  | FRMSYNC            | FRMPOL            | MSSEN             | FRMSYPW           | F                 | RMCNT<2:0        | >                     |
| 00.40        | R/W-0                  | U-0                | U-0               | U-0               | U-0               | U-0               | R/W-0            | R/W-0                 |
| 23:16        | MCLKSEL <sup>(2)</sup> | —                  |                   | —                 | —                 |                   | SPIFE            | ENHBUF <sup>(2)</sup> |
| 45.0         | R/W-0                  | U-0                | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0                 |
| 15:8         | ON <sup>(1)</sup>      | —                  | SIDL              | DISSDO            | MODE32            | MODE16            | SMP              | CKE <sup>(3)</sup>    |
| 7.0          | R/W-0                  | R/W-0              | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0                 |
| 7:0          | SSEN                   | CKP <sup>(4)</sup> | MSTEN             | DISSDI            | STXISE            | L<1:0>            | SRXIS            | EL<1:0>               |

#### REGISTER 17-1: SPIxCON: SPI CONTROL REGISTER

#### Legend:

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

bit 31 FRMEN: Framed SPI Support bit

- 1 = Framed SPI support is enabled (SSx pin used as FSYNC input/output)
  0 = Framed SPI support is disabled
- bit 30 **FRMSYNC:** Frame Sync Pulse Direction Control on <u>SSx</u> pin bit (Framed SPI mode only)
  - 1 = Frame sync pulse input (Slave mode)
  - 0 = Frame sync pulse output (Master mode)
- bit 29 FRMPOL: Frame Sync Polarity bit (Framed SPI mode only)
  - 1 = Frame pulse is active-high
  - 0 = Frame pulse is active-low
- bit 28 MSSEN: Master Mode Slave Select Enable bit
  - 1 = Slave select SPI support enabled. The SS pin is automatically driven during transmission in Master mode. Polarity is determined by the FRMPOL bit.
  - 0 = Slave select SPI support is disabled.
- bit 27 FRMSYPW: Frame Sync Pulse Width bit
  - 1 = Frame sync pulse is one character wide
  - 0 = Frame sync pulse is one clock wide
- bit 26-24 **FRMCNT<2:0>:** Frame Sync Pulse Counter bits. Controls the number of data characters transmitted per pulse. This bit is only valid in FRAMED\_SYNC mode.
  - 111 = Reserved; do not use
  - 110 = Reserved; do not use
  - 101 = Generate a frame sync pulse on every 32 data characters
  - 100 = Generate a frame sync pulse on every 16 data characters
  - 011 = Generate a frame sync pulse on every 8 data characters
  - 010 = Generate a frame sync pulse on every 4 data characters
  - 001 = Generate a frame sync pulse on every 2 data characters
  - 000 = Generate a frame sync pulse on every data character
- bit 23 MCLKSEL: Master Clock Enable bit<sup>(2)</sup>
  - 1 = REFCLK is used by the Baud Rate Generator
  - 0 = PBCLK is used by the Baud Rate Generator
- bit 22-18 Unimplemented: Read as '0'
- **Note 1:** When using the 1:1 PBCLK divisor, the user's software should not read or write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit.
  - 2: This bit can only be written when the ON bit = 0.
  - **3:** This bit is not used in the Framed SPI mode. The user should program this bit to '0' for the Framed SPI mode (FRMEN = 1).
  - 4: When AUDEN = 1, the SPI module functions as if the CKP bit is equal to '1', regardless of the actual value of CKP.

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| 04.04        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 31:24        |                   | _                 | _                 | _                 | —                 | -                 | _                | _                |
| 00.40        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 23:16        | —                 | _                 |                   | —                 | —                 | -                 | _                | _                |
| 45.0         | R/W-0             | U-0               | R/W-0             | R/W-0             | R/W-0             | U-0               | R/W-0            | R/W-0            |
| 15:8         | 0N <sup>(1)</sup> | _                 | SIDL              | IREN              | RTSMD             | _                 | UEN              | <1:0>            |
| 7.0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |
| 7:0          | WAKE              | LPBACK            | ABAUD             | RXINV             | BRGH              | PDSEL             | <1:0>            | STSEL            |

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

## Legend:

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

#### bit 31-16 Unimplemented: Read as '0'

- bit 15 ON: UARTx Enable bit<sup>(1)</sup>
  - 1 = UARTx is enabled. UARTx pins are controlled by UARTx as defined by the UEN<1:0> and UTXEN control bits.
  - 0 = UARTx is disabled. All UARTx pins are controlled by corresponding bits in the PORTx, TRISx and LATx registers; UARTx power consumption is minimal.
- bit 14 Unimplemented: Read as '0'

#### bit 13 **SIDL:** Stop in Idle Mode bit

- 1 = Discontinue module operation when the device enters Idle mode
- 0 = Continue module operation when the device enters Idle mode
- bit 12 IREN: IrDA Encoder and Decoder Enable bit
  - 1 = IrDA is enabled
  - 0 = IrDA is disabled
- bit 11 **RTSMD:** Mode Selection for UxRTS Pin bit
  - $1 = \overline{\text{UxRTS}}$  pin is in Simplex mode
  - $0 = \overline{\text{UxRTS}}$  pin is in Flow Control mode
- bit 10 Unimplemented: Read as '0'
- bit 9-8 UEN<1:0>: UARTx Enable bits
  - 11 = UxTX, UxRX and UxBCLK pins are enabled and used; UxCTS pin is controlled by corresponding bits in the PORTx register
  - 10 = UxTX, UxRX, UxCTS and UxRTS pins are enabled and used
  - 01 = UxTX, UxRX and UxRTS pins are enabled and used; UxCTS pin is controlled by corresponding bits in the PORTx register
  - 00 = UxTX and UxRX pins are enabled and used; UxCTS and UxRTS/UxBCLK pins are controlled by corresponding bits in the PORTx register
- bit 7 WAKE: Enable Wake-up on Start bit Detect During Sleep Mode bit
  - 1 = Wake-up enabled
  - 0 = Wake-up disabled
- bit 6 LPBACK: UARTx Loopback Mode Select bit
  - 1 = Loopback mode is enabled
  - 0 = Loopback mode is disabled
- **Note 1:** When using 1:1 PBCLK divisor, the user software should not read/write the peripheral SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit.

| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| 04.04        | U-0               | U-0               | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x            | R/W-x            |
| 31:24        |                   |                   | HR10              | <1:0>             |                   | HR01              | <3:0>            |                  |
| 00.40        | U-0               | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x            | R/W-x            |
| 23:16        |                   |                   | MIN10<2:0>        |                   |                   | MIN01             | <3:0>            |                  |
| 45.0         | U-0               | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x            | R/W-x            |
| 15:8         |                   |                   | SEC10<2:0>        |                   |                   | SEC01             | <3:0>            |                  |
| 7.0          | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 7:0          | _                 | _                 | —                 | —                 | —                 | _                 | —                | —                |
|              |                   |                   |                   |                   |                   |                   |                  |                  |
| Leaend:      |                   |                   |                   |                   |                   |                   |                  |                  |

#### REGISTER 21-5: ALRMTIME: ALARM TIME VALUE REGISTER

# R = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown

bit 31-30 Unimplemented: Read as '0'

bit 29-28 HR10<1:0>: Binary Coded Decimal value of hours bits, 10s place digit; contains a value from 0 to 2

bit 27-24 **HR01<3:0>:** Binary Coded Decimal value of hours bits, 1s place digit; contains a value from 0 to 9 bit 23 **Unimplemented:** Read as '0'

bit 22-20 MIN10<2:0>: Binary Coded Decimal value of minutes bits, 10s place digit; contains a value from 0 to 5

bit 19-16 **MIN01<3:0>:** Binary Coded Decimal value of minutes bits, 1s place digit; contains a value from 0 to 9 bit 15 **Unimplemented:** Read as '0'

bit 14-12 SEC10<2:0>: Binary Coded Decimal value of seconds bits, 10s place digit; contains a value from 0 to 5

bit 11-8 **SEC01<3:0>:** Binary Coded Decimal value of seconds bits, 1s place digit; contains a value from 0 to 9

bit 7-0 Unimplemented: Read as '0'

## 23.1 Comparator Control Registers

#### TABLE 23-1: COMPARATOR REGISTER MAP

| ess                         |                                 | 0         |       |       |       |       |       |       |      | Bi   | its  |        |      |      |      |       |       |       |           |
|-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|------|--------|------|------|------|-------|-------|-------|-----------|
| Virtual Address<br>(BF80_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8 | 23/7 | 22/6   | 21/5 | 20/4 | 19/3 | 18/2  | 17/1  | 16/0  | All Reset |
| 4000                        | CM1CON                          | 31:16     | _     | _     | -     | _     | -     | _     |      | -    | —    | _      | -    | —    | —    | —     | _     | —     | 0000      |
| A000                        | CIVITCON                        | 15:0      | ON    | COE   | CPOL  | _     | -     | _     | _    | COUT | EVPO | L<1:0> | -    | CREF | _    | —     | CCH   | <1:0> | 00C3      |
| A010                        | CM2CON                          | 31:16     | _     | _     |       | _     |       | _     |      |      | _    | _      |      | _    | _    | _     | _     | _     | 0000      |
| 7010                        | CIVIZCON                        | 15:0      | ON    | COE   | CPOL  |       | -     |       | -    | COUT | EVPO | L<1:0> | -    | CREF | —    | —     | CCH   | <1:0> | 00C3      |
| A020                        | CM3CON                          | 31:16     | -     |       |       |       | -     |       | -    | -    | —    | —      | -    | _    | —    | —     |       | —     | 0000      |
| A020                        | CIVISCON                        | 15:0      | ON    | COE   | CPOL  | _     | —     | _     | —    | COUT | EVPO | L<1:0> | —    | CREF | _    | —     | CCH   | <1:0> | 00C3      |
| A060                        | CMSTAT                          | 31:16     | _     | —     | _     | _     | -     | _     | _    |      | —    | _      | -    | _    | _    | —     | _     | —     | 0000      |
| 7000                        | CIVISTAI                        | 15:0      | _     | _     | SIDL  | _     |       | _     |      |      | -    | _      |      | _    | -    | C3OUT | C2OUT | C10UT | 0000      |

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

Note 1: All registers in this table have corresponding CLR, SET and INV registers at their virtual addresses, plus offsets of 0x4, 0x8 and 0xC, respectively. See Section 11.2 "CLR, SET and INV Registers" for more information.

# 26.0 POWER-SAVING FEATURES

| Note: | This data sheet summarizes the features<br>of the PIC32MX1XX/2XX 28/36/44-pin<br>Family of devices. It is not intended to be<br>a comprehensive reference source. To<br>complement the information in this data<br>sheet, refer to <b>Section 10. "Power-</b><br><b>Saving Features"</b> (DS60001130), which<br>is available from the <i>Documentation</i> ><br><i>Reference Manual</i> section of the<br>Microchip PIC32 web site |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | (www.microchip.com/pic32).                                                                                                                                                                                                                                                                                                                                                                                                         |
|       | (                                                                                                                                                                                                                                                                                                                                                                                                                                  |

This section describes power-saving features for the PIC32MX1XX/2XX 28/36/44-pin Family. The PIC32 devices offer a total of nine methods and modes, organized into two categories, that allow the user to balance power consumption with device performance. In all of the methods and modes described in this section, power-saving is controlled by software.

# 26.1 Power Saving with CPU Running

When the CPU is running, power consumption can be controlled by reducing the CPU clock frequency, lowering the PBCLK and by individually disabling modules. These methods are grouped into the following categories:

- FRC Run mode: the CPU is clocked from the FRC clock source with or without postscalers
- LPRC Run mode: the CPU is clocked from the LPRC clock source
- Sosc Run mode: the CPU is clocked from the Sosc clock source

In addition, the Peripheral Bus Scaling mode is available where peripherals are clocked at the programmable fraction of the CPU clock (SYSCLK).

# 26.2 CPU Halted Methods

The device supports two power-saving modes, Sleep and Idle, both of which Halt the clock to the CPU. These modes operate with all clock sources, as follows:

- Posc Idle mode: the system clock is derived from the Posc. The system clock source continues to operate. Peripherals continue to operate, but can optionally be individually disabled.
- FRC Idle mode: the system clock is derived from the FRC with or without postscalers. Peripherals continue to operate, but can optionally be individually disabled.
- Sosc Idle mode: the system clock is derived from the Sosc. Peripherals continue to operate, but can optionally be individually disabled.

- LPRC Idle mode: the system clock is derived from the LPRC. Peripherals continue to operate, but can optionally be individually disabled. This is the lowest power mode for the device with a clock running.
- Sleep mode: the CPU, the system clock source and any peripherals that operate from the system clock source are Halted. Some peripherals can operate in Sleep using specific clock sources. This is the lowest power mode for the device.

# 26.3 Power-Saving Operation

Peripherals and the CPU can be Halted or disabled to further reduce power consumption.

## 26.3.1 SLEEP MODE

Sleep mode has the lowest power consumption of the device power-saving operating modes. The CPU and most peripherals are Halted. Select peripherals can continue to operate in Sleep mode and can be used to wake the device from Sleep. See the individual peripheral module sections for descriptions of behavior in Sleep.

Sleep mode includes the following characteristics:

- The CPU is halted
- The system clock source is typically shutdown. See Section 26.3.3 "Peripheral Bus Scaling Method" for specific information.
- There can be a wake-up delay based on the oscillator selection
- The Fail-Safe Clock Monitor (FSCM) does not operate during Sleep mode
- The BOR circuit remains operative during Sleep mode
- The WDT, if enabled, is not automatically cleared prior to entering Sleep mode
- Some peripherals can continue to operate at limited functionality in Sleep mode. These peripherals include I/O pins that detect a change in the input signal, WDT, ADC, UART and peripherals that use an external clock input or the internal LPRC oscillator (e.g., RTCC, Timer1 and Input Capture).
- I/O pins continue to sink or source current in the same manner as they do when the device is not in Sleep
- The USB module can override the disabling of the Posc or FRC. Refer to the USB section for specific details.
- Modules can be individually disabled by software prior to entering Sleep in order to further reduce consumption

#### TABLE 30-4: DC TEMPERATURE AND VOLTAGE SPECIFICATIONS

| DC CHA        | ARACTER   | ISTICS                                                           | $\begin{array}{l} \mbox{Standard Operating Conditions: 2.3V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for Industria} \\ & -40^{\circ}C \leq TA \leq +105^{\circ}C \mbox{ for V-temp} \end{array}$ |      |       |       |            |  |  |  |  |
|---------------|-----------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------|------------|--|--|--|--|
| Param.<br>No. | Symbol    | Characteristics                                                  | Min.                                                                                                                                                                                                                                                                                 | Тур. | Max.  | Units | Conditions |  |  |  |  |
| Operati       | ng Voltag | e                                                                |                                                                                                                                                                                                                                                                                      |      |       |       |            |  |  |  |  |
| DC10          | Vdd       | Supply Voltage (Note 2)                                          | 2.3                                                                                                                                                                                                                                                                                  |      | 3.6   | V     | —          |  |  |  |  |
| DC12          | Vdr       | RAM Data Retention Voltage<br>(Note 1)                           | 1.75                                                                                                                                                                                                                                                                                 | _    | —     | V     | _          |  |  |  |  |
| DC16          | VPOR      | VDD Start Voltage<br>to Ensure Internal Power-on Reset<br>Signal | 1.75                                                                                                                                                                                                                                                                                 | —    | 2.1   | V     | _          |  |  |  |  |
| DC17          | SVDD      | VDD Rise Rate<br>to Ensure Internal Power-on Reset<br>Signal     | 0.00005                                                                                                                                                                                                                                                                              | _    | 0.115 | V/μs  | _          |  |  |  |  |

**Note 1:** This is the limit to which VDD can be lowered without losing RAM data.

2: Overall functional device operation at VBORMIN < VDD < VDDMIN is tested, but not characterized. All device Analog modules, such as ADC, etc., will function, but with degraded performance below VDDMIN. Refer to parameter BO10 in Table 30-11 for BOR values.

#### TABLE 30-34: ADC MODULE SPECIFICATIONS

|               | AC CHAR    | ACTERISTICS                       | (unless otl | herwise stat | <b>ed)</b><br>-40°C ≤ TA | √≤ +85° | e 5): 2.5V to 3.6V<br>C for Industrial<br>°C for V-temp |
|---------------|------------|-----------------------------------|-------------|--------------|--------------------------|---------|---------------------------------------------------------|
| Param.<br>No. | Symbol     | Characteristics                   | Min.        | Typical      | Max.                     | Units   | Conditions                                              |
| ADC Ac        | curacy – N | leasurements with Inter           | nal VREF+/V | REF-         |                          |         | •                                                       |
| AD20d         | Nr         | Resolution                        |             | 10 data bits | 3                        | bits    | (Note 3)                                                |
| AD21d         | INL        | Integral Non-linearity            | > -1        | _            | < 1                      | LSb     | VINL = AVSS = 0V,<br>AVDD = 2.5V to 3.6V<br>(Note 3)    |
| AD22d         | DNL        | Differential Non-linearity        | > -1        | —            | < 1                      | LSb     | VINL = AVss = 0V,<br>AVDD = 2.5V to 3.6V<br>(Notes 2,3) |
| AD23d         | Gerr       | Gain Error                        | > -4        | _            | < 4                      | LSb     | VINL = AVSS = 0V,<br>AVDD = 2.5V to 3.6V<br>(Note 3)    |
| AD24d         | EOFF       | Offset Error                      | > -2        | _            | < 2                      | Lsb     | VINL = AVSS = 0V,<br>AVDD = 2.5V to 3.6V<br>(Note 3)    |
| AD25d         |            | Monotonicity                      |             |              | _                        | _       | Guaranteed                                              |
| Dynami        | c Performa | ance                              | ·           |              |                          |         |                                                         |
| AD32b         | SINAD      | Signal to Noise and<br>Distortion | 55          | 58.5         | _                        | dB      | (Notes 3,4)                                             |
| AD34b         | ENOB       | Effective Number of bits          | 9.0         | 9.5          |                          | bits    | (Notes 3,4)                                             |

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

2: With no missing codes.

3: These parameters are characterized, but not tested in manufacturing.

4: Characterized with a 1 kHz sine wave.

**5:** The ADC module is functional at VBORMIN < VDD < 2.5V, but with degraded performance. Unless otherwise stated, module functionality is tested, but not characterized.

## 28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC]

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



Microchip Technology Drawing C04-052C Sheet 1 of 2

| TABLE A-1: | MAJOR SECTION UPDATES (CONTINUED) |
|------------|-----------------------------------|
|------------|-----------------------------------|

| Section                           | Update Description                                                                                                                                    |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29.0 "Electrical Characteristics" | Updated the Absolute Maximum Ratings (removed Voltage on VCORE with respect to Vss).                                                                  |
|                                   | Added the SPDIP specification to the Thermal Packaging Characteristics (see Table 29-2).                                                              |
|                                   | Updated the Typical values for parameters DC20-DC24 in the Operating Current (IDD) specification (see Table 29-5).                                    |
|                                   | Updated the Typical values for parameters DC30a-DC34a in the Idle Current (IIDLE) specification (see Table 29-6).                                     |
|                                   | Updated the Typical values for parameters DC40i and DC40n and removed parameter DC40m in the Power-down Current (IPD) specification (see Table 29-7). |
|                                   | Removed parameter D320 (VCORE) from the Internal Voltage Regulator Specifications and updated the Comments (see Table 29-13).                         |
|                                   | Updated the Minimum, Typical, and Maximum values for parameter F20b in the Internal FRC Accuracy specification (see Table 29-17).                     |
|                                   | Removed parameter SY01 (TPWRT) and removed all Conditions from Resets Timing (see Table 29-20).                                                       |
|                                   | Updated all parameters in the CTMU Specifications (see Table 29-39).                                                                                  |
| 31.0 "Packaging Information"      | Added the 28-lead SPDIP package diagram information (see <b>31.1</b> "Package Marking Information" and <b>31.2</b> "Package Details").                |
| "Product Identification System"   | Added the SPDIP (SP) package definition.                                                                                                              |

# Revision C (November 2011)

All major changes are referenced by their respective section in Table A-2.

| TABLE A-2: | MAJOR SECTION UPDATES |
|------------|-----------------------|
|------------|-----------------------|

| Section                                                                                                                             | Update Description                                                                                                                                                                   |
|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "32-bit Microcontrollers (up to 128 KB<br>Flash and 32 KB SRAM) with Audio<br>and Graphics Interfaces, USB, and<br>Advanced Analog" | Revised the source/sink on I/O pins (see "Input/Output" on page 1).<br>Added the SPDIP package to the PIC32MX220F032B device in the<br>PIC32MX2XX USB Family Features (see Table 2). |
| 4.0 "Memory Organization"                                                                                                           | Removed ANSB6 from the ANSELB register and added the ODCB6, ODCB10, and ODCB11 bits in the PORTB Register Map (see Table 4-20).                                                      |
| 29.0 "Electrical Characteristics"                                                                                                   | Updated the minimum value for parameter OS50 in the PLL Clock Timing Specifications (see Table 29-16).                                                                               |

| U1OTGSTAT (USB OTG Status)       | 110 |
|----------------------------------|-----|
| U1PWRC (USB Power Control)       | 112 |
| U1SOF (USB SOF Threshold)        | 123 |
| U1STAT (USB Status)              | 118 |
| U1TOK (USB Token)                | 122 |
| UxMODE (UARTx Mode)              | 183 |
| UxSTA (UARTx Status and Control) | 185 |
| WDTCON (Watchdog Timer Control)  | 155 |
| Resets                           |     |
| Revision History                 | 329 |
| RTCALRM (RTC ALARM Control)      | 203 |

# S

| Serial Peripheral Interface (SPI) | 165 |
|-----------------------------------|-----|
| Software Simulator (MPLAB SIM)    |     |
| Special Features                  | 239 |

# Т

| Timer1 Module<br>Timer2/3, Timer4/5 Modules<br>Timing Diagrams |     |
|----------------------------------------------------------------|-----|
| 10-Bit Analog-to-Digital Conversion                            |     |
| (ASAM = 0, SSRC<2:0> = 000)                                    | 293 |
| 10-Bit Analog-to-Digital Conversion (ASAM = 1,                 |     |
| SSRC<2:0> = 111, SAMC<4:0> = 00001)                            | 294 |
| EJTAG                                                          | 300 |
| External Clock                                                 | 269 |
| I/O Characteristics                                            | 272 |
| I2Cx Bus Data (Master Mode)                                    | 283 |
| I2Cx Bus Data (Slave Mode)                                     | 286 |
| I2Cx Bus Start/Stop Bits (Master Mode)                         | 283 |
| I2Cx Bus Start/Stop Bits (Slave Mode)                          | 286 |
| Input Capture (CAPx)                                           | 276 |
| OCx/PWM                                                        |     |
| Output Compare (OCx)                                           | 277 |
| Parallel Master Port Read                                      | 296 |
| Parallel Master Port Write                                     | 297 |
|                                                                |     |

| Parallel Slave Port                      | . 295 |
|------------------------------------------|-------|
| SPIx Master Mode (CKE = 0)               | . 278 |
| SPIx Master Mode (CKE = 1)               | . 279 |
| SPIx Slave Mode (CKE = 0)                | . 280 |
| SPIx Slave Mode (CKE = 1)                | . 281 |
| Timer1, 2, 3, 4, 5 External Clock        | . 275 |
| UART Reception                           | . 187 |
| UART Transmission (8-bit or 9-bit Data)  | . 187 |
| Timing Requirements                      |       |
| CLKO and I/O                             | . 272 |
| Timing Specifications                    |       |
| I2Cx Bus Data Requirements (Master Mode) |       |
| I2Cx Bus Data Requirements (Slave Mode)  |       |
| Input Capture Requirements               |       |
| Output Compare Requirements              |       |
| Simple OCx/PWM Mode Requirements         |       |
| SPIx Master Mode (CKE = 0) Requirements  |       |
| SPIx Master Mode (CKE = 1) Requirements  |       |
| SPIx Slave Mode (CKE = 1) Requirements   |       |
| SPIx Slave Mode Requirements (CKE = 0)   | . 280 |
| Timing Specifications (50 MHz)           |       |
| SPIx Master Mode (CKE = 0) Requirements  |       |
| SPIx Master Mode (CKE = 1) Requirements  |       |
| SPIx Slave Mode (CKE = 1) Requirements   |       |
| SPIx Slave Mode Requirements (CKE = 0)   | . 305 |
| U                                        |       |
|                                          | 101   |

| UART                |     |
|---------------------|-----|
| USB On-The-Go (OTG) | 103 |
| V                   |     |
| VCAP nin            | 250 |

| VCAP pin                    |     |
|-----------------------------|-----|
| Voltage Regulator (On-Chip) | 250 |
|                             |     |
| W                           |     |
| M/M/M/ Addross              | 2/1 |

| WWW Address          | . 341 |
|----------------------|-------|
| WWW, On-Line Support | 16    |