

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

E·XFI

| 2 0 0 0 0 0                |                                                                                |
|----------------------------|--------------------------------------------------------------------------------|
| Product Status             | Active                                                                         |
| Core Processor             | MIPS32® M4K™                                                                   |
| Core Size                  | 32-Bit Single-Core                                                             |
| Speed                      | 40MHz                                                                          |
| Connectivity               | CANbus, I <sup>2</sup> C, IrDA, LINbus, PMP, SPI, UART/USART, USB OTG          |
| Peripherals                | Brown-out Detect/Reset, DMA, I <sup>2</sup> S, POR, PWM, WDT                   |
| Number of I/O              | 49                                                                             |
| Program Memory Size        | 256KB (256K x 8)                                                               |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                |                                                                                |
| RAM Size                   | 32K x 8                                                                        |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 3.6V                                                                    |
| Data Converters            | A/D 28x10b                                                                     |
| Oscillator Type            | Internal                                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                              |
| Mounting Type              | Surface Mount                                                                  |
| Package / Case             | 64-VFQFN Exposed Pad                                                           |
| Supplier Device Package    | 64-QFN (9x9)                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic32mx550f256h-i-mr |
|                            |                                                                                |

Email: info@E-XFL.COM

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

# PIC32MX1XX/2XX/5XX 64/100-PIN FAMILY

| TABLE 1-1: | <b>PINOUT I/O DESCRIPTIONS (</b> | (CONTINUED) |
|------------|----------------------------------|-------------|
|            |                                  |             |

|          | Pin N                  | umber           |             |                |                                                                                             |  |  |  |  |  |
|----------|------------------------|-----------------|-------------|----------------|---------------------------------------------------------------------------------------------|--|--|--|--|--|
| Pin Name | 64-pin<br>QFN/<br>TQFP | 100-pin<br>TQFP | Pin<br>Type | Buffer<br>Type | Description                                                                                 |  |  |  |  |  |
| RTCC     | 42                     | 68              | 0           |                | Real-Time Clock Alarm Output                                                                |  |  |  |  |  |
| CVREFOUT | 23                     | 34              | 0           | Analog         | Comparator Voltage Reference (Output)                                                       |  |  |  |  |  |
| C1INA    | 11                     | 20              | Ι           | Analog         |                                                                                             |  |  |  |  |  |
| C1INB    | 12                     | 21              | Ι           | Analog         |                                                                                             |  |  |  |  |  |
| C1INC    | 5                      | 11              | Ι           | Analog         | Comparator 1 Inputs                                                                         |  |  |  |  |  |
| C1IND    | 4                      | 10              | Ι           | Analog         |                                                                                             |  |  |  |  |  |
| C2INA    | 13                     | 22              | Ι           | Analog         |                                                                                             |  |  |  |  |  |
| C2INB    | 14                     | 23              | Ι           | Analog         | Comporator 2 Inputa                                                                         |  |  |  |  |  |
| C2INC    | 8                      | 14              | Ι           | Analog         | Comparator 2 Inputs                                                                         |  |  |  |  |  |
| C2IND    | 6                      | 12              | Ι           | Analog         |                                                                                             |  |  |  |  |  |
| C3INA    | 58                     | 87              | Ι           | Analog         |                                                                                             |  |  |  |  |  |
| C3INB    | 55                     | 84              | Ι           | Analog         | Comporator 2 Inputa                                                                         |  |  |  |  |  |
| C3INC    | 54                     | 83              | Ι           | Analog         | Comparator 3 Inputs                                                                         |  |  |  |  |  |
| C3IND    | 51                     | 78              | Ι           | Analog         |                                                                                             |  |  |  |  |  |
| C1OUT    | PPS                    | PPS             | 0           | _              | Comparator 1 Output                                                                         |  |  |  |  |  |
| C2OUT    | PPS                    | PPS             | 0           | _              | Comparator 2 Output                                                                         |  |  |  |  |  |
| C3OUT    | PPS                    | PPS             | 0           | _              | Comparator 3 Output                                                                         |  |  |  |  |  |
| PMALL    | 30                     | 44              | 0           | TTL/ST         | Parallel Master Port Address Latch Enable Low Byte                                          |  |  |  |  |  |
| PMALH    | 29                     | 43              | 0           | TTL/ST         | Parallel Master Port Address Latch Enable High Byte                                         |  |  |  |  |  |
| PMA0     | 30                     | 44              | 0           | TTL/ST         | Parallel Master Port Address bit 0 Input (Buffered Slave modes) and Output (Master modes)   |  |  |  |  |  |
| PMA1     | 29                     | 43              | 0           | TTL/ST         | T Parallel Master Port Address bit 0 Input (Buffered Slave modes) and Output (Master modes) |  |  |  |  |  |
| Legend:  | CMOS = CN              | IOS compat      | ible inpu   | it or output   | Analog = Analog input I = Input O = Output                                                  |  |  |  |  |  |

**Legend:** CMOS = CMOS compatible input or output Analog = Analog input I = Input ST = Schmitt Trigger input with CMOS levels TTL = TTL input buffer P = Power

Note 1: This pin is only available on devices without a USB module.

2: This pin is only available on devices with a USB module.

3: This pin is not available on 64-pin devices with a USB module.

4: This pin is only available on 100-pin devices without a USB module.

The MIPS architecture defines that the result of a multiply or divide operation be placed in the HI and LO registers. Using the Move-From-HI (MFHI) and Move-From-LO (MFLO) instructions, these values can be transferred to the General Purpose Register file.

In addition to the HI/LO targeted operations, the MIPS32<sup>®</sup> architecture also defines a multiply instruction, MUL, which places the least significant results in the primary register file instead of the HI/LO register pair. By avoiding the explicit MFLO instruction required when using the LO register, and by supporting multiple destination registers, the throughput of multiply-intensive operations is increased.

Two other instructions, Multiply-Add (MADD) and Multiply-Subtract (MSUB), are used to perform the multiply-accumulate and multiply-subtract operations. The MADD instruction multiplies two numbers and then adds the product to the current contents of the HI and LO registers. Similarly, the MSUB instruction multiplies two operands and then subtracts the product from the HI and LO registers. The MADD and MSUB operations are commonly used in DSP algorithms.

### 3.2.3 SYSTEM CONTROL COPROCESSOR (CP0)

In the MIPS architecture, CP0 is responsible for the virtual-to-physical address translation, the exception control system, the processor's diagnostics capability, the operating modes (Kernel, User and Debug) and whether interrupts are enabled or disabled. Configuration information, such as presence of options like MIPS16e<sup>®</sup>, is also available by accessing the CP0 registers, listed in Table 3-2.

| Register<br>Name        | Function                                                                                                                                                              |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                | Reserved in the PIC32MX1XX/2XX/5XX 64/100-pin family core.                                                                                                            |
| HWREna                  | Enables access via the RDHWR instruction to selected hardware registers.                                                                                              |
| BadVAddr <sup>(1)</sup> | Reports the address for the most recent address-related exception.                                                                                                    |
| Count <sup>(1)</sup>    | Processor cycle count.                                                                                                                                                |
| Reserved                | Reserved in the PIC32MX1XX/2XX/5XX 64/100-pin family core.                                                                                                            |
| Compare <sup>(1)</sup>  | Timer interrupt control.                                                                                                                                              |
| Status <sup>(1)</sup>   | Processor status and control.                                                                                                                                         |
| IntCtl <sup>(1)</sup>   | Interrupt system status and control.                                                                                                                                  |
| Cause <sup>(1)</sup>    | Cause of last general exception.                                                                                                                                      |
| EPC <sup>(1)</sup>      | Program counter at last exception.                                                                                                                                    |
| PRId                    | Processor identification and revision.                                                                                                                                |
| EBASE                   | Exception vector base register.                                                                                                                                       |
| Config                  | Configuration register.                                                                                                                                               |
| Config1                 | Configuration register 1.                                                                                                                                             |
| Config2                 | Configuration register 2.                                                                                                                                             |
| Config3                 | Configuration register 3.                                                                                                                                             |
| Reserved                | Reserved in the PIC32MX1XX/2XX/5XX 64/100-pin family core.                                                                                                            |
| Debug <sup>(2)</sup>    | Debug control and exception status.                                                                                                                                   |
| DEPC <sup>(2)</sup>     | Program counter at last debug exception.                                                                                                                              |
| Reserved                | Reserved in the PIC32MX1XX/2XX/5XX 64/100-pin family core.                                                                                                            |
| ErrorEPC <sup>(1)</sup> | Program counter at last error.                                                                                                                                        |
| DESAVE <sup>(2)</sup>   | Debug handler scratchpad register.                                                                                                                                    |
|                         | NameReservedHWREnaBadVAddr(1)Count(1)ReservedCompare(1)Status(1)IntCtl(1)Cause(1)EPC(1)PRIdEBASEConfigConfig1Config2Config3ReservedDebug(2)DEPC(2)ReservedErrorEPC(1) |

| TABLE 3-2. COPROCESSOR UREGISTERS | <b>TABLE 3-2:</b> | <b>COPROCESSOR 0 REGISTERS</b> |
|-----------------------------------|-------------------|--------------------------------|
|-----------------------------------|-------------------|--------------------------------|

Note 1: Registers used in exception processing.

**2:** Registers used during debug.

### 7.1 Control Registers

### TABLE 7-1: RESET SFR SUMMARY

| ess                         |                                 |           |       | Bits  |       |       |       |       |      |       |      |      |      |      |       |      |      |       |                     |
|-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-------|------|------|------|------|-------|------|------|-------|---------------------|
| 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 Resets          |
| F600                        | RCON                            | 31:16     |       | —     | HVDR  | —     | —     | —     | —    | —     | —    | —    | —    | —    | —     | —    | —    |       | 0000                |
| F000                        | RCON                            | 15:0      |       | _     | —     | _     | _     | —     | CMR  | VREGS | EXTR | SWR  | _    | WDTO | SLEEP | IDLE | BOR  | POR   | <sub>xxxx</sub> (1) |
| <b>F610</b>                 | DOWDOT                          | 31:16     | _     | _     | —     | —     | _     | _     | _    | —     | _    | _    | _    | —    | _     | _    | -    | —     | 0000                |
| F610                        | RSWRST                          | 15:0      | _     | —     | _     | —     | —     | _     | —    | _     | _    | _    | —    | —    | —     | _    | _    | SWRST | 0000                |

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

**Note 1:** The Reset value is dependent on the DEVCFGx Configuration bits and the type of reset.

| ess                         |                                 |               |                   |       |       |       |        |       |      | Bi          | 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 |
| 3060                        | DCH0CON                         | 31:16<br>15:0 | —<br>CHBUSY       | _     |       |       | -      | -     |      | —<br>CHCHNS | —<br>CHEN | —<br>CHAED | —<br>CHCHN | —<br>CHAEN |         | —<br>CHEDET |        | —<br>I<1:0> | 00         |
|                             |                                 | 31:16         |                   |       |       |       |        |       |      |             |           | 00         |            |            |         |             |        |             |            |
| 3070                        | DCH0ECON                        | 15:0          |                   |       |       | CHSIR | Q<7:0> |       |      |             | CFORCE    | CABORT     | PATEN      | SIRQEN     |         |             | _      |             | FF         |
|                             |                                 | 31:16         | _                 | _     | —     | _     | _      | _     |      | _           | CHSDIE    | CHSHIE     | CHDDIE     | CHDHIE     | CHBCIE  | CHCCIE      | CHTAIE | CHERIE      | 00         |
| 3080                        | DCH0INT                         | 15:0          | _                 | _     | _     | _     | _      | _     |      |             | CHSDIF    | CHSHIF     | CHDDIF     | CHDHIF     | CHBCIF  | CHCCIF      | CHTAIF | CHERIF      | 00         |
| 3090                        | DCH0SSA                         | 31:16<br>15:0 |                   |       |       |       |        |       |      | CHSSA       | <31:0>    |            |            |            | •       |             |        |             | 00         |
| 30A0                        | DCH0DSA                         | 31:16<br>15:0 |                   |       |       |       |        |       |      | CHDSA       | <31:0>    |            |            |            |         |             |        |             | 00         |
|                             | D.0110.0017                     | 31:16         | _                 | _     | _     | _     | _      | _     | _    | _           | _         | _          | _          | _          | _       | _           | _      | _           | 00         |
| 30B0                        | DCH0SSIZ                        | 15:0          | 15:0 CHSSIZ<15:0> |       |       |       |        |       |      |             | 0.0       |            |            |            |         |             |        |             |            |
| 2000                        | DCH0DSIZ                        | 31:16         | _                 | _     | _     | —     | _      | _     |      | _           | _         | _          | _          | _          | _       | _           | —      | _           | 00         |
| 5000                        | DCHUD3IZ                        | 15:0          | 0 CHDSIZ<15:0> 0  |       |       |       |        |       |      |             |           | 00         |            |            |         |             |        |             |            |
| 3000                        | DCH0SPTR                        | 31:16         | —                 | _     | —     | —     | _      | _     | —    | -           | _         | —          |            |            | _       | —           | _      |             | 00         |
| 0000                        | Donioor III                     | 15:0          |                   |       |       |       |        |       |      | CHSPTI      | R<15:0>   |            |            |            |         |             |        |             | 00         |
| 30E0                        | DCH0DPTR                        | 31:16         | —                 | _     | —     | —     | —      | —     | —    |             | _         | —          |            | —          | —       | —           | _      | _           | 00         |
|                             |                                 | 15:0          |                   |       |       |       |        |       |      | CHDPTI      | R<15:0>   |            |            |            |         |             |        |             | 00         |
| 30F0                        | DCH0CSIZ                        | 31:16         | —                 |       | —     | —     | —      | —     |      |             | -         |            | —          | —          |         | —           | —      | _           | 00         |
|                             |                                 | 15:0          |                   |       |       |       | _      |       |      | CHCSIZ      | 2<15:0>   | _          |            | _          |         |             |        |             | 00         |
| 3100                        | DCH0CPTR                        | 31:16<br>15:0 | —                 |       |       |       | _      |       |      | CHCPTI      |           |            |            |            | _       | —           | _      |             | 00         |
|                             |                                 | 31:16         |                   | _     | _     | _     | _      | _     | _    |             |           | _          | _          |            |         | _           | _      | _           | 00         |
| 3110                        | DCH0DAT                         | 15:0          | _                 | _     | _     | _     | _      | _     | _    | _           |           |            |            |            | AT<7:0> |             |        |             | 00         |
|                             |                                 | 31:16         | _                 | _     | _     |       | _      | _     |      | _           | _         | —          | —          | _          | _       | _           | _      | _           | 00         |
| 3120                        | DCH1CON                         | 15:0          | CHBUSY            | _     | _     | _     | _      | _     | _    | CHCHNS      | CHEN      | CHAED      | CHCHN      | CHAEN      | _       | CHEDET      | CHPR   | <1:0>       | 00         |
| 0400                        | DOLUEDON                        | 31:16         | _                 | _     | _     | _     | _      | _     | _    | -           |           |            |            | CHAIR      | Q<7:0>  |             |        |             | 00         |
| 3130                        | DCH1ECON                        | 15:0          |                   |       |       | CHSIR | Q<7:0> |       |      |             | CFORCE    | CABORT     | PATEN      | SIRQEN     | AIRQEN  | _           | —      | —           | FF         |
| 3140                        | DCH1INT                         | 31:16         |                   | _     |       | _     | _      |       |      | _           | CHSDIE    | CHSHIE     | CHDDIE     | CHDHIE     | CHBCIE  | CHCCIE      | CHTAIE | CHERIE      | 00         |
| 5140                        | DCHIINI                         | 15:0          | —                 |       | —     | _     | _      | _     | —    | —           | CHSDIF    | CHSHIF     | CHDDIF     | CHDHIF     | CHBCIF  | CHCCIF      | CHTAIF | CHERIF      | 00         |
| 3150                        | DCH1SSA                         | 31:16<br>15:0 | CHSSA<31:0>       |       |       |       |        |       |      |             | 00        |            |            |            |         |             |        |             |            |
| 3160                        | DCH1DSA                         | 31:16<br>15:0 |                   |       |       |       |        |       |      | CHDSA       | <31:0>    |            |            |            |         |             |        |             | 00         |

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. Note 1:

# PIC32MX1XX/2XX/5XX 64/100-PIN FAMILY

# PIC32MX1XX/2XX/5XX 64/100-PIN FAMILY

| ILCIOID L    | SISTER 9-10. DETRESIZ: DWA CHANNEL & CELE-SIZE 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              |  |  |
|              |                                                         | —                 | _                 | _                 | —                 | —                 | -                | —                |  |  |
| 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                                                   | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |
| 15:8         | CHCSIZ<15:8>                                            |                   |                   |                   |                   |                   |                  |                  |  |  |
| 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          |                                                         |                   |                   | CHCSIZ            | <7:0>             |                   |                  |                  |  |  |

### REGISTER 9-16: DCHxCSIZ: DMA CHANNEL 'x' CELL-SIZE REGISTER

# Legend: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-16 Unimplemented: Read as '0'

### bit 15-0 CHCSIZ<15:0>: Channel Cell-Size bits

1111111111111111 = 65,535 bytes transferred on an event

### **REGISTER 9-17: DCHxCPTR: DMA CHANNEL 'x' CELL POINTER 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 |  |  |
|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|
| 21.24             | 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-0               | R-0               | R-0               | R-0               | R-0               | R-0               | R-0              | R-0              |  |  |
| 15:8 CHCPTR<15:8> |                   |                   |                   |                   |                   |                   |                  |                  |  |  |
| 7:0               | R-0               | R-0               | R-0               | R-0               | R-0               | R-0               | R-0              | R-0              |  |  |
| 7.0               |                   |                   |                   | CHCPTF            | R<7:0>            |                   |                  |                  |  |  |

| Legend:           |                  |                          |                    |
|-------------------|------------------|--------------------------|--------------------|
| 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-16 Unimplemented: Read as '0'

### Note: When in Pattern Detect mode, this register is reset on a pattern detect.

| 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               | 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        |                   | —                 | —                 | —                 | —                 |                   | _                | —                |
| 15:8         | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 10.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          | DPPULUP           | DMPULUP           | DPPULDWN          | DMPULDWN          | VBUSON            | OTGEN             | VBUSCHG          | VBUSDIS          |

### REGISTER 10-4: U1OTGCON: USB OTG CONTROL REGISTER

### Legend:

bit

| Logona                            |                  |                                    |                    |  |  |  |
|-----------------------------------|------------------|------------------------------------|--------------------|--|--|--|
| 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'

| 7 | DPI | PUL | UP: | D+ I | Pull-Up | Enable | e bit |  |
|---|-----|-----|-----|------|---------|--------|-------|--|
|   |     | -   |     |      |         |        |       |  |

1 = D+ data line pull-up resistor is enabled
 0 = D+ data line pull-up resistor is disabled

### bit 6 **DMPULUP:** D- Pull-Up Enable bit

- to **DMPOLOP:** D- Pull-Op Enable bit
  - 1 = D- data line pull-up resistor is enabled
     0 = D- data line pull-up resistor is disabled

### bit 5 **DPPULDWN:** D+ Pull-Down Enable bit

1 = D+ data line pull-down resistor is enabled
 0 = D+ data line pull-down resistor is disabled

### bit 4 **DMPULDWN:** D- Pull-Down Enable bit

- 1 = D- data line pull-down resistor is enabled
- 0 = D- data line pull-down resistor is disabled
- bit 3 **VBUSON:** VBUS Power-on bit
  - 1 = VBUS line is powered
  - 0 = VBUS line is not powered
- bit 2 **OTGEN:** OTG Functionality Enable bit
  - 1 = DPPULUP, DMPULUP, DPPULDWN and DMPULDWN bits are under software control
  - 0 = DPPULUP, DMPULUP, DPPULDWN and DMPULDWN bits are under USB hardware control

### bit 1 VBUSCHG: VBUS Charge Enable bit

- 1 = VBUS line is charged through a pull-up resistor
- 0 = VBUS line is not charged through a resistor
- bit 0 VBUSDIS: VBUS Discharge Enable bit
  - 1 = VBUS line is discharged through a pull-down resistor
  - 0 = VBUS line is not discharged through a resistor

|              |                   | • • • • • • • • • •     |                         |                   |                      |                   |                       |                         |  |
|--------------|-------------------|-------------------------|-------------------------|-------------------|----------------------|-------------------|-----------------------|-------------------------|--|
| 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                     |  |
|              | —                 | —                       | _                       |                   | —                    | _                 | _                     | —                       |  |
| 15:8         | U-0               | U-0                     | U-0                     | U-0               | U-0                  | U-0               | U-0                   | U-0                     |  |
| 15.6         | —                 | —                       | _                       |                   | —                    | —                 | —                     | —                       |  |
|              | R/WC-0, HS        | R/WC-0, HS              | R/WC-0, HS              | R/WC-0, HS        | R/WC-0, HS           | R/WC-0, HS        | R-0                   | R/WC-0, HS              |  |
| 7:0          | STALLIF           | ATTACHIF <sup>(1)</sup> | RESUMEIF <sup>(2)</sup> | IDLEIF            | TRNIF <sup>(3)</sup> | SOFIF             | UERRIF <sup>(4)</sup> | URSTIF <sup>(5)</sup>   |  |
|              | UIALLII           |                         |                         | IULLII            |                      | 00111             |                       | DETACHIF <sup>(6)</sup> |  |
|              | •                 | •                       |                         |                   |                      |                   |                       |                         |  |

### REGISTER 10-6: U1IR: USB INTERRUPT REGISTER

| Legend:           | WC = Write '1' to clear | WC = Write '1' to clear HS = Hardware Settable b |                    |  |  |  |  |
|-------------------|-------------------------|--------------------------------------------------|--------------------|--|--|--|--|
| R = Readable bit  | W = Writable bit        | U = Unimplemented b                              | vit, 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 |    | STALLIF: STALL Handshake Interrupt bit                                                                                                                                                 |
|-------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |    | 1 = In Host mode, a STALL handshake was received during the handshake phase of the transaction                                                                                         |
|       |    | In Device mode, a STALL handshake was transmitted during the handshake phase of the transaction                                                                                        |
|       |    | 0 = STALL handshake has not been sent                                                                                                                                                  |
| bit 6 |    | ATTACHIF: Peripheral Attach Interrupt bit <sup>(1)</sup>                                                                                                                               |
|       |    | 1 = Peripheral attachment was detected by the USB module                                                                                                                               |
|       |    | 0 = Peripheral attachment was not detected                                                                                                                                             |
| bit 5 |    | RESUMEIF: Resume Interrupt bit <sup>(2)</sup>                                                                                                                                          |
|       |    | 1 = K-State is observed on the D+ or D- pin for 2.5 $\mu$ s                                                                                                                            |
|       |    | 0 = K-State is not observed                                                                                                                                                            |
| bit 4 |    | IDLEIF: Idle Detect Interrupt bit                                                                                                                                                      |
|       |    | 1 = Idle condition detected (constant Idle state of 3 ms or more)                                                                                                                      |
|       |    | 0 = No Idle condition detected                                                                                                                                                         |
| bit 3 |    | <b>TRNIF:</b> Token Processing Complete Interrupt bit <sup>(3)</sup>                                                                                                                   |
|       |    | <ul> <li>1 = Processing of current token is complete; a read of the U1STAT register will provide endpoint information</li> <li>0 = Processing of current token not complete</li> </ul> |
| h:+ 0 |    |                                                                                                                                                                                        |
| bit 2 |    | <b>SOFIF:</b> SOF Token Interrupt bit<br>1 = SOF token received by the peripheral or the SOF threshold reached by the host                                                             |
|       |    | 0 = SOF token was not received nor threshold reached                                                                                                                                   |
| bit 1 |    | <b>UERRIF:</b> USB Error Condition Interrupt bit <sup>(4)</sup>                                                                                                                        |
| DICT  |    | 1 = Unmasked error condition has occurred                                                                                                                                              |
|       |    | 0 = Unmasked error condition has not occurred                                                                                                                                          |
| bit 0 |    | URSTIF: USB Reset Interrupt bit (Device mode) <sup>(5)</sup>                                                                                                                           |
| 2.00  |    | 1 = Valid USB Reset has occurred                                                                                                                                                       |
|       |    | 0 = No USB Reset has occurred                                                                                                                                                          |
| bit 0 |    | DETACHIF: USB Detach Interrupt bit (Host mode) <sup>(6)</sup>                                                                                                                          |
|       |    | 1 = Peripheral detachment was detected by the USB module                                                                                                                               |
|       |    | 0 = Peripheral detachment was not detected                                                                                                                                             |
| Note  | 1. | This bit is valid only if the HOSTEN bit is set (see Register 10-11), there is no activity on the USB for                                                                              |
| noto  | •• | $2.5 \mu$ s, and the current bus state is not SE0.                                                                                                                                     |
|       | 2: | When not in Suspend mode, this interrupt should be disabled.                                                                                                                           |
|       | 3: | Clearing this bit will cause the STAT FIFO to advance.                                                                                                                                 |
|       | 4: | Only error conditions enabled through the U1EIE register will set this bit.                                                                                                            |
|       | 5: | Device mode.                                                                                                                                                                           |
|       | 6: | Host mode.                                                                                                                                                                             |

# PIC32MX1XX/2XX/5XX 64/100-PIN FAMILY

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

| Bit<br>Range | Bit Bit<br>31/23/15/7 30/22/14/6 |      | Bit Bit<br>29/21/13/5 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  | 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              |
| 10.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, 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 **ENDPT<3:0>:** Encoded Number of Last Endpoint Activity bits (Represents the number of the BDT, updated by the last USB transfer.)
  - 1111 = Endpoint 15 1110 = Endpoint 14 . . 0001 = Endpoint 1 0000 = Endpoint 0
- bit 3 **DIR:** Last BD Direction Indicator bit
  - 1 = Last transaction was a transmit transfer (TX)
  - 0 = Last transaction was a receive transfer (RX)
- bit 2 PPBI: Ping-Pong BD Pointer Indicator bit
  - 1 = The last transaction was to the ODD BD bank
  - 0 = The last transaction was to the EVEN BD 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 bit (U1IR<3>) is active. Clearing the TRNIF bit advances the FIFO. Data in register is invalid when the TRNIF bit = 0.

### REGISTER 10-11: U1CON: USB CONTROL REGISTER (CONTINUED)

### bit 1 **PPBRST:** Ping-Pong Buffers Reset bit

- 1 = Reset all Even/Odd buffer pointers to the EVEN BD banks
- 0 = Even/Odd buffer pointers not being Reset
- bit 0 USBEN: USB Module Enable bit<sup>(4)</sup>
  - 1 = USB module and supporting circuitry enabled
  - 0 = USB module and supporting circuitry disabled

SOFEN: SOF Enable bit(5)

- 1 = SOF token sent every 1 ms
- 0 = SOF token disabled
- **Note 1:** Software is required to check this bit before issuing another token command to the U1TOK register (see Register 10-15).
  - 2: All host control logic is reset any time that the value of this bit is toggled.
  - 3: Software must set the RESUME bit for 10 ms if the part is a function, or for 25 ms if the part is a host, and then clear it to enable remote wake-up. In Host mode, the USB module will append a low-speed EOP to the RESUME signaling when this bit is cleared.
  - 4: Device mode.
  - 5: Host mode.

### **REGISTER 15-1:** ICXCON: INPUT CAPTURE 'x' CONTROL REGISTER ('x' = 1 THROUGH 5)

| Bit 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     | —                 | —                 | _                 | _                 | _                 | _                 | _                                                                     | _                |
| 45.0      | R/W-0             | U-0               | R/W-0             | U-0               | U-0               | U-0               | R/W-0                                                                 | R/W-0            |
| 15:8      | 0N <sup>(1)</sup> | —                 | SIDL              | _                 | _                 | _                 | —         —           R/W-0         R/W-0           FEDGE         C32 |                  |
| 7.0       | R/W-0             | R/W-0             | R/W-0             | R-0               | R-0               | R/W-0             | R/W-0                                                                 | R/W-0            |
| 7:0       | ICTMR             | ICI<              | 1:0>              | ICOV              | ICBNE             | ICM<2:0>          |                                                                       |                  |

### Legend:

| R = Readable bit                          | W = Writable bit | U = Unimplemented bit |                  |
|-------------------------------------------|------------------|-----------------------|------------------|
| -n = Bit Value at POR: ('0', '1', x = unk | nown)            | P = Programmable bit  | r = Reserved bit |

| bit 31-16 | Unimplemented: Read as '0'                                                                                                                             |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 15    | ON: Input Capture Module Enable bit <sup>(1)</sup>                                                                                                     |
|           | <ul> <li>1 = Module enabled</li> <li>0 = Disable and reset module, disable clocks, disable interrupt generation and allow SFR modifications</li> </ul> |
| bit 14    | Unimplemented: Read as '0'                                                                                                                             |
| bit 13    | SIDL: Stop in Idle Control bit                                                                                                                         |
|           | <ul> <li>1 = Halt in CPU Idle mode</li> <li>0 = Continue to operate in CPU Idle mode</li> </ul>                                                        |
| bit 12-10 | Unimplemented: Read as '0'                                                                                                                             |
| bit 9     | FEDGE: First Capture Edge Select bit (only used in mode 6, ICM<2:0> = 110)                                                                             |
|           | <ul><li>1 = Capture rising edge first</li><li>0 = Capture falling edge first</li></ul>                                                                 |
| bit 8     | C32: 32-bit Capture Select bit                                                                                                                         |
|           | <ul> <li>1 = 32-bit timer resource capture</li> <li>0 = 16-bit timer resource capture</li> </ul>                                                       |
| bit 7     | ICTMR: Timer Select bit (Does not affect timer selection when C32 (ICxCON<8>) is '1')                                                                  |
|           | <ul><li>0 = Timer3 is the counter source for capture</li><li>1 = Timer2 is the counter source for capture</li></ul>                                    |
| bit 6-5   | ICI<1:0>: Interrupt Control bits                                                                                                                       |
|           | 11 = Interrupt on every fourth capture event                                                                                                           |
|           | <ul> <li>10 = Interrupt on every third capture event</li> <li>01 = Interrupt on every second capture event</li> </ul>                                  |
|           | 00 = Interrupt on every second capture event                                                                                                           |
| bit 4     | ICOV: Input Capture Overflow Status Flag bit (read-only)                                                                                               |
|           | 1 = Input capture overflow occurred                                                                                                                    |
|           | 0 = No input capture overflow occurred                                                                                                                 |
| bit 3     | ICBNE: Input Capture Buffer Not Empty Status bit (read-only)                                                                                           |
|           | <ul> <li>1 = Input capture buffer is not empty; at least one more capture value can be read</li> <li>0 = Input capture buffer is empty</li> </ul>      |
|           |                                                                                                                                                        |

**Note 1:** When using 1:1 PBCLK divisor, the user software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit.

© 2014-2016 Microchip Technology Inc.

### REGISTER 17-3: SPIxSTAT: SPI STATUS REGISTER (CONTINUED)

bit 3 SPITBE: SPI Transmit Buffer Empty Status bit 1 = Transmit buffer, SPIxTXB is empty 0 = Transmit buffer, SPIxTXB is not empty Automatically set in hardware when SPI transfers data from SPIxTXB to SPIxSR. Automatically cleared in hardware when SPIxBUF is written to, loading SPIxTXB. bit 2 Unimplemented: Read as '0' bit 1 SPITBF: SPI Transmit Buffer Full Status bit 1 = Transmit not yet started, SPITXB is full 0 = Transmit buffer is not full Standard Buffer Mode: Automatically set in hardware when the core writes to the SPIBUF location, loading SPITXB. Automatically cleared in hardware when the SPI module transfers data from SPITXB to SPISR. Enhanced Buffer Mode: Set when CWPTR + 1 = SRPTR; cleared otherwise bit 0 SPIRBF: SPI Receive Buffer Full Status bit 1 = Receive buffer, SPIxRXB is full

0 = Receive buffer, SPIxRXB is not full

Standard Buffer Mode:

Automatically set in hardware when the SPI module transfers data from SPIxSR to SPIxRXB. Automatically cleared in hardware when SPIxBUF is read from, reading SPIxRXB.

Enhanced Buffer Mode:

Set when SWPTR + 1 = CRPTR; cleared otherwise

### 18.0 INTER-INTEGRATED CIRCUIT (I<sup>2</sup>C)

Note: This data sheet summarizes the features of the PIC32MX1XX/2XX/5XX 64/100-pin family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 24. "Inter-Integrated Circuit (I<sup>2</sup>C)" (DS60001116) in the "PIC32 Family Reference Manual", which is available from the Microchip web site (www.microchip.com/PIC32). The  $l^2C$  module provides complete hardware support for both Slave and Multi-Master modes of the  $l^2C$  serial communication standard. Figure 18-1 illustrates the  $l^2C$  module block diagram.

Each  $I^2C$  module has a 2-pin interface: the SCLx pin is clock and the SDAx pin is data.

Each I<sup>2</sup>C module offers the following key features:

- I<sup>2</sup>C interface supporting both master and slave operation
- I<sup>2</sup>C Slave mode supports 7-bit and 10-bit addressing
- I<sup>2</sup>C Master mode supports 7-bit and 10-bit addressing
- I<sup>2</sup>C port allows bidirectional transfers between master and slaves
- Serial clock synchronization for the I<sup>2</sup>C port can be used as a handshake mechanism to suspend and resume serial transfer (SCLREL control)
- I<sup>2</sup>C supports multi-master operation; detects bus collision and arbitrates accordingly
- · Provides support for address bit masking

# PIC32MX1XX/2XX/5XX 64/100-PIN FAMILY

| KE0131E      | CEGISTER 18-1. IZCACON. I C X CONTROL REGISTER (X = I AND Z) |       |                   |                   |                   |                   |                  |                  |  |  |  |  |  |  |
|--------------|--------------------------------------------------------------|-------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|--|--|
| Bit<br>Range | Bit Bit<br>31/23/15/7 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        | 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        | —                                                            | —     | —                 | _                 | —                 | _                 | —                | —                |  |  |  |  |  |  |
| 45.0         | R/W-0                                                        | U-0   | R/W-0             | R/W-1, HC         | R/W-0             | R/W-0             | R/W-0            | R/W-0            |  |  |  |  |  |  |
| 15:8         | 0N <sup>(1)</sup>                                            | _     | SIDL              | SCLREL            | STRICT            | A10M              | DISSLW           | SMEN             |  |  |  |  |  |  |
| 7.0          | R/W-0                                                        | R/W-0 | R/W-0             | R/W-0, HC         | R/W-0, HC         | R/W-0, HC         | R/W-0, HC        | R/W-0, HC        |  |  |  |  |  |  |
| 7:0          | GCEN                                                         | STREN | ACKDT             | ACKEN             | RCEN              | PEN               | RSEN             | SEN              |  |  |  |  |  |  |

### **REGISTER 18-1:** I2CxCON: $I^2C'x'$ CONTROL REGISTER ('x' = 1 AND 2)

| Legend:           | HC = Cleared in Hardwar | e                        |                    |
|-------------------|-------------------------|--------------------------|--------------------|
| 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-16 Unimplemented: Read as '0'

- bit 15 **ON:** I<sup>2</sup>C Enable bit<sup>(1)</sup>
  - 1 = Enables the  $I^2C$  module and configures the SDA and SCL pins as serial port pins
  - 0 = Disables the I<sup>2</sup>C module; all I<sup>2</sup>C pins are controlled by PORT functions
- bit 14 Unimplemented: Read as '0'
- bit 13 **SIDL:** Stop in Idle Mode bit
  - 1 = Discontinue module operation when device enters Idle mode
  - 0 = Continue module operation in Idle mode
  - SCLREL: SCLx Release Control bit (when operating as I<sup>2</sup>C slave)
  - 1 = Release SCLx clock

bit 12

0 = Hold SCLx clock low (clock stretch)

### If STREN = 1:

Bit is R/W (i.e., software can write '0' to initiate stretch and write '1' to release clock). Hardware clear at beginning of slave transmission. Hardware clear at end of slave reception.

### If STREN = 0:

Bit is R/S (i.e., software can only write '1' to release clock). Hardware clear at beginning of slave transmission.

- bit 11 STRICT: Strict I<sup>2</sup>C Reserved Address Rule Enable bit
  - 1 = Strict reserved addressing is enforced. Device does not respond to reserved address space or generate addresses in reserved address space.
  - 0 =Strict I<sup>2</sup>C Reserved Address Rule not enabled

### bit 10 A10M: 10-bit Slave Address bit

- 1 = I2CxADD is a 10-bit slave address
- 0 = I2CxADD is a 7-bit slave address
- bit 9 DISSLW: Disable Slew Rate Control bit
  - 1 = Slew rate control disabled
    - 0 = Slew rate control enabled
- bit 8 SMEN: SMBus Input Levels bit
  - 1 = Enable I/O pin thresholds compliant with SMBus specification
  - 0 = Disable SMBus input thresholds
- **Note 1:** When using 1:1 PBCLK divisor, the user software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit.

### **19.1 Control Registers**

### TABLE 19-1: UART1 THROUGH UART5 REGISTER MAP

| 'ess<br>)                   |                              | e             |                                    |        |        |       |        |       |       | Bi          | ts          |         |       |           |               |       |        |       | s          |
|-----------------------------|------------------------------|---------------|------------------------------------|--------|--------|-------|--------|-------|-------|-------------|-------------|---------|-------|-----------|---------------|-------|--------|-------|------------|
| Virtual Address<br>(BF80_#) | Register<br>Name             | 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                        | U1MODE <sup>(1)</sup>        | 31:16         | _                                  |        | _      | _     | —      |       |       | —           | _           | —       | _     | _         |               | —     |        | _     | 0000       |
| 0000                        | OTWODE                       | 15:0          | ON                                 | -      | SIDL   | IREN  | RTSMD  | _     | UEN   | <1:0>       | WAKE        | LPBACK  | ABAUD | RXINV     | BRGH          | PDSEI | _<1:0> | STSEL | 0000       |
| 6010                        | U1STA <sup>(1)</sup>         | 31:16         | —                                  | —      | —      | —     | —      | —     | —     | ADM_EN      |             |         |       | ADDR      | -             |       |        |       | 0000       |
| 0010                        | 0101/1                       | 15:0          | UTXISE                             | L<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT        | URXISE      | EL<1:0> | ADDEN | RIDLE     | PERR          | FERR  | OERR   | URXDA | FFFF       |
| 6020                        | U1TXREG                      | 31:16         | —                                  | —      | —      | —     | —      | —     | —     | —           | —           | —       | —     | —         | —             | —     | —      | —     | 0000       |
| 0020                        | 011XIII20                    | 15:0          | —                                  | —      | —      | —     | —      | —     | —     | TX8         |             |         |       | Transmit  | Register      |       |        |       | 0000       |
| 6030                        | U1RXREG                      | 31:16         | —                                  | _      | —      | _     | —      | _     | _     | —           | _           | —       | —     | —         | —             | —     | —      | —     | 0000       |
|                             | 01101120                     | 15:0          | —                                  | —      | —      | _     | —      | —     | —     | RX8         |             |         |       | Receive   | Register      |       |        |       | 0000       |
| 6040                        | 040 U1BRG <sup>(1)</sup>     | 31:16         | —                                  | —      | —      | _     |        | —     | —     |             | _           |         | —     | —         |               |       | —      | —     | 0000       |
|                             |                              | 15:0          | Baud Rate Generator Prescaler 0000 |        |        |       |        |       |       |             |             | 0000    |       |           |               |       |        |       |            |
| 6200                        | U2MODE <sup>(1)</sup>        | 31:16         | _                                  |        |        |       |        | _     | _     | —           | _           |         | _     |           | _             |       | —      |       | 0000       |
|                             |                              | 15:0          | ON                                 | —      | SIDL   | IREN  | RTSMD  | —     | UEN   | -           | WAKE        | LPBACK  | ABAUD | RXINV     | BRGH          | PDSEI | _<1:0> | STSEL | 0000       |
| 6210                        | 5210 U2STA <sup>(1)</sup> 31 |               | —                                  | —      | —      | —     | —      | —     | —     | ADM_EN      |             |         |       | ADDR      | -             |       |        | -     | 0000       |
|                             |                              | 15:0          | UTXISE                             | L<1:0> | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT        | URXISE      | EL<1:0> | ADDEN | RIDLE     | PERR          | FERR  | OERR   | URXDA | FFFF       |
| 6220                        | U2TXREG                      | 31:16         | _                                  | _      |        | _     | —      | _     | —     | —           | _           | _       | _     |           |               |       | _      | —     | 0000       |
|                             |                              | 15:0          | _                                  | _      |        |       | —      | _     | _     | TX8         |             |         |       | Transmit  | Register      |       |        |       | 0000       |
| 6230                        | U2RXREG                      | 31:16         | _                                  | _      | —      | _     | —      | _     | _     | _           | _           | _       | _     |           | _             | —     | —      | —     | 0000       |
|                             |                              | 15:0          | _                                  | _      | —      |       | —      | —     |       | RX8         |             |         |       | Receive   | Register      |       |        |       | 0000       |
| 6240                        | U2BRG <sup>(1)</sup>         | 31:16         | _                                  | _      |        |       | —      |       |       |             |             |         | _     |           | _             | —     | _      | —     | 0000       |
|                             |                              | 15:0          |                                    |        |        |       |        |       | Bau   | d Rate Gene | erator Pres | caler   |       |           |               |       |        |       | 0000       |
| 6400                        | U3MODE <sup>(1)</sup>        | 31:16<br>15:0 | -                                  | _      | -      | -     | -      | —     | —     | —           |             | —       |       | —         | —             |       | _      | -     | 0000       |
| -                           |                              |               | ON                                 | _      | SIDL   | IREN  | RTSMD  |       | UEN   | -           | WAKE        | LPBACK  | ABAUD | RXINV     | BRGH          | PDSEI | _<1:0> | STSEL | 0000       |
| 6410                        | U3STA <sup>(1)</sup>         | 31:16         | —                                  | —      | -      | -     | -      | -     | —     | ADM_EN      |             | -1 -1 0 |       | ADDR      | -             | 5500  | 0500   |       | 0000       |
|                             |                              | 15:0          | UTXISE                             | -      | UTXINV | URXEN | UTXBRK | UTXEN | UTXBF | TRMT        | URXISE      | =L<1:0> | ADDEN | RIDLE     | PERR          | FERR  | OERR   | URXDA | FFFF       |
| 6420                        | <b>U3TXREG</b>               | 31:16         | _                                  |        |        |       |        | _     | _     | —<br>       | _           | —       | _     |           | —             | _     | _      | —     | 0000       |
|                             |                              | 15:0          |                                    |        |        |       |        | _     |       | TX8         |             |         |       | Transmit  | Register      |       |        |       | 0000       |
| 6430                        | U3RXREG                      | 31:16         | _                                  |        |        |       | _      | _     |       |             | _           | _       |       | - Boogive | —<br>Bogistor | _     | _      | —     | 0000       |
|                             |                              | 15:0          | —                                  | —      | —      |       |        | —     | —     | RX8         |             |         |       | Receive   | Register      |       |        |       | 0000       |

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

Note 1: This register has 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.

2: This register is only available on 100-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 |
|--------------|--------------------------|----------------------|--------------------|-------------------------|-----------------------------|-------------------|------------------|------------------|
| 21.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        | —                        | —                    | —                  | —                       | _                           | —                 | _                | —                |
| 45.0         | R/W-0                    | R/W-0                | R/W-0              | R-0                     | R/W-0                       | R/W-0             | R/W-0            | R/W-0            |
| 15:8         | ALRMEN <sup>(1,2)</sup>  | CHIME <sup>(2)</sup> | PIV <sup>(2)</sup> | ALRMSYNC <sup>(3)</sup> | ) AMASK<3:0> <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            |
|              | ARPT<7:0> <sup>(3)</sup> |                      |                    |                         |                             |                   |                  |                  |

### REGISTER 21-2: RTCALRM: RTC ALARM 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-16 Unimplemented: Read as '0'

- bit 15 ALRMEN: Alarm Enable bit<sup>(1,2)</sup>
  - 1 = Alarm is enabled
  - 0 = Alarm is disabled

### bit 14 CHIME: Chime Enable bit<sup>(2)</sup>

- 1 = Chime is enabled ARPT<7:0> is allowed to rollover from 0x00 to 0xFF
- 0 = Chime is disabled ARPT<7:0> stops once it reaches 0x00

### bit 13 **PIV:** Alarm Pulse Initial Value bit<sup>(2)</sup>

When ALRMEN = 0, PIV is writable and determines the initial value of the Alarm Pulse. When ALRMEN = 1, PIV is read-only and returns the state of the Alarm Pulse.

### bit 12 ALRMSYNC: Alarm Sync bit<sup>(3)</sup>

- 1 = ARPT<7:0> and ALRMEN may change as a result of a half second rollover during a read. The ARPT must be read repeatedly until the same value is read twice. This must be done since multiple bits may be changing, which are then synchronized to the PB clock domain
- 0 = ARPT<7:0> and ALRMEN can be read without concerns of rollover because the prescaler is > 32 RTC clocks away from a half-second rollover

### bit 11-8 AMASK<3:0>: Alarm Mask Configuration bits<sup>(3)</sup>

- 0000 = Every half-second
- 0001 = Every second
- 0010 = Every 10 seconds
- 0011 = Every minute
- 0100 = Every 10 minutes
- 0101 = Every hour
- 0110 = Once a day
- 0111 = Once a week
- 1000 = Once a month
- 1001 = Once a year (except when configured for February 29, once every four years)
- 1010 = Reserved; do not use
- 1011 = Reserved; do not use
- 11xx = Reserved; do not use
- **Note 1:** Hardware clears the ALRMEN bit anytime the alarm event occurs, when ARPT<7:0> = 00 and CHIME = 0.
  - 2: This field should not be written when the RTCC ON bit = '1' (RTCCON<15>) and ALRMSYNC = 1.
  - 3: This assumes a CPU read will execute in less than 32 PBCLKs.

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

'0' = Bit is cleared

x = Bit is unknown

| 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 |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
|              | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x            | R/W-x            |
| 31:24        |                   | HR10              | <3:0>             |                   |                   | HR01              | <3:0>            |                  |
| 00.40        | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x            | R/W-x            |
| 23:16        |                   | MIN10             | <3:0>             | MIN01<3:0>        |                   |                   |                  |                  |
|              | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x             | R/W-x            | R/W-x            |
| 15:8         |                   | SEC10             | <3:0>             | SEC01<3:0>        |                   |                   |                  |                  |
| 7.0          | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 7:0          | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|              |                   |                   |                   |                   |                   |                   |                  |                  |
| Legend:      |                   |                   |                   |                   |                   |                   |                  |                  |
| R = Read     | able bit          |                   | W = Writable      | e bit             | U = Unimple       | emented bit, re   | ead as '0'       |                  |

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

bit 31-28 HR10<3:0>: Binary Coded Decimal value of hours bits, 10s place digits; 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-20 MIN10<3:0>: Binary Coded Decimal value of minutes bits, 10s place digits; 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-12 SEC10<3:0>: Binary Coded Decimal value of seconds bits, 10s place digits; 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'

'1' = Bit is set

-n = Value at POR

| 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              |  |  |
| 51.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               | R-0                       | R-0               | R-0               | R-0              | R-0              |  |  |
| 15.0         | —                 | —                 | —                 |                           |                   | FILHIT<4:0>       |                  |                  |  |  |
| 7:0          | U-0               | R-1               | R-0               | R-0                       | R-0               | R-0               | R-0              | R-0              |  |  |
| 7.0          | _                 |                   |                   | ICODE<6:0> <sup>(1)</sup> |                   |                   |                  |                  |  |  |

### REGISTER 23-4: C1VEC: CAN INTERRUPT CODE REGISTER

### Legend:

| 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-13 Unimplemented: Read as '0'

```
bit 12-8 FILHIT<4:0>: Filter Hit Number bit
         11111 = Reserved
         10000 = Reserved
         01111 = Filter 15
         00000 = Filter 0
bit 7
         Unimplemented: Read as '0'
         ICODE<6:0>: Interrupt Flag Code bits<sup>(1)</sup>
bit 6-0
         1111111 = Reserved
         1001001 = Reserved
         1001000 = Invalid message received (IVRIF)
         1000111 = CAN module mode change (MODIF)
         1000110 = CAN timestamp timer (CTMRIF)
         1000101 = Bus bandwidth error (SERRIF)
         1000100 = Address error interrupt (SERRIF)
         1000011 = Receive FIFO overflow interrupt (RBOVIF)
         1000010 = Wake-up interrupt (WAKIF)
         1000001 = Error Interrupt (CERRIF)
         1000000 = No interrupt
         0111111 = Reserved
         0010000 = Reserved
         0001111 = FIFO15 Interrupt (C1FSTAT<15> set)
         0000000 = FIFO0 Interrupt (C1FSTAT<0> set)
```



### 28.0 SPECIAL FEATURES

Note: This data sheet summarizes the features of the PIC32MX1XX/2XX/5XX 64/100-pin family of devices. However, it is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 9. "Watchdog Timer and Power-up Timer" (DS60001114), Section 32. "Configuration" (DS60001124) and Section 33. "Programming and Diagnostics" (DS60001129) in the "PIC32 Family Reference Manual", which are available from the Microchip web site (www.microchip.com/PIC32).

PIC32MX1XX/2XX/5XX 64/100-pin devices include several features intended to maximize application flexibility and reliability and minimize cost through elimination of external components. These are:

- Flexible device configuration
- Watchdog Timer (WDT)
- Joint Test Action Group (JTAG) interface
- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>)

### 28.1 Configuration Bits

The Configuration bits can be programmed using the following registers to select various device configurations.

- DEVCFG0: Device Configuration Word 0
- DEVCFG1: Device Configuration Word 1
- DEVCFG2: Device Configuration Word 2
- DEVCFG3: Device Configuration Word 3
- CFGCON: Configuration Control Register

In addition, the DEVID register (Register 28-6) provides device and revision information.

| AC CHA        | RACTERI       | ISTICS                                                                                                           | $\begin{tabular}{lllllllllllllllllllllllllllllllllll$ |                        |             |            |                                              |  |  |
|---------------|---------------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------|-------------|------------|----------------------------------------------|--|--|
| Param.<br>No. | Symbol        | Characteristics                                                                                                  | Min.                                                  | Typical <sup>(1)</sup> | Max.        | Units      | Conditions                                   |  |  |
| OS10          | Fosc          | External CLKI Frequency<br>(External clocks allowed only<br>in EC and ECPLL modes)                               | DC<br>4                                               |                        | 40<br>40    | MHz<br>MHz | EC (Note 4)<br>ECPLL (Note 3)                |  |  |
| OS11          |               | Oscillator Crystal Frequency                                                                                     | 3                                                     | —                      | 10          | MHz        | XT (Note 4)                                  |  |  |
| OS12          |               |                                                                                                                  | 4                                                     | —                      | 10          | MHz        | XTPLL<br>(Notes 3,4)                         |  |  |
| OS13          |               |                                                                                                                  | 10                                                    | —                      | 25          | MHz        | HS (Note 5)                                  |  |  |
| OS14          |               |                                                                                                                  | 10                                                    | —                      | 25          | MHz        | HSPLL<br>(Notes 3,4)                         |  |  |
| OS15          |               |                                                                                                                  | 32                                                    | 32.768                 | 100         | kHz        | Sosc (Note 4)                                |  |  |
| OS20          | Tosc          | Tosc = 1/Fosc = Tcy (Note 2)                                                                                     | _                                                     | _                      | _           | —          | See parameter<br>OS10 for Fosc<br>value      |  |  |
| OS30          | TosL,<br>TosH | External Clock In (OSC1)<br>High or Low Time                                                                     | 0.45 x Tosc                                           | —                      | —           | ns         | EC (Note 4)                                  |  |  |
| OS31          | TosR,<br>TosF | External Clock In (OSC1)<br>Rise or Fall Time                                                                    | —                                                     | —                      | 0.05 x Tosc | ns         | EC (Note 4)                                  |  |  |
| OS40          | Tost          | Oscillator Start-up Timer Period<br>(Only applies to HS, HSPLL,<br>XT, XTPLL and Sosc Clock<br>Oscillator modes) | _                                                     | 1024                   | _           | Tosc       | (Note 4)                                     |  |  |
| OS41          | TFSCM         | Primary Clock Fail Safe<br>Time-out Period                                                                       | —                                                     | 2                      | _           | ms         | (Note 4)                                     |  |  |
| OS42          | Gм            | External Oscillator<br>Transconductance (Primary<br>Oscillator only)                                             |                                                       | 12                     |             | mA/V       | VDD = 3.3V,<br>TA = +25°C<br><b>(Note 4)</b> |  |  |

### TABLE 31-17: EXTERNAL CLOCK TIMING REQUIREMENTS

Note 1: Data in "Typical" column is at 3.3V, 25°C unless otherwise stated. Parameters are characterized but are not tested.

2: Instruction cycle period (TcY) equals the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min." values with an external clock applied to the OSC1/CLKI pin.

**3:** PLL input requirements: 4 MHz  $\leq$  FPLLIN  $\leq$  5 MHz (use PLL prescaler to reduce Fosc). This parameter is characterized, but tested at 10 MHz only at manufacturing.

4: This parameter is characterized, but not tested in manufacturing.

| AC CHA        | ARACTER                | ISTICS                                                               | $\begin{array}{l} \mbox{Standard Operating Conditions (see Note 4): 2.5V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^\circ C \leq TA \leq +85^\circ C \mbox{ for Industrial} \\ -40^\circ C \leq TA \leq +105^\circ C \mbox{ for V-temp} \end{array}$ |                        |         |       |                                                           |  |
|---------------|------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------|-------|-----------------------------------------------------------|--|
| Param.<br>No. | Sympol Characteristics |                                                                      |                                                                                                                                                                                                                                                                                              | Typical <sup>(1)</sup> | Max.    | Units | Conditions                                                |  |
| Clock P       | arameter               | S                                                                    | •                                                                                                                                                                                                                                                                                            | •                      |         |       | ·                                                         |  |
| AD50          | Tad                    | ADC Clock Period <sup>(2)</sup>                                      | 65                                                                                                                                                                                                                                                                                           | —                      | —       | ns    | See Table 31-35                                           |  |
| Convers       | sion Rate              |                                                                      |                                                                                                                                                                                                                                                                                              |                        |         |       |                                                           |  |
| AD55          | TCONV                  | Conversion Time                                                      |                                                                                                                                                                                                                                                                                              | 12 Tad                 | _       |       | —                                                         |  |
| AD56          | FCNV                   | Throughput Rate                                                      | _                                                                                                                                                                                                                                                                                            | _                      | 1000    | ksps  | AVDD = 3.0V to 3.6V                                       |  |
|               |                        | (Sampling Speed)                                                     | _                                                                                                                                                                                                                                                                                            | —                      | 400     | ksps  | AVDD = 2.5V to 3.6V                                       |  |
| AD57          | TSAMP                  | Sample Time                                                          | 1 Tad                                                                                                                                                                                                                                                                                        | —                      | —       | _     | TSAMP must be $\geq$ 132 ns                               |  |
| Timing        | Paramete               | rs                                                                   |                                                                                                                                                                                                                                                                                              |                        |         |       |                                                           |  |
| AD60          | TPCS                   | Conversion Start from Sample<br>Trigger <sup>(3)</sup>               |                                                                                                                                                                                                                                                                                              | 1.0 Tad                | _       | —     | Auto-Convert Trigger<br>(SSRC<2:0> = 111)<br>not selected |  |
| AD61          | TPSS                   | Sample Start from Setting<br>Sample (SAMP) bit                       | 0.5 TAD                                                                                                                                                                                                                                                                                      | —                      | 1.5 Tad | _     | —                                                         |  |
| AD62          | TCSS                   | Conversion Completion to<br>Sample Start (ASAM = 1) <sup>(3)</sup>   | _                                                                                                                                                                                                                                                                                            | 0.5 Tad                | —       | _     | _                                                         |  |
| AD63          | TDPU                   | Time to Stabilize Analog Stage from ADC Off to ADC On <sup>(3)</sup> |                                                                                                                                                                                                                                                                                              |                        | 2       | μS    | _                                                         |  |

### TABLE 31-36: ANALOG-TO-DIGITAL CONVERSION TIMING REQUIREMENTS

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

2: Because the sample caps will eventually lose charge, clock rates below 10 kHz can affect linearity performance, especially at elevated temperatures.

**3:** Characterized by design but not tested.

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