



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Details                    |                                                                                   |
|----------------------------|-----------------------------------------------------------------------------------|
| Product Status             | Active                                                                            |
| Core Processor             | MIPS32® M4K™                                                                      |
| Core Size                  | 32-Bit Single-Core                                                                |
| Speed                      | 50MHz                                                                             |
| Connectivity               | 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        | 128KB (128K x 8)                                                                  |
| Program Memory Type        | FLASH                                                                             |
| EEPROM Size                | -                                                                                 |
| RAM Size                   | 16K 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-TQFP                                                                           |
| Supplier Device Package    | 64-TQFP (10x10)                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic32mx230f128ht-50i-pt |
|                            |                                                                                   |

Email: info@E-XFL.COM

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

#### TABLE 5: PIN NAMES FOR 100-PIN USB DEVICES

### **100-PIN TQFP (TOP VIEW)**

PIC32MX230F128L PIC32MX530F128L PIC32MX250F256L PIC32MX550F256L PIC32MX270F512L PIC32MX570F512L

100

| Pin # | Full Pin Name                         | Div | n #  | Full Pin Name                   |
|-------|---------------------------------------|-----|------|---------------------------------|
|       |                                       |     |      |                                 |
| 1     | AN28/RG15                             |     | -    | /ss                             |
| 2     | VDD                                   | -   |      |                                 |
| 3     | AN22/RPE5/PMD5/RE5                    | 3   | .0   | ICK/CTED2/RA1                   |
| 4     | AN23/PMD6/RE6                         | 3   | -    | AN34/RPF13/SCK3/RF13            |
| 5     | AN27/PMD7/RE7                         | 4   | .0 A | AN35/RPF12/RF12                 |
| 6     | AN29/RPC1/RC1                         | 4   | -1 A | AN12/PMA11/RB12                 |
| 7     | AN30/RPC2/RC2                         | 4   | -2 A | AN13/PMA10/RB13                 |
| 8     | AN31/RPC3/RC3                         | 4   | -3 A | AN14/RPB14/CTED5/PMA1/RB14      |
| 9     | RPC4/CTED7/RC4                        | 4   | 4 A  | AN15/RPB15/OCFB/CTED6/PMA0/RB15 |
| 10    | AN16/C1IND/RPG6/SCK2/PMA5/RG6         | 4   | ·5 \ | /ss                             |
| 11    | AN17/C1INC/RPG7/PMA4/RG7              | 4   | ·6 \ | /DD                             |
| 12    | AN18/C2IND/RPG8/PMA3/RG8              | 4   | ·7 A | AN36/RPD14/RD14                 |
| 13    | MCLR                                  | 4   | -8 A | AN37/RPD15/SCK4/RD15            |
| 14    | AN19/C2INC/RPG9/PMA2/RG9              | 4   | .9 F | RPF4/PMA9/RF4                   |
| 15    | Vss                                   | 5   | 60 F | RPF5/PMA8/RF5                   |
| 16    | Vdd                                   | 5   | i1 L | JSBID/RPF3/RF3                  |
| 17    | TMS/CTED1/RA0                         | 5   | 2 A  | AN38/RPF2/RF2                   |
| 18    | AN32/RPE8/RE8                         | 5   | 3 A  | AN39/RPF8/RF8                   |
| 19    | AN33/RPE9/RE9                         | 5   | i4 \ | /BUS                            |
| 20    | AN5/C1INA/RPB5/VBUSON/RB5             | 5   | 5 \  | /USB3V3                         |
| 21    | AN4/C1INB/RB4                         | 5   | 6 E  | )-                              |
| 22    | PGED3/AN3/C2INA/RPB3/RB3              | 5   | 7 E  | )+                              |
| 23    | PGEC3/AN2/CTCMP/C2INB/RPB2/CTED13/RB2 | 5   | 8 5  | SCL2/RA2                        |
| 24    | PGEC1/AN1/RPB1/CTED12/RB1             | 5   | 9 5  | SDA2/RA3                        |
| 25    | PGED1/AN0/RPB0/RB0                    | 6   | т 0  | IDI/CTED9/RA4                   |
| 26    | PGEC2/AN6/RPB6/RB6                    | 6   | i1 T | IDO/RA5                         |
| 27    | PGED2/AN7/RPB7/CTED3/RB7              | 6   | i2 \ | /DD                             |
| 28    | VREF-/PMA7/RA9                        | 6   | i3 ( | DSC1/CLKI/RC12                  |
| 29    | VREF+/PMA6/RA10                       | 6   | i4 ( | DSC2/CLKO/RC15                  |
| 30    | AVdd                                  | 6   | 5 \  | /ss                             |
| 31    | AVss                                  | 6   | 6 F  | RPA14/SCL1/RA14                 |
| 32    | AN8/RPB8/CTED10/RB8                   | 6   | 57 F | RPA15/SDA1/RA15                 |
| 33    | AN9/RPB9/CTED4/RB9                    | 6   | i8 F | RPD8/RTCC/RD8                   |
| 34    | CVREFOUT/AN10/RPB10/CTED11/PMA13/RB10 | 6   | ;9 F | RPD9/RD9                        |
| 35    | AN11/PMA12/RB11                       | 7   | '0 F | RPD10/SCK1/PMA15/RD10           |

Note 1: The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and Section 11.3 "Peripheral Pin Select" for restrictions.

2: Every I/O port pin (RAx-RGx) can be used as a change notification pin (CNAx-CNGx). See Section 11.0 "I/O Ports" for more information.

3: Shaded pins are 5V tolerant.

# 7.0 RESETS

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 7.** "**Resets**" (DS60001118) in the "*PIC32 Family Reference Manual*", which is available from the Microchip web site (www.microchip.com/PIC32). The Reset module combines all Reset sources and controls the device Master Reset signal, SYSRST. The following is a list of device Reset sources:

- POR: Power-on Reset
- MCLR: Master Clear Reset pin
- · SWR: Software Reset
- WDTR: Watchdog Timer Reset
- · BOR: Brown-out Reset
- CMR: Configuration Mismatch Reset
- HVDR: High Voltage Detect Reset

A simplified block diagram of the Reset module is illustrated in Figure 7-1.



## FIGURE 7-1: SYSTEM RESET BLOCK DIAGRAM

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

### REGISTER 9-2: DMASTAT: DMA STATUS REGISTER

### Legend:

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

- bit 3 RDWR: Read/Write Status bit
  - 1 = Last DMA bus access was a read
  - 0 = Last DMA bus access was a write
- bit 2-0 **DMACH<2:0>:** DMA Channel bits These bits contain the value of the most recent active DMA channel.

## REGISTER 9-3: DMAADDR: DMA ADDRESS 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 |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|
| 24.04        | R-0               | R-0               | R-0               | R-0               | R-0               | R-0               | R-0              | R-0              |  |  |  |
| 31:24        | DMAADDR<31:24>    |                   |                   |                   |                   |                   |                  |                  |  |  |  |
| 00.40        | R-0               | R-0               | R-0               | R-0               | R-0               | R-0               | R-0              | R-0              |  |  |  |
| 23:16        | DMAADDR<23:16>    |                   |                   |                   |                   |                   |                  |                  |  |  |  |
| 15:8         | R-0               | R-0               | R-0               | R-0               | R-0               | R-0               | R-0              | R-0              |  |  |  |
| 0.61         | DMAADDR<15:8>     |                   |                   |                   |                   |                   |                  |                  |  |  |  |
| 7.0          | R-0               | R-0               | R-0               | R-0               | R-0               | R-0               | R-0              | R-0              |  |  |  |
| 7:0          |                   |                   |                   | DMAADD            | R<7:0>            |                   |                  |                  |  |  |  |

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

bit 31-0 DMAADDR<31:0>: DMA Module Address bits

These bits contain the address of the most recent DMA access.

| REGISTE      | REGISTER 9-8: DCHXECON: DMA CHANNEL 'X' EVENT CONTROL REGISTER |                   |                   |                   |                   |                   |                  |                  |  |  |
|--------------|----------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|
| Bit<br>Range | Bit<br>31/23/15/7                                              | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |
| 31:24        | U-0                                                            | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |
| 31.24        | —                                                              | —                 | —                 | —                 | —                 | —                 | _                | —                |  |  |
| 22:16        | R/W-1                                                          | R/W-1             | R/W-1             | R/W-1             | R/W-1             | R/W-1             | R/W-1            | R/W-1            |  |  |
| 23:16        | CHAIRQ<7:0> <sup>(1)</sup>                                     |                   |                   |                   |                   |                   |                  |                  |  |  |
| 15:0         | R/W-1                                                          | R/W-1             | R/W-1             | R/W-1             | R/W-1             | R/W-1             | R/W-1            | R/W-1            |  |  |
| 15:8         | CHSIRQ<7:0> <sup>(1)</sup>                                     |                   |                   |                   |                   |                   |                  |                  |  |  |
| 7:0          | S-0                                                            | S-0               | R/W-0             | R/W-0             | R/W-0             | U-0               | U-0              | U-0              |  |  |
| 7.0          | CFORCE                                                         | CABORT            | PATEN             | SIRQEN            | AIRQEN            | _                 |                  |                  |  |  |

#### 

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

#### bit 31-24 **-** -· ~ '

| bit 31-24 | Unimplemented: Read as '0'                                                       |
|-----------|----------------------------------------------------------------------------------|
| bit 23-16 | CHAIRQ<7:0>: Channel Transfer Abort IRQ bits <sup>(1)</sup>                      |
|           | 11111111 = Interrupt 255 will abort any transfers in progress and set CHAIF flag |
|           | •                                                                                |
|           | •                                                                                |
|           | •                                                                                |
|           | 00000001 = Interrupt 1 will abort any transfers in progress and set CHAIF flag   |
|           | 00000000 = Interrupt 0 will abort any transfers in progress and set CHAIF flag   |
| bit 15-8  | CHSIRQ<7:0>: Channel Transfer Start IRQ bits <sup>(1)</sup>                      |
|           | 11111111 = Interrupt 255 will initiate a DMA transfer                            |
|           | •                                                                                |
|           | •                                                                                |
|           | •                                                                                |
|           | 00000001 = Interrupt 1 will initiate a DMA transfer                              |
|           | 0000000 = Interrupt 0 will initiate a DMA transfer                               |
| bit 7     | CFORCE: DMA Forced Transfer bit                                                  |
|           | 1 = A DMA transfer is forced to begin when this bit is written to a '1'          |
|           | 0 = This bit always reads '0'                                                    |
| bit 6     | CABORT: DMA Abort Transfer bit                                                   |
|           | 1 = A DMA transfer is aborted when this bit is written to a '1'                  |
|           | 0 = This bit always reads '0'                                                    |
| bit 5     | PATEN: Channel Pattern Match Abort Enable bit                                    |
|           | 1 = Abort transfer and clear CHEN on pattern match                               |
|           | 2 Dettern weetsk is dischlad                                                     |

- 0 = Pattern match is disabled
- bit 4 SIRQEN: Channel Start IRQ Enable bit
  - 1 = Start channel cell transfer if an interrupt matching CHSIRQ occurs
  - 0 = Interrupt number CHSIRQ is ignored and does not start a transfer
- bit 3 AIRQEN: Channel Abort IRQ Enable bit
  - 1 = Channel transfer is aborted if an interrupt matching CHAIRQ occurs
  - 0 = Interrupt number CHAIRQ is ignored and does not terminate a transfer
- bit 2-0 Unimplemented: Read as '0'
- Note 1: See Table 5-1: "Interrupt IRQ, Vector and Bit Location" for the list of available interrupt IRQ sources.

|              | Celister 10-3. Utorestat. 036 016 Status Redister |                   |                   |                   |                   |                   |                  |                  |  |  |
|--------------|---------------------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|
| Bit<br>Range | Bit<br>31/23/15/7                                 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |
| 31:24        | U-0                                               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |
| 31.24        |                                                   | —                 | -                 |                   | _                 | -                 | -                | —                |  |  |
| 23:16        | U-0                                               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |
| 23.10        |                                                   | —                 | -                 |                   | _                 | -                 | -                | —                |  |  |
| 15:8         | U-0                                               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |
| 15.0         |                                                   | _                 | -                 |                   | _                 | -                 |                  | _                |  |  |
| 7.0          | R-0                                               | U-0               | R-0               | U-0               | R-0               | R-0               | U-0              | R-0              |  |  |
| 7:0          | ID                                                | —                 | LSTATE            | _                 | SESVD             | SESEND            |                  | VBUSVD           |  |  |

# REGISTER 10-3: U1OTGSTAT: USB OTG STATUS REGISTER

#### Legend:

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

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

- bit 7 ID: ID Pin State Indicator bit
  - 1 = No cable is attached or a Type-B cable has been plugged into the USB receptacle
  - 0 = A Type-A cable has been plugged into the USB receptacle
- bit 6 Unimplemented: Read as '0'
- bit 5 LSTATE: Line State Stable Indicator bit
  - 1 = USB line state (U1CON<SE0> and U1CON<JSTATE>) has been stable for the previous 1 ms
  - 0 = USB line state (U1CON<SE0> and U1CON<JSTATE>) has not been stable for the previous 1 ms

#### bit 4 Unimplemented: Read as '0'

- bit 3 SESVD: Session Valid Indicator bit
  - 1 = VBUS voltage is above Session Valid on the A or B device
  - 0 = VBUS voltage is below Session Valid on the A or B device
- bit 2 **SESEND:** B-Device Session End Indicator bit
  - 1 = VBUS voltage is below Session Valid on the B device
  - 0 = VBUS voltage is above Session Valid on the B device

#### bit 1 Unimplemented: Read as '0'

- bit 0 VBUSVD: A-Device VBUS Valid Indicator bit
  - 1 = VBUS voltage is above Session Valid on the A device
  - 0 = VBUS voltage is below Session Valid on the A device

| 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.10        | U-0               | U-0               | U-0                  | U-0                  | U-0               | U-0               | U-0                    | U-0              |
| 23:16        | -                 | -                 | —                    | -                    | -                 | —                 | —                      | —                |
| 15:8         | U-0               | U-0               | U-0                  | U-0                  | U-0               | U-0               | U-0                    | U-0              |
| 15.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/WC-0, HS             | R/WC-0, HS       |
| 7:0          | BTSEF             | BMXEF             | DMAEF <sup>(1)</sup> | BTOEF <sup>(2)</sup> | DFN8EF            | CRC16EF           | CRC5EF <sup>(4)</sup>  | PIDEF            |
|              | BIGER             | DIVIALE           | DIVIALLY             | BIOEF                | DINOLF            | CRUIDEF           | EOFEF <sup>(3,5)</sup> | PIDEF            |

## REGISTER 10-8: U1EIR: USB ERROR INTERRUPT STATUS REGISTER

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

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

- bit 7 BTSEF: Bit Stuff Error Flag bit
  - 1 = Packet rejected due to bit stuff error
  - 0 = Packet accepted
- bit 6 BMXEF: Bus Matrix Error Flag bit
   1 = The base address, of the BDT, or the address of an individual buffer pointed to by a BDT entry, is invalid.
   0 = No address error
- bit 5 **DMAEF:** DMA Error Flag bit<sup>(1)</sup> 1 = USB DMA error condition detected
  - 0 = No DMA error
- bit 4 **BTOEF:** Bus Turnaround Time-Out Error Flag bit<sup>(2)</sup>
  - 1 = Bus turnaround time-out has occurred
  - 0 = No bus turnaround time-out

#### bit 3 **DFN8EF:** Data Field Size Error Flag bit

- 1 = Data field received is not an integral number of bytes
- 0 = Data field received is an integral number of bytes

#### bit 2 CRC16EF: CRC16 Failure Flag bit

- 1 = Data packet rejected due to CRC16 error
- 0 = Data packet accepted
- **Note 1:** This type of error occurs when the module's request for the DMA bus is not granted in time to service the module's demand for memory, resulting in an overflow or underflow condition, and/or the allocated buffer size is not sufficient to store the received data packet causing it to be truncated.
  - **2:** This type of error occurs when more than 16-bit-times of Idle from the previous End-of-Packet (EOP) has elapsed.
  - **3:** This type of error occurs when the module is transmitting or receiving data and the SOF counter has reached zero.
  - 4: Device mode.
  - 5: Host mode.

# 11.4 Control Registers

# TABLE 11-3: PORTA REGISTER MAP 100-PIN DEVICES ONLY

| -                           |                                 |           |               |               |       |       | -     |               |              |      |              |              |              |              |              |              |              |              |               |
|-----------------------------|---------------------------------|-----------|---------------|---------------|-------|-------|-------|---------------|--------------|------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|---------------|
| ress<br>)                   | <b>N</b> .                      | Ð         |               |               |       |       |       |               |              | 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<br>Resets |
| 6000                        | ANSELA                          | 31:16     | _             | _             | _     | _     | —     | —             | —            | _    | —            | —            | —            |              | —            |              | I            | —            | 0000          |
| 0000                        | ANGELA                          | 15:0      | _             | —             | _     | —     | —     | ANSELA10      | ANSELA9      | —    | —            | _            | _            |              | _            | _            |              | _            | 0060          |
| 6010                        | TRISA                           | 31:16     | _             | —             | _     | —     | —     | —             | —            | —    | —            | _            | _            |              | _            | _            |              | _            | 0000          |
| 0010                        | INISA                           | 15:0      | TRISA15       | TRISA14       | —     | —     | —     | TRISA10       | TRISA9       | —    | TRISA7       | TRISA6       | TRISA5       | TRISA4       | TRISA3       | TRISA2       | TRISA1       | TRISA0       | C6FF          |
| 6020                        | PORTA                           | 31:16     | —             | —             | —     | —     | —     | —             | —            | —    | —            | —            | —            | _            | —            | —            | _            | —            | 0000          |
| 0020                        | FURIA                           | 15:0      | RA15          | RA14          | —     | —     | —     | RA10          | RA9          | —    | RA7          | RA6          | RA5          | RA4          | RA3          | RA2          | RA1          | RA0          | xxxx          |
| 6030                        | LATA                            | 31:16     | —             | —             | —     | —     | —     | —             | —            | —    | —            | —            | —            | _            | —            | —            | _            | —            | 0000          |
| 0030                        | LAIA                            | 15:0      | LATA15        | LATA14        | —     | —     | —     | LATA10        | LATA9        | —    | LATA7        | LATA6        | LATA5        | LATA4        | LATA3        | LATA2        | LATA1        | LATA0        | xxxx          |
| 6040                        | ODCA                            | 31:16     | —             | —             | —     | —     | —     | —             | —            | —    | —            | —            | —            | _            | —            | —            | _            | —            | 0000          |
| 0040                        | ODCA                            | 15:0      | ODCA15        | ODCA14        | —     | —     | —     | ODCA10        | ODCA9        | —    | ODCA7        | ODCA6        | ODCA5        | ODCA4        | ODCA3        | ODCA2        | ODCA1        | ODCA0        | 0000          |
| 6050                        | CNPUA                           | 31:16     | _             | —             | _     | —     | _     | —             | —            | _    | —            | —            | —            | -            | —            | _            | _            | —            | 0000          |
| 0000                        |                                 | 15:0      | CNPUA15       | CNPUA14       | —     | —     | _     | CNPUA10       | CNPUA9       | —    | CNPUA7       | CNPUA6       | CNPUA5       | CNPUA4       | CNPUA3       | CNPUA2       | CNPUA1       | CNPUA0       | 0000          |
| 6060                        | CNPDA                           | 31:16     | _             | —             | _     | _     | _     | _             | —            | _    | _            |              |              | _            |              | _            |              |              | 0000          |
| 0000                        |                                 | 15:0      | CNPDA15       | CNPDA14       | _     | _     | _     | CNPDA10       | CNPDA9       | _    | CNPDA7       | CNPDA6       | CNPDA5       | CNPDA4       | CNPDA3       | CNPDA2       | CNPDA1       | CNPDA0       | 0000          |
| 6070                        | CNCONA                          | 31:16     | —             | —             | —     | —     | —     | —             | —            | —    | —            | —            | —            | —            | —            | —            | _            | —            | 0000          |
| 0010                        |                                 | 15:0      | ON            | —             | SIDL  | —     | —     | —             | —            | —    | —            | —            | —            | —            | —            | —            | —            | —            | 0000          |
| 6080                        | CNENA                           | 31:16     | —             | —             | —     | —     | —     | —             | —            | —    | —            | —            | —            | —            | —            | —            | —            | —            | 0000          |
| 0000                        | ONEN                            | 15:0      | CNIEA15       | CNIEA14       | _     | _     | _     | CNIEA10       | CNIEA9       | _    | CNIEA7       | CNIEA6       | CNIEA5       | CNIEA4       | CNIEA3       | CNIEA2       | CNIEA1       | CNIEA0       | 0000          |
|                             |                                 | 31:16     | _             | —             | _     | —     | —     | —             | —            | _    | —            | —            | —            | _            | —            | —            | _            | —            | 0000          |
| 6090                        | CNSTATA                         | 15:0      | CN<br>STATA15 | CN<br>STATA14 | _     | _     | _     | CN<br>STATA10 | CN<br>STATA9 | _    | CN<br>STATA7 | CN<br>STATA6 | CN<br>STATA5 | CN<br>STATA4 | CN<br>STATA3 | CN<br>STATA2 | CN<br>STATA1 | CN<br>STATA0 | 0000          |

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

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

# TABLE 11-10: PORTE REGISTER MAP FOR 64-PIN DEVICES ONLY

| ess                         |                                 | 0         |       |       |       |       |       |       |      | E    | Bits         |              |              |              |              |              |              |              |               |
|-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|---------------|
| 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<br>Resets |
| 6400                        | ANSELE                          | 31:16     | —     | _     | —     | —     | _     | _     |      | -    | —            | —            | —            | —            | -            | _            | —            | _            | 0000          |
| 0400                        | ANSELE                          | 15:0      | —     | -     |       | —     | -     | _     |      |      | ANSELE7      | ANSELE6      | ANSELE5      | ANSELE4      |              | ANSELE2      | -            | _            | 03F4          |
| 6410                        | TRISE                           | 31:16     | —     | -     | -     | _     | -     | -     |      |      | _            | —            |              | 1            |              | _            | -            | —            | 0000          |
| 0410                        | TRISE                           | 15:0      | —     | _     | —     | —     | _     | _     | _    | _    | TRISE7       | TRISE6       | TRISE5       | TRISE4       | TRISE3       | TRISE2       | TRISE1       | TRISE0       | OOFF          |
| 6420                        | PORTE                           | 31:16     | _     | _     |       | _     | _     | _     |      |      | _            | _            |              |              |              | _            |              | -            | 0000          |
| 0420                        | FORTE                           | 15:0      | _     | _     | _     | _     | _     | _     | _    | _    | RE7          | RE6          | RE5          | RE4          | RE3          | RE2          | RE1          | RE0          | xxxx          |
| 6440                        | LATE                            | 31:16     | _     | -     | -     | _     | -     | _     |      |      | _            | _            | -            |              |              | -            | -            | _            | 0000          |
| 0440                        | LAIL                            | 15:0      | —     | -     |       | —     | -     | _     |      |      | LATE7        | LATE6        | LATE5        | LATE4        | LATE3        | LATE2        | LATE1        | LATE0        | xxxx          |
| 6440                        | ODCE                            | 31:16     | —     | -     |       | —     | -     | _     |      |      | _            | -            |              |              |              | _            |              | -            | 0000          |
| 0440                        | ODOL                            | 15:0      | —     | _     | —     | —     | _     | _     | —    | -    | ODCE7        | ODCE6        | ODCE5        | ODCE4        | ODCE3        | ODCE2        | ODCE1        | ODCE0        | 0000          |
| 6450                        | CNPUE                           | 31:16     | —     | _     | —     | —     | _     | _     | —    | -    | —            | —            | _            | —            | _            | —            | _            | —            | 0000          |
| 0400                        |                                 | 15:0      | —     | —     | —     | —     | —     | —     | _    | _    | CNPUE7       | CNPUE6       | CNPUE5       | CNPUE4       | CNPDE3       | CNPUE2       | CNPUE1       | CNPUE0       | 0000          |
| 6460                        | CNPDE                           | 31:16     | —     | —     | _     | —     | —     | —     |      | _    | —            |              |              |              |              | —            |              |              | 0000          |
| 0400                        |                                 | 15:0      | —     | —     | _     | —     | —     | —     |      | _    | CNPDE7       | CNPDE6       | CNPDE5       | CNPDE4       | CNPDE3       | CNPDE2       | CNPDE1       | CNPDE0       | 0000          |
| 6470                        | CNCONE                          | 31:16     | —     | —     | —     | —     | —     | —     |      | _    | —            |              |              |              |              | —            |              |              | 0000          |
| 0470                        | ONCOME                          | 15:0      | ON    | —     | SIDL  | —     | —     | —     |      | _    | —            |              |              |              |              | —            |              |              | 0000          |
| 6480                        | CNENE                           | 31:16     | —     | —     | _     | —     | —     | —     |      | _    | —            |              |              |              |              | —            |              |              | 0000          |
| 0400                        | ONLINE                          | 15:0      | —     | _     | —     | —     | _     | _     | _    | -    | CNIEE7       | CNIEE6       | CNIEE5       | CNIEE4       | CNIEE3       | CNIEE2       | CNIEE1       | CNIEE0       | 0000          |
|                             |                                 | 31:16     | —     | _     | —     | —     | _     | _     |      |      | —            | —            | -            | 1            | -            | —            | -            | —            | 0000          |
| 6490                        | CNSTATE                         | 15:0      | —     | -     |       | _     | -     | _     |      |      | CN<br>STATE7 | CN<br>STATE6 | CN<br>STATE5 | CN<br>STATE4 | CN<br>STATE3 | CN<br>STATE2 | CN<br>STATE1 | CN<br>STATE0 | 0000          |

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

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

| IVE OIS LE   |                   |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| 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:16        | 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         | DATAOUT<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            |  |  |  |  |
|              | DATAOUT<7:0>      |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |

### REGISTER 20-4: PMDOUT: PARALLEL PORT OUTPUT DATA REGISTER

# Legend:

| 9                 |                  |                        |                    |
|-------------------|------------------|------------------------|--------------------|
| 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-0 DATAOUT<15:0>: Port Data Output bits

This register is used for Read operations in the Enhanced Parallel Slave mode and Write operations for Dual Buffer Master mode.

In Dual Buffer Master mode, the DUALBUF bit (PMPCON<17>) = 1, a write to the MSB triggers the transaction on the PMP port. When MODE16 = 1, MSB = DATAOUT<15:8>. When MODE16 = 0, MSB = DATAOUT<7:0>.

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

#### REGISTER 20-5: PMDIN: PARALLEL PORT INPUT DATA REGISTER

# Legend:

| 9                 |                  |                        |                    |
|-------------------|------------------|------------------------|--------------------|
| 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-0 DATAIN<15:0>: Port Data Input bits

This register is used for both Parallel Master Port mode and Enhanced Parallel Slave mode. In Parallel Master mode, a write to the MSB triggers the write transaction on the PMP port. Similarly, a read to the MSB triggers the read transaction on the PMP port. When MODE16 = 1, MSB = DATAIN<15:8>. When MODE16 = 0, MSB = DATAIN<7:0>.

Note: This register is not used in Dual Buffer Master mode (i.e., DUALBUF bit (PMPCON<17>) = 1).

**Note:** In Master mode, a read will return the last value written to the register. In Slave mode, a read will return indeterminate results.

## REGISTER 21-1: RTCCON: RTC CONTROL REGISTER (CONTINUED)

- bit 3 RTCWREN: RTC Value Registers Write Enable bit<sup>(4)</sup>
  - 1 = RTC Value registers can be written to by the user
    - 0 = RTC Value registers are locked out from being written to by the user
- bit 2 RTCSYNC: RTCC Value Registers Read Synchronization bit
  - 1 = RTC Value registers can change while reading, due to a rollover ripple that results in an invalid data read If the register is read twice and results in the same data, the data can be assumed to be valid
  - 0 = RTC Value registers can be read without concern about a rollover ripple
- bit 1 HALFSEC: Half-Second Status bit<sup>(5)</sup>
  - 1 = Second half period of a second
  - 0 = First half period of a second
- bit 0 RTCOE: RTCC Output Enable bit
  - 1 = RTCC clock output enabled clock presented onto an I/O
  - 0 = RTCC clock output disabled
- **Note 1:** The ON bit is only writable when RTCWREN = 1.
  - 2: When using the 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.
  - 3: Requires RTCOE = 1 (RTCCON<0>) for the output to be active.
  - 4: The RTCWREN bit can be set only when the write sequence is enabled.
  - 5: This bit is read-only. It is cleared to '0' on a write to the seconds bit fields (RTCTIME<14:8>).

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

| REGIST  | ER 21-2: RTCALRM: RTC ALARM CONTROL REGISTER (CONTINUED)                                               |
|---------|--------------------------------------------------------------------------------------------------------|
| bit 7-0 | ARPT<7:0>: Alarm Repeat Counter Value bits <sup>(3)</sup>                                              |
|         | 11111111 =Alarm will trigger 256 times                                                                 |
|         | •                                                                                                      |
|         | •                                                                                                      |
|         | •<br>00000000 =Alarm will trigger one time                                                             |
|         | The counter decrements on any alarm event. The counter only rolls over from 0x00 to 0xFF if CHIME = 1. |
| 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).                                                 |
|         |                                                                                                        |

| ILCIOID IL   |                   |                   |                   |                   |                   |                   |                  |                  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
| 04.04        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 31:24        | —                 | _                 | _                 | —                 | _                 | _                 | _                | —                |
| 00.40        | 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        |                   | MONT              | H10<3:0>          |                   |                   | MONTH             | 01<3:0>          |                  |
| 45.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         |                   | DAY               | 10<1:0>           |                   |                   | DAY01             | <3:0>            |                  |
| 7.0          | U-0               | U-0               | U-0               | U-0               | R/W-x             | R/W-x             | R/W-x            | R/W-x            |
| 7:0          | _                 | —                 | —                 | _                 |                   | WDAY0             | 1<3:0>           |                  |

# REGISTER 21-6: ALRMDATE: ALARM DATE VALUE REGISTER

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

bit 31-24 Unimplemented: Read as '0'

bit 23-20 MONTH10<3:0>: Binary Coded Decimal value of months bits, 10s place digits; contains a value of 0 or 1

bit 19-16 MONTH01<3:0>: Binary Coded Decimal value of months bits, 1s place digit; contains a value from 0 to 9

bit 15-12 **DAY10<3:0>:** Binary Coded Decimal value of days bits, 10s place digits; contains a value from 0 to 3

bit 11-8 **DAY01<3:0>:** Binary Coded Decimal value of days bits, 1s place digit; contains a value from 0 to 9 bit 7-4 **Unimplemented:** Read as '0'

bit 3-0 WDAY01<3:0>: Binary Coded Decimal value of weekdays bits, 1s place digit; contains a value from 0 to 6

# 23.0 CONTROLLER AREA NETWORK (CAN)

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 34. "Controller Area Network (CAN)" (DS60001154) in the "PIC32 Family Reference Manual", which is available from the Microchip web site (www.microchip.com/PIC32).

The Controller Area Network (CAN) module supports the following key features:

- · Standards Compliance:
  - Full CAN 2.0B compliance
  - Programmable bit rate up to 1 Mbps
- Message Reception and Transmission:
  - 16 message FIFOs
  - Each FIFO can have up to 16 messages for a total of 256 messages

- FIFO can be a transmit message FIFO or a receive message FIFO
- User-defined priority levels for message FIFOs used for transmission
- 16 acceptance filters for message filtering
- Four acceptance filter mask registers for message filtering
- Automatic response to remote transmit request
- DeviceNet<sup>™</sup> addressing support
- Additional Features:
  - Loopback, Listen All Messages, and Listen Only modes for self-test, system diagnostics and bus monitoring
  - Low-power operating modes
  - CAN module is a bus master on the PIC32 system bus
  - Use of DMA is not required
  - Dedicated time-stamp timer
  - Dedicated DMA channels
- Data-only Message Reception mode

Figure 23-1 illustrates the general structure of the CAN module.

#### FIGURE 23-1: PIC32 CAN MODULE BLOCK DIAGRAM



#### 23.1 **Control Registers**

# TABLE 23-1: CAN1 REGISTER SUMMARY

| ess                         |                                 |               |              |                                                                                                                      |              |          |              |              |             | Bit         | 5       |                   |             |             |             |            |         |         |            |
|-----------------------------|---------------------------------|---------------|--------------|----------------------------------------------------------------------------------------------------------------------|--------------|----------|--------------|--------------|-------------|-------------|---------|-------------------|-------------|-------------|-------------|------------|---------|---------|------------|
| 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 |
|                             | 01001                           | 31:16         | _            | _                                                                                                                    | _            | _        | ABAT         | F            | REQOP<2:0   | >           | (       | OPMOD<2:0         | >           | CANCAP      | _           | _          | _       | _       | 0480       |
| B000                        | C1CON                           | 15:0          | ON           | ON - SIDLE - CANBUSY DNCNT<4:0>                                                                                      |              |          |              |              |             |             |         | •                 | 0000        |             |             |            |         |         |            |
| B010                        | C1CFG                           | 31:16         | _            | — — — — — — — — WAKFIL — — — SI                                                                                      |              |          |              |              |             |             |         | EG2PH<2:0         | >           | 0000        |             |            |         |         |            |
| 8010                        | CICFG                           | 15:0          | SEG2PHTS     |                                                                                                                      |              |          |              |              |             |             |         |                   |             | 0000        |             |            |         |         |            |
| B020                        | C1INT                           | 31:16         | IVRIE        | IVRIE WAKIE CERRIE SERRIE RBOVIE — — — — — — — MODIE CTMRIE RBIE                                                     |              |          |              |              |             |             |         |                   | TBIE        | 0000        |             |            |         |         |            |
| 0020                        | 01111                           | 15:0          | IVRIF        | WAKIF                                                                                                                | CERRIF       | SERRIF   | RBOVIF       | —            | —           | —           | —       | —                 | —           | —           | MODIF       | CTMRIF     | RBIF    | TBIF    | 0000       |
| B030                        | C1VEC                           | 31:16         | —            | —                                                                                                                    | —            | —        | —            | _            | —           | —           | _       | —                 | —           | —           | —           | —          | —       | —       | 0000       |
| 2000                        |                                 | 15:0          | —            |                                                                                                                      |              |          |              |              |             |             |         |                   |             | 0040        |             |            |         |         |            |
| B040                        | C1TREC                          | 31:16         | —            | _                                                                                                                    | _            | —        | _            | _            | —           | —           | —       | _                 | TXBO        | TXBP        | RXBP        | TXWARN     | RXWARN  | EWARN   | 0000       |
|                             |                                 | 15:0          |              |                                                                                                                      |              | TERRC    | NT<7:0>      |              |             |             |         |                   |             | RERRCN      | T<7:0>      |            |         |         | 0000       |
| B050                        | C1FSTAT                         | 31:16         | -            | -                                                                                                                    | -            | -        | -            | -            | -           | -           | -       | -                 | -           | -           | -           | -          | -       | -       | 0000       |
|                             |                                 | 15:0          | FIFOIP15     | FIFOIP14                                                                                                             | FIFOIP13     | FIFOIP12 | FIFOIP11     | FIFOIP10     | FIFOIP9     | FIFOIP8     | FIFOIP7 | FIFOIP6           | FIFOIP5     | FIFOIP4     | FIFOIP3     | FIFOIP2    | FIFOIP1 | FIFOIP0 | 0000       |
| B060                        | C1RXOVF                         | 31:16<br>15:0 | —<br>RXOVF15 | —<br>RXOVF14                                                                                                         | –<br>RXOVF13 |          | –<br>RXOVF11 | –<br>RXOVF10 | –<br>RXOVF9 | –<br>RXOVF8 | RXOVF7  | –<br>RXOVF6       | –<br>RXOVF5 | —<br>RXOVF4 | –<br>RXOVF3 | RXOVF2     | RXOVF1  | RXOVF0  | 0000       |
|                             |                                 | 31:16         | KAUVE 15     | KAUVF14                                                                                                              | RAUVEIS      | RAUVE 12 | RAUVEII      | RAUVEIU      | KAUVF9      | CANTS<      |         | RAUVEO            | RAUVFS      | KAUVF4      | RAUVES      | RAUVF2     | RAUVEI  | RAUVFU  | 0000       |
| B070                        | C1TMR                           | 15:0          |              |                                                                                                                      |              |          |              |              | CA          | NTSPRE<15   |         |                   |             |             |             |            |         |         | 0000       |
|                             |                                 | 31:16         |              |                                                                                                                      |              |          |              | SID<10:0>    | 0A          |             | 05      |                   |             |             | MIDE        | _          | EID<1   | 7.16>   | xxxx       |
| B080                        | C1RXM0                          | 15:0          |              |                                                                                                                      |              |          |              | 012 110.0    |             | EID<1       | 5.0>    |                   |             |             | MIDE        |            |         | 7.10    | XXXX       |
|                             |                                 | 31:16         |              |                                                                                                                      |              |          |              | SID<10:0>    |             |             |         |                   |             |             | MIDE        |            | EID<1   | 7.16>   | xxxx       |
| B090                        | C1RXM1                          | 15:0          |              |                                                                                                                      |              |          |              | 0.0 10.0     |             | EID<1       | 5.0>    |                   |             |             |             |            | 2.0     |         | XXXX       |
|                             |                                 | 31:16         |              |                                                                                                                      |              |          |              | SID<10:0>    |             | 210 11      |         |                   |             |             | MIDE        | _          | EID<1   | 7.16>   | xxxx       |
| B0A0                        | C1RXM2                          | 15:0          |              |                                                                                                                      |              |          |              | 0.0 10.0     |             | EID<1       | 5:0>    |                   |             |             |             |            | 2.0     |         | XXXX       |
|                             |                                 | 31:16         |              |                                                                                                                      |              |          |              | SID<10:0>    |             |             |         |                   |             |             | MIDE        | _          | EID<1   | 7:16>   | xxxx       |
| B0B0                        | C1RXM3                          | 15:0          |              |                                                                                                                      |              |          |              |              |             | EID<1       | 5:0>    |                   |             |             |             |            | ļ       |         | xxxx       |
|                             |                                 | 31:16         | FLTEN3       | MSEL                                                                                                                 | 3<1:0>       |          |              | FSEL3<4:0>   | >           |             | FLTEN2  | MSEL              | 2<1:0>      |             | F           | SEL2<4:0>  |         |         | 0000       |
| B0C0                        | C1FLTCON0                       | 15:0          | FLTEN1       | MSEL                                                                                                                 | 1<1:0>       |          |              | FSEL1<4:0>   | >           |             | FLTEN0  | MSEL              | 0<1:0>      |             | F           | SEL0<4:0>  |         |         | 0000       |
|                             | 0.151 700114                    | 31:16         | FLTEN7       | MSEL                                                                                                                 | 7<1:0>       |          |              | FSEL7<4:0>   | >           |             | FLTEN6  | MSEL              | 6<1:0>      |             | F           | SEL6<4:0>  |         |         | 0000       |
| B0D0                        | C1FLTCON1                       | 15:0          | FLTEN5       | MSEL                                                                                                                 | 5<1:0>       |          |              | FSEL5<4:0>   | <b>`</b>    |             | FLTEN4  | MSEL              | 4<1:0>      |             | F           | SEL4<4:0>  |         |         | 0000       |
| DOFO                        |                                 | 31:16         | FLTEN11      | MSEL <sup>2</sup>                                                                                                    | 11<1:0>      |          |              | FSEL11<4:0   | >           |             | FLTEN10 | MSEL <sup>2</sup> | 10<1:0>     |             | F           | SEL10<4:0> | •       |         | 0000       |
| B0E0                        | C1FLTCON2                       | 15:0          | FLTEN9       | FLTEN9         MSEL9<1:0>         FSEL9<4:0>         FLTEN8         MSEL8<1:0>         FSEL8<4:0>         000        |              |          |              |              |             |             |         |                   | 0000        |             |             |            |         |         |            |
| B0F0                        | C1FLTCON3                       | 31:16         | FLTEN15      | FLTEN15         MSEL15<1:0>         FSEL15<4:0>         FLTEN14         MSEL14<1:0>         FSEL14<4:0>         0000 |              |          |              |              |             |             |         |                   |             | 0000        |             |            |         |         |            |
| BUFU                        | GIFLI CONS                      | 15:0          | FLTEN13      | FLTEN13 MSEL13<1:0> FSEL13<4:0> FLTEN12 MSEL12<1:0> FSEL12<4:0> 0000                                                 |              |          |              |              |             |             |         |                   |             |             |             |            |         |         |            |
| B140                        | Onoan                           | 31:16         |              |                                                                                                                      |              |          |              | SID<10:0>    |             |             |         |                   |             |             | EXID        |            | EID<1   | 7:16>   | xxxx       |
| 040                         | (n = 0-15)                      | 15:0          |              |                                                                                                                      |              |          |              | aa ara ahawr |             | EID<1       | 5:0>    |                   |             |             |             |            |         |         | xxxx       |

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

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

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:

|              |                   | 101 00. DE        |                   | 100IIA IIOI       |                   |                   |                  |                  |  |  |  |  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|--|--|--|--|
| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |  |  |  |  |
| 24.24        | R/P               | R/P               | R/P               | R/P               | U-0               | U-0               | U-0              | U-0              |  |  |  |  |
| 31:24        | FVBUSONIO         | FUSBIDIO          | IOL1WAY           | PMDL1WAY          | _                 | —                 | —                | _                |  |  |  |  |
| 23:16        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |  |  |  |  |
| 23.10        | —                 | _                 | _                 | _                 | -                 | _                 | -                | _                |  |  |  |  |
| 15:8         | R/P               | R/P               | R/P               | R/P               | R/P               | R/P               | R/P              | R/P              |  |  |  |  |
| 10.0         |                   |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |
| 7:0          | R/P               | R/P               | R/P               | R/P               | R/P               | R/P               | R/P              | R/P              |  |  |  |  |
| 7:0          | USERID<7:0>       |                   |                   |                   |                   |                   |                  |                  |  |  |  |  |

#### REGISTER 28-4: DEVCFG3: DEVICE CONFIGURATION WORD 3

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

bit 31 FVBUSONIO: USB VBUS\_ON Selection bit

- 1 = VBUSON pin is controlled by the USB module 0 = VBUSON pin is controlled by the port function
- bit 30 **FUSBIDIO:** USB USBID Selection bit 1 = USBID pin is controlled by the USB module 0 = USBID pin is controlled by the port function
- bit 29 **IOL1WAY:** Peripheral Pin Select Configuration bit
  - 1 = Allow only one reconfiguration
  - 0 = Allow multiple reconfigurations
- bit 28 PMDL1WAY: Peripheral Module Disable Configuration bit
  - 1 = Allow only one reconfiguration
  - 0 = Allow multiple reconfigurations
- bit 27-16 Unimplemented: Read as '0'
- bit 15-0 USERID<15:0>: This is a 16-bit value that is user-defined and is readable via ICSP™ and JTAG

# 28.3 On-Chip Voltage Regulator

All PIC32MX1XX/2XX/5XX 64/100-pin devices' core and digital logic are designed to operate at a nominal 1.8V. To simplify system designs, most devices in the PIC32MX1XX/2XX/5XX 64/100-pin family incorporate an on-chip regulator providing the required core logic voltage from VDD.

A low-ESR capacitor (such as tantalum) must be connected to the VCAP pin (see Figure 28-1). This helps to maintain the stability of the regulator. The recommended value for the filter capacitor is provided in **Section 31.1 "DC Characteristics"**.

| Note: | It is important that the low-ESR capacitor |
|-------|--------------------------------------------|
|       | is placed as close as possible to the VCAP |
|       | pin.                                       |

### 28.3.1 HIGH VOLTAGE DETECT (HVD)

The HVD module monitors the core voltage at the VCAP pin. If a voltage above the required level is detected on VCAP, the I/O pins are disabled and the device is held in Reset as long as the HVD condition persists. See parameter HV10 (VHVD) in Table 31-11 in **Section 31.1** "**DC Characteristics**" for more information.

### 28.3.2 ON-CHIP REGULATOR AND POR

It takes a fixed delay for the on-chip regulator to generate an output. During this time, designated as TPU, code execution is disabled. TPU is applied every time the device resumes operation after any power-down, including Sleep mode.

#### 28.3.3 ON-CHIP REGULATOR AND BOR

PIC32MX1XX/2XX/5XX 64/100-pin devices also have a simple brown-out capability. If the voltage supplied to the regulator is inadequate to maintain a regulated level, the regulator Reset circuitry will generate a Brown-out Reset. This event is captured by the BOR flag bit (RCON<1>). The brown-out voltage levels are specific in **Section 31.1 "DC Characteristics"**.

# FIGURE 28-1: CONNECTIONS FOR THE ON-CHIP REGULATOR



# 28.4 Programming and Diagnostics

PIC32MX1XX/2XX/5XX 64/100-pin devices provide a complete range of programming and diagnostic features that can increase the flexibility of any application using them. These features allow system designers to include:

- Simplified field programmability using two-wire In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) interfaces
- · Debugging using ICSP
- Programming and debugging capabilities using the EJTAG extension of JTAG
- JTAG boundary scan testing for device and board diagnostics

PIC32 devices incorporate two programming and diagnostic modules that provide a range of functions to the application developer.



#### BLOCK DIAGRAM OF PROGRAMMING, DEBUGGING AND TRACE PORTS



# 30.6 MPLAB X SIM Software Simulator

The MPLAB X SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers.

The MPLAB X SIM Software Simulator fully supports symbolic debugging using the MPLAB XC Compilers, and the MPASM and MPLAB Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool.

# 30.7 MPLAB REAL ICE In-Circuit Emulator System

The MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs all 8, 16 and 32-bit MCU, and DSC devices with the easy-to-use, powerful graphical user interface of the MPLAB X IDE.

The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with in-circuit debugger systems (RJ-11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5).

The emulator is field upgradable through future firmware downloads in MPLAB X IDE. MPLAB REAL ICE offers significant advantages over competitive emulators including full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, logic probes, a ruggedized probe interface and long (up to three meters) interconnection cables.

# 30.8 MPLAB ICD 3 In-Circuit Debugger System

The MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost-effective, high-speed hardware debugger/programmer for Microchip Flash DSC and MCU devices. It debugs and programs PIC Flash microcontrollers and dsPIC DSCs with the powerful, yet easy-to-use graphical user interface of the MPLAB IDE.

The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a highspeed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers.

# 30.9 PICkit 3 In-Circuit Debugger/ Programmer

The MPLAB PICkit 3 allows debugging and programming of PIC and dsPIC Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB IDE. The MPLAB PICkit 3 is connected to the design engineer's PC using a fullspeed USB interface and can be connected to the target via a Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the Reset line to implement in-circuit debugging and In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>).

# 30.10 MPLAB PM3 Device Programmer

The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features a large LCD display (128 x 64) for menus and error messages, and a modular, detachable socket assembly to support various package types. The ICSP cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in this mode. The MPLAB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized algorithms for quick programming of large memory devices, and incorporates an MMC card for file storage and data applications.

| DC CHARACTERISTICS                    |                        |      | $ \begin{array}{ l l l l l l l l l l l l l l l l l l l$ |            |                                                 |
|---------------------------------------|------------------------|------|---------------------------------------------------------|------------|-------------------------------------------------|
| Param.<br>No.                         | Typical <sup>(2)</sup> | Max. | Units                                                   | Conditions |                                                 |
| Power-Down Current (IPD) (Notes 1, 5) |                        |      |                                                         |            |                                                 |
| DC40k                                 | 33                     | 78   | μA                                                      | -40°C      |                                                 |
| DC40I                                 | 49                     | 78   | μA                                                      | +25°C      | Base Power-Down Current                         |
| DC40n                                 | 281                    | 450  | μA                                                      | +85°C      | Base Fower-Down Current                         |
| DC40m                                 | 559                    | 895  | μA                                                      | +105°C     |                                                 |
| Module Differential Current           |                        |      |                                                         |            |                                                 |
| DC41e                                 | 10                     | 25   | μA                                                      | 3.6V       | Watchdog Timer Current: AIWDT (Note 3)          |
| DC42e                                 | 29                     | 50   | μA                                                      | 3.6V       | RTCC + Timer1 w/32 kHz Crystal: ΔIRTCC (Note 3) |
| DC43d                                 | 1000                   | 1300 | μA                                                      | 3.6V       | ADC: △IADC (Notes 3,4)                          |

## TABLE 31-7: DC CHARACTERISTICS: POWER-DOWN CURRENT (IPD)

**Note 1:** The test conditions for IPD current measurements are as follows:

Oscillator mode is EC (for 8 MHz and below) and EC+PLL (for above 8 MHz) with OSC1 driven by external square wave from rail-to-rail, (OSC1 input clock input over/undershoot < 100 mV required)

OSC2/CLKO is configured as an I/O input pin

- USB PLL oscillator is disabled if the USB module is implemented, PBCLK divisor = 1:8
- CPU is in Sleep mode, and SRAM data memory Wait states = 1
- No peripheral modules are operating, (ON bit = 0), but the associated PMD bit is set
- WDT, Clock Switching, Fail-Safe Clock Monitor, and Secondary Oscillator are disabled
- All I/O pins are configured as inputs and pulled to Vss
- MCLR = VDD
- RTCC and JTAG are disabled
- 2: Data in the "Typical" column is at 3.3V, 25°C unless otherwise stated. Parameters are for design guidance only and are not tested.
- **3:** The ∆ current is the additional current consumed when the module is enabled. This current should be added to the base IPD current.
- 4: Test conditions for ADC module differential current are as follows: Internal ADC RC oscillator enabled.
- 5: IPD electrical characteristics for devices with 256 KB Flash are only provided as Preliminary information.

| AC CHARACTERISTICS <sup>(2)</sup> |          |                       |         |                 |                                                         |
|-----------------------------------|----------|-----------------------|---------|-----------------|---------------------------------------------------------|
| ADC Speed                         | TAD Min. | Sampling<br>Time Min. | Rs Max. | Vdd             | ADC Channels Configuration                              |
| 1 Msps to 400 ksps <sup>(1)</sup> | 65 ns    | 132 ns                | 500Ω    | 3.0V to<br>3.6V | ANX CHX ADC                                             |
| Up to 400 ksps                    | 200 ns   | 200 ns                | 5.0 kΩ  | 2.5V to<br>3.6V | ANX CHX<br>ANX OF VREF-<br>ANX OF VREF-<br>ANX OF VREF- |

#### TABLE 31-35: 10-BIT CONVERSION RATE PARAMETERS

**Note 1:** External VREF- and VREF+ pins must be used for correct operation.

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

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

# **PRODUCT IDENTIFICATION SYSTEM**

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

| Package             |                                                                                                                                                                                                                          | Example:<br>PIC32MX170F512H-50I/PT:<br>General Purpose PIC32, 32-bit RISC MCU,<br>512 KB program memory,<br>64-pin, Industrial temperature,<br>TQFP package. |  |  |  |  |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Flash Memory Fan    | nily                                                                                                                                                                                                                     |                                                                                                                                                              |  |  |  |  |  |
| Architecture        | MX = 32-bit RISC MCU core                                                                                                                                                                                                |                                                                                                                                                              |  |  |  |  |  |
| Product Groups      | 1XX = General Purpose microcontroller family<br>2XX = USB microcontroller family<br>5XX = USB and CAN microcontroller family                                                                                             |                                                                                                                                                              |  |  |  |  |  |
| Flash Memory Family | F = Flash program memory                                                                                                                                                                                                 |                                                                                                                                                              |  |  |  |  |  |
| Program Memory Size | 064 = 64 KB<br>128 = 128 KB<br>256 = 256 KB<br>512 = 512 KB                                                                                                                                                              |                                                                                                                                                              |  |  |  |  |  |
| Pin Count           | H = 64-pin<br>L = 100-pin                                                                                                                                                                                                |                                                                                                                                                              |  |  |  |  |  |
| Speed               | = 40 MHz (blank, no marking on package)<br>50 = 50 MHz                                                                                                                                                                   |                                                                                                                                                              |  |  |  |  |  |
| Temperature Range   | I = $-40^{\circ}$ C to $+85^{\circ}$ C (Industrial)<br>V = $-40^{\circ}$ C to $+105^{\circ}$ C (V-Temp)                                                                                                                  |                                                                                                                                                              |  |  |  |  |  |
| Package             | PT = 64-Lead (10x10x1 mm) TQFP (Thin Quad Flatpack)<br>PT = 100-Lead (12x12x1 mm) TQFP (Thin Quad Flatpack)<br>PF = 100-Lead (14x14x1 mm) TQFP (Thin Quad Flatpack)<br>MR = 64-Lead (9x9x0.9 mm) QFN (Plastic Quad Flat) |                                                                                                                                                              |  |  |  |  |  |
| Pattern             | Three-digit QTP, SQTP, Code or Special Requirements (blank otherwise ES = Engineering Sample                                                                                                                             | e)                                                                                                                                                           |  |  |  |  |  |