

#### 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

| Product Status             | Obsolete                                                                        |
|----------------------------|---------------------------------------------------------------------------------|
| Core Processor             | MIPS32® M4K™                                                                    |
| Core Size                  | 32-Bit Single-Core                                                              |
| Speed                      | 80MHz                                                                           |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, PMP, SPI, UART/USART, USB OTG                   |
| Peripherals                | Brown-out Detect/Reset, DMA, POR, PWM, WDT                                      |
| Number of I/O              | 85                                                                              |
| Program Memory Size        | 256KB (256K x 8)                                                                |
| Program Memory Type        | FLASH                                                                           |
| EEPROM Size                | -                                                                               |
| RAM Size                   | 64K 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             | 124-VFTLA Dual Rows, Exposed Pad                                                |
| Supplier Device Package    | 124-VTLA (9x9)                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic32mx450f256lt-i-tl |
|                            |                                                                                 |

Email: info@E-XFL.COM

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

# TABLE 7: PIN NAMES FOR 124-PIN DEVICES (CONTINUED)

| 124               | -PIN VTLA (BOTTOM VIEW) <sup>(1,2,3,4)</sup>                             | 17       |                   |                | A34           | A34                   |  |  |
|-------------------|--------------------------------------------------------------------------|----------|-------------------|----------------|---------------|-----------------------|--|--|
|                   | A                                                                        | 17       |                   | B13 B29        |               | nductive<br>ermal Pad |  |  |
|                   | PIC32MX430F064L<br>PIC32MX450F128L<br>PIC32MX450F256L<br>PIC32MX470F512L |          |                   | B1<br>B56      | B41           | A51                   |  |  |
|                   |                                                                          | y Indica | A1<br>tor         | A68            |               |                       |  |  |
| Package<br>Bump # | Full Pin Name                                                            |          | Package<br>Bump # |                | Full Pin Name |                       |  |  |
| B7                | MCLR                                                                     |          | B32               | SDA2/RA3       |               |                       |  |  |
| B8                | Vss                                                                      |          | B33               | TDO/RA5        |               |                       |  |  |
| B9                | TMS/CTED1/RA0                                                            |          | B34               | OSC1/CLKI/RC12 | 2             |                       |  |  |
| B10               | RPE9/RE9                                                                 |          | B35               | No Connect     |               |                       |  |  |
| B11               | AN4/C1INB/RB4                                                            |          | B36               | SCL1/RPA14/RA  | 14            |                       |  |  |
| B12               | Vss                                                                      |          | B37               | RPD8/RTCC/RD8  | 8             |                       |  |  |
| B13               | PGEC3/AN2/C2INB/RPB2/CTED13/RB2                                          |          | B38               | RPD10/SCK1/PM  | CS2/RD10      |                       |  |  |
| B14               | PGED1/AN0/RPB0/RB0                                                       |          | B39               | RPD0/INT0/RD0  |               |                       |  |  |
| B15               | No Connect                                                               |          | B40               | SOSCO/RPC14/T  | 1CK/RC14      |                       |  |  |
| B16               | PGED2/AN7/RPB7/CTED3/RB7                                                 |          | B41               | Vss            |               |                       |  |  |
| B17               | VREF+/CVREF+/PMA6/RA10                                                   |          | B42               | AN25/RPD2/RD2  |               |                       |  |  |
| B18               | AVss                                                                     |          | B43               | RPD12/PMD12/R  | D12           |                       |  |  |
| B19               | AN9/RPB9/CTED4/RB9                                                       |          | B44               | RPD4/PMWR/RD   | 4             |                       |  |  |
| B20               | AN11/PMA12/RB11                                                          |          | B45               | PMD14/RD6      |               |                       |  |  |
| B21               | Vdd                                                                      |          | B46               | No Connect     |               |                       |  |  |
| B22               | RPF13/RF13                                                               |          | B47               | No Connect     |               |                       |  |  |
| B23               | AN12/PMA11/RB12                                                          |          | B48               | VCAP           |               |                       |  |  |
| B24               | AN14/RPB14/CTED5/PMA1/RB14                                               |          | B49               | RPF0/PMD11/RF  | 0             |                       |  |  |
| B25               | Vss                                                                      |          | B50               | RPG1/PMD9/RG   | 1             |                       |  |  |
| B26               | RPD14/RD14                                                               |          | B51               | TRCLK/RA6      |               |                       |  |  |
| B27               | RPF4/PMA9/RF4                                                            |          | B52               | PMD0/RE0       |               |                       |  |  |
| B28               | No Connect                                                               |          | B53               | VDD            |               |                       |  |  |
| B29               | RPF8/RF8                                                                 |          | B54               | TRD2/RG14      |               |                       |  |  |
| B30               | VUSB3V3                                                                  |          | B55               | TRD0/RG13      |               |                       |  |  |
| B31               | D+                                                                       |          | B56               | RPE3/CTPLS/PM  | D3/RE3        |                       |  |  |

Note 1: The RPn pins can be used by remappable peripherals. See Table 1 for the available peripherals and Section 12.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 12.0 "I/O Ports" for more information.

3: Shaded package bumps are 5V tolerant.

4: It is recommended that the user connect the printed circuit board (PCB) ground to the conductive thermal pad on the bottom of the package. And to not run non-Vss PCB traces under the conductive thermal pad on the same side of the PCB layout.

# 2.5 ICSP Pins

The PGECx and PGEDx pins are used for In-Circuit Serial Programming<sup>TM</sup> (ICSP<sup>TM</sup>) and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of Ohms, not to exceed 100 Ohms.

Pull-up resistors, series diodes and capacitors on the PGECx and PGEDx pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits and pin input voltage high (VIH) and input low (VIL) requirements.

Ensure that the "Communication Channel Select" (i.e., PGECx/PGEDx pins) programmed into the device matches the physical connections for the ICSP to MPLAB<sup>®</sup> ICD 3 or MPLAB REAL ICE<sup>™</sup>.

For more information on ICD 3 and REAL ICE connection requirements, refer to the following documents that are available on the Microchip web site.

- "Using MPLAB<sup>®</sup> ICD 3" (poster) DS50001765
- "MPLAB<sup>®</sup> ICD 3 Design Advisory" DS50001764
- "MPLAB<sup>®</sup> REAL ICE™ In-Circuit Debugger User's Guide" DS50001616
- *"Using MPLAB<sup>®</sup> REAL ICE™ Emulator"* (poster) DS50001749

# 2.6 JTAG

The TMS, TDO, TDI and TCK pins are used for testing and debugging according to the Joint Test Action Group (JTAG) standard. It is recommended to keep the trace length between the JTAG connector and the JTAG pins on the device as short as possible. If the JTAG connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of Ohms, not to exceed 100 Ohms.

Pull-up resistors, series diodes and capacitors on the TMS, TDO, TDI and TCK pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits and pin input voltage high (VIH) and input low (VIL) requirements.

# 2.7 Trace

The trace pins can be connected to a hardware trace-enabled programmer to provide a compressed real-time instruction trace. When used for trace, the TRD3, TRD2, TRD1, TRD0 and TRCLK pins should be dedicated for this use. The trace hardware requires a 22 Ohm series resistor between the trace pins and the trace connector.

# 2.8 External Oscillator Pins

Many MCUs have options for at least two oscillators: a high-frequency primary oscillator and a low-frequency secondary oscillator (refer to **Section 8.0 "Oscillator Configuration"** for details).

The oscillator circuit should be placed on the same side of the board as the device. Also, place the oscillator circuit close to the respective oscillator pins, not exceeding one-half inch (12 mm) distance between them. The load capacitors should be placed next to the oscillator itself, on the same side of the board. Use a grounded copper pour around the oscillator circuit to isolate them from surrounding circuits. The grounded copper pour should be routed directly to the MCU ground. Do not run any signal traces or power traces inside the ground pour. Also, if using a two-sided board, avoid any traces on the other side of the board where the crystal is placed. A suggested layout is illustrated in Figure 2-3.

# FIGURE 2-3: SUGGESTED OSCILLATOR CIRCUIT PLACEMENT



| REGIST  | ER 7-6: IPCx: INTERRUPT PRIORITY CONTROL REGISTER (CONTINUED)                                                                                                                    |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 9-8 | IS1<1:0>: Interrupt Subpriority bits<br>11 = Interrupt subpriority is 3<br>10 = Interrupt subpriority is 2<br>01 = Interrupt subpriority is 1<br>00 = Interrupt subpriority is 0 |
| bit 7-5 | Unimplemented: Read as '0'                                                                                                                                                       |
| bit 4-2 | IP0<2:0>: Interrupt Priority bits                                                                                                                                                |
|         | <pre>111 = Interrupt priority is 7</pre>                                                                                                                                         |
|         | 001 = Interrupt priority is 1<br>000 = Interrupt is disabled                                                                                                                     |
| bit 1-0 | ISO<1:0>: Interrupt Subpriority bits                                                                                                                                             |
|         | <pre>11 = Interrupt subpriority is 3 10 = Interrupt subpriority is 2 01 = Interrupt subpriority is 1 00 = Interrupt subpriority is 0</pre>                                       |
| Note:   | This register represents a generic definition of the IPCx register. Refer to Table 7-1 for the exact bit definitions.                                                            |

| Bit<br>Range | Bit<br>31/23/15/7   | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 |       |     | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0      |
|--------------|---------------------|-------------------|-------------------|-------|-----|-------------------|------------------|-----------------------|
| 21.04        | U-0                 | U-0               | U-0               | U-0   | U-0 | U-0               | U-0              | U-0                   |
| 31:24        |                     | —                 | _                 | _     |     | _                 | -                | —                     |
| 00.40        | U-0                 | U-0               | U-0               | U-0   | U-0 | U-0               | U-0              | U-0                   |
| 23:16        | —                   | —                 | _                 | _     | _   | —                 | _                | —                     |
| 45.0         | R/W-0               | U-0               | U-0               | U-0   | U-0 | U-0               | U-0              | R/W-0                 |
| 15:8         | CHBUSY              | —                 | _                 | _     | _   | _                 | _                | CHCHNS <sup>(1)</sup> |
| 7.0          | R/W-0               | R/W-0             | R/W-0             | R/W-0 | U-0 | R-0 R/W-0         |                  | R/W-0                 |
| 7:0          | CHEN <sup>(2)</sup> | CHAED             | CHCHN             | CHAEN | _   | CHEDET            | CHPF             | RI<1:0>               |

# REGISTER 10-7: DCHxCON: DMA CHANNEL 'x' 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 CHBUSY: Channel Busy bit
  - 1 = Channel is active or has been enabled
  - 0 = Channel is inactive or has been disabled
- bit 14-9 Unimplemented: Read as '0'
- bit 8 CHCHNS: Chain Channel Selection bit<sup>(1)</sup>
  - 1 = Chain to channel lower in natural priority (CH1 will be enabled by CH2 transfer complete)
  - 0 = Chain to channel higher in natural priority (CH1 will be enabled by CH0 transfer complete)

# bit 7 CHEN: Channel Enable bit<sup>(2)</sup>

- 1 = Channel is enabled
- 0 = Channel is disabled

# bit 6 CHAED: Channel Allow Events If Disabled bit

- 1 = Channel start/abort events will be registered, even if the channel is disabled
- 0 = Channel start/abort events will be ignored if the channel is disabled

### bit CHCHN: Channel Chain Enable bit

- 1 = Allow channel to be chained
- 0 = Do not allow channel to be chained
- bit 4 CHAEN: Channel Automatic Enable bit
  - 1 = Channel is continuously enabled, and not automatically disabled after a block transfer is complete
     0 = Channel is disabled on block transfer complete

# bit 3 Unimplemented: Read as '0'

- bit 2 CHEDET: Channel Event Detected bit
  - 1 = An event has been detected
  - 0 = No events have been detected
- bit 1-0 CHPRI<1:0>: Channel Priority bits
  - 11 = Channel has priority 3 (highest)
  - 10 = Channel has priority 2
  - 01 = Channel has priority 1
  - 00 = Channel has priority 0
- Note 1: The chain selection bit takes effect when chaining is enabled (i.e., CHCHN = 1).
  - 2: When the channel is suspended by clearing this bit, the user application should poll the CHBUSY bit (if available on the device variant) to see when the channel is suspended, as it may take some clock cycles to complete a current transaction before the channel is suspended.

| 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        | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0             | R/W-0            | R/W-0            |
| 23:16        | CHSDIE            | CHSHIE            | CHDDIE            | CHDHIE            | CHBCIE            | CHCCIE            | CHTAIE           | CHERIE           |
| 45.0         | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 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          | CHSDIF            | CHSHIF            | CHDDIF            | CHDHIF            | CHBCIF            | CHCCIF            | CHTAIF           | CHERIF           |
|              |                   |                   |                   |                   |                   |                   |                  |                  |

# REGISTER 10-9: DCHxINT: DMA CHANNEL 'x' INTERRUPT 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-24  | Unimplemented: Read as '0'                                                                                                                |   |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------|---|
| bit 23     | CHSDIE: Channel Source Done Interrupt Enable bit                                                                                          |   |
|            | <ul><li>1 = Interrupt is enabled</li><li>0 = Interrupt is disabled</li></ul>                                                              |   |
| bit 22     | CHSHIE: Channel Source Half Empty Interrupt Enable bit                                                                                    |   |
|            | 1 = Interrupt is enabled                                                                                                                  |   |
| h:+ 04     | 0 = Interrupt is disabled                                                                                                                 |   |
| bit 21     | <b>CHDDIE:</b> Channel Destination Done Interrupt Enable bit<br>1 = Interrupt is enabled                                                  |   |
|            | 0 = Interrupt is disabled                                                                                                                 |   |
| bit 20     | CHDHIE: Channel Destination Half Full Interrupt Enable bit                                                                                |   |
|            | 1 = Interrupt is enabled                                                                                                                  |   |
|            | 0 = Interrupt is disabled                                                                                                                 |   |
| bit 19     | CHBCIE: Channel Block Transfer Complete Interrupt Enable bit                                                                              |   |
|            | <ul> <li>1 = Interrupt is enabled</li> <li>0 = Interrupt is disabled</li> </ul>                                                           |   |
| bit 18     | CHCCIE: Channel Cell Transfer Complete Interrupt Enable bit                                                                               |   |
| DIL TO     | 1 = Interrupt is enabled                                                                                                                  |   |
|            | 0 = Interrupt is disabled                                                                                                                 |   |
| bit 17     | CHTAIE: Channel Transfer Abort Interrupt Enable bit                                                                                       |   |
|            | 1 = Interrupt is enabled                                                                                                                  |   |
|            | 0 = Interrupt is disabled                                                                                                                 |   |
| bit 16     | CHERIE: Channel Address Error Interrupt Enable bit                                                                                        |   |
|            | <ul> <li>1 = Interrupt is enabled</li> <li>0 = Interrupt is disabled</li> </ul>                                                           |   |
| bit 15-8   | Unimplemented: Read as '0'                                                                                                                |   |
| bit 7      | CHSDIF: Channel Source Done Interrupt Flag bit                                                                                            |   |
|            | 1 = Channel Source Pointer has reached end of source (CHSPTR = CHSSIZ)                                                                    |   |
|            | 0 = No interrupt is pending                                                                                                               |   |
| bit 6      | CHSHIF: Channel Source Half Empty Interrupt Flag bit                                                                                      |   |
|            | 1 = Channel Source Pointer has reached midpoint of source (CHSPTR = CHSSIZ/2)                                                             |   |
|            | 0 = No interrupt is pending                                                                                                               |   |
| bit 5      | <b>CHDDIF:</b> Channel Destination Done Interrupt Flag bit                                                                                |   |
|            | <ul> <li>1 = Channel Destination Pointer has reached end of destination (CHDPTR = CHDSIZ)</li> <li>0 = No interrupt is pending</li> </ul> |   |
|            |                                                                                                                                           |   |
|            |                                                                                                                                           | - |
| © 2012-201 | 16 Microchip Technology Inc. DS                                                                                                           | 6 |

NOTES:

# REGISTER 18-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

# REGISTER 19-2: I2CxSTAT: I<sup>2</sup>C STATUS REGISTER

|              | -                 |                   |                   |                   |                   |                   |                  |                  |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
| 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        | —                 | _                 | _                 | _                 | _                 | —                 | _                | _                |
| 15.0         | R-0, HSC          | R-0, HSC          | U-0               | U-0               | U-0               | R/C-0, HS         | R-0, HSC         | R-0, HSC         |
| 15:8         | ACKSTAT           | TRSTAT            | -                 | -                 | _                 | BCL               | GCSTAT           | ADD10            |
| 7:0          | R/C-0, HS         | R/C-0, HS         | R-0, HSC          | R/C-0, HSC        | R/C-0, HSC        | R-0, HSC          | R-0, HSC         | R-0, HSC         |
| 7:0          | IWCOL             | I2COV             | D_A               | Р                 | S                 | R_W               | RBF              | TBF              |

| Legend:           | HS = Set in hardware | HSC = Hardware set/cleared |                   |  |  |
|-------------------|----------------------|----------------------------|-------------------|--|--|
| 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       | C = Clearable bit |  |  |

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

bit 15 ACKSTAT: Acknowledge Status bit

(when operating as  $I^2C$  master, applicable to master transmit operation)

- 1 = Acknowledge was not received from slave
- 0 = Acknowledge was received from slave

Hardware set or clear at end of slave Acknowledge.

- bit 14 **TRSTAT:** Transmit Status bit (when operating as I<sup>2</sup>C master, applicable to master transmit operation)
  - 1 = Master transmit is in progress (8 bits + ACK)
  - 0 = Master transmit is not in progress

Hardware set at beginning of master transmission. Hardware clear at end of slave Acknowledge.

- bit 13-11 Unimplemented: Read as '0'
- bit 10 BCL: Master Bus Collision Detect bit

1 = A bus collision has been detected during a master operation

0 = No collision

Hardware set at detection of bus collision. This condition can only be cleared by disabling (ON bit = 0) and re-enabling (ON bit = 1) the module.

- bit 9 **GCSTAT:** General Call Status bit
  - 1 = General call address was received
  - 0 = General call address was not received

Hardware set when address matches general call address. Hardware clear at Stop detection.

bit 8 ADD10: 10-bit Address Status bit

1 = 10-bit address was matched

0 = 10-bit address was not matched

Hardware set at match of 2nd byte of matched 10-bit address. Hardware clear at Stop detection.

- bit 7 IWCOL: Write Collision Detect bit
  - 1 = An attempt to write the I2CxTRN register failed because the I<sup>2</sup>C module is busy
  - 0 = No collision

Hardware set at occurrence of write to I2CxTRN while busy (cleared by software).

bit 6 I2COV: Receive Overflow Flag bit

1 = A byte was received while the I2CxRCV register is still holding the previous byte 0 = No overflow

Hardware set at attempt to transfer I2CxRSR to I2CxRCV (cleared by software).

- bit 5 **D\_A:** Data/Address bit (when operating as I<sup>2</sup>C slave)
  - 1 = Indicates that the last byte received was data
  - 0 = Indicates that the last byte received was device address

Hardware clear at device address match. Hardware set by reception of slave byte.

NOTES:

# 23.0 10-BIT ANALOG-TO-DIGITAL CONVERTER (ADC)

Note: This data sheet summarizes the features of the PIC32MX330/350/370/430/450/470 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 17. "10-bit Analog-to-Digital Converter (ADC)" (DS60001104), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32). The 10-bit Analog-to-Digital Converter (ADC) includes the following features:

- Successive Approximation Register (SAR) conversion
- Up to 1 Msps conversion speed
- · Up to 28 analog input pins
- External voltage reference input pins
- One unipolar, differential Sample and Hold Amplifier (SHA)
- Automatic Channel Scan mode
- · Selectable conversion trigger source
- · 16-word conversion result buffer
- · Selectable buffer fill modes
- · Eight conversion result format options
- · Operation during CPU Sleep and Idle modes

A block diagram of the 10-bit ADC is illustrated in Figure 23-1. The 10-bit ADC has up to 28 analog input pins, designated AN0-AN27. In addition, there are two analog input pins for external voltage reference connections. These voltage reference inputs may be shared with other analog input pins and may be common to other analog module references.



4: This selection is only used with CTMU capacitive and time measurement.

# TABLE 23-1: ADC REGISTER MAP (CONTINUED)

| ess                         |          | 0                                          |       |                                    |       |       |       |       |         | В          | its      |          |      |      |      |      |      |      | ŝ          |
|-----------------------------|----------|--------------------------------------------|-------|------------------------------------|-------|-------|-------|-------|---------|------------|----------|----------|------|------|------|------|------|------|------------|
| Virtual Address<br>(BF80_#) |          | 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 |
| 9110                        | ADC1BUFA | DC1BUFA ADC Result Word A (ADC1BUFA<31:0>) |       |                                    |       |       |       |       |         |            |          | 0000     |      |      |      |      |      |      |            |
| 9120                        | ADC1BUFB | 31:16<br>15:0                              |       | ADC Result Word B (ADC1BUFB<31:0>) |       |       |       |       |         |            |          |          | 0000 |      |      |      |      |      |            |
| 9130                        | ADC1BUFC | 31:16<br>15:0                              |       |                                    |       |       |       |       | ADC Res | ult Word C | (ADC1BUF | C<31:0>) |      |      |      |      |      |      | 0000       |
| 9140                        | ADC1BUFD | 31:16<br>15:0                              |       |                                    |       |       |       |       | ADC Res | ult Word D | (ADC1BUF | D<31:0>) |      |      |      |      |      |      | 0000       |
| 9150                        | ADC1BUFE | 31:16<br>15:0                              |       | ADC Result Word E (ADC1BUFE<31:0>) |       |       |       |       |         |            |          | 0000     |      |      |      |      |      |      |            |
| 9160                        | ADC1BUFF | 31:16<br>15:0                              |       |                                    |       |       |       |       | ADC Res | ult Word F | (ADC1BUF | F<31:0>) |      |      |      |      |      |      | 0000       |

PIC32MX330/350/370/430/450/470

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

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

#### REGISTER 26-1: CTMUCON: CTMU CONTROL REGISTER (CONTINUED)

- bit 10 EDGSEQEN: Edge Sequence Enable bit 1 = Edge 1 must occur before Edge 2 can occur 0 = No edge sequence is needed bit 9 **IDISSEN:** Analog Current Source Control bit<sup>(2)</sup> 1 = Analog current source output is grounded 0 = Analog current source output is not grounded CTTRIG: Trigger Control bit bit 8 1 = Trigger output is enabled 0 = Trigger output is disabled bit 7-2 ITRIM<5:0>: Current Source Trim bits 011111 = Maximum positive change from nominal current 011110 000001 = Minimum positive change from nominal current 000000 = Nominal current output specified by IRNG<1:0> 1111111 = Minimum negative change from nominal current 100010 100001 = Maximum negative change from nominal current IRNG<1:0>: Current Range Select bits<sup>(3)</sup> bit 1-0 11 = 100 times base current 10 = 10 times base current 01 = Base current level 00 = 1000 times base current<sup>(4)</sup>
- Note 1: When this bit is set for Pulse Delay Generation, the EDG2SEL<3:0> bits must be set to '1110' to select C2OUT.
  - 2: The ADC module Sample and Hold capacitor is not automatically discharged between sample/conversion cycles. Software using the ADC as part of a capacitive measurement, must discharge the ADC capacitor before conducting the measurement. The IDISSEN bit, when set to '1', performs this function. The ADC module must be sampling while the IDISSEN bit is active to connect the discharge sink to the capacitor array.
  - 3: Refer to the CTMU Current Source Specifications (Table 31-42) in Section 31.0 "Electrical Characteristics" for current values.
  - 4: This bit setting is not available for the CTMU temperature diode.

# 27.4.1 CONTROLLING CONFIGURATION CHANGES

Because peripherals can be disabled during run time, some restrictions on disabling peripherals are needed to prevent accidental configuration changes. PIC32 devices include two features to prevent alterations to enabled or disabled peripherals:

- Control register lock sequence
- · Configuration bit select lock

# 27.4.1.1 Control Register Lock

Under normal operation, writes to the PMDx registers are not allowed. Attempted writes appear to execute normally, but the contents of the registers remain unchanged. To change these registers, they must be unlocked in hardware. The register lock is controlled by the PMDLOCK Configuration bit (CFGCON<12>). Setting PMDLOCK prevents writes to the control registers; clearing PMDLOCK allows writes.

To set or clear PMDLOCK, an unlock sequence must be executed. Refer to **Section 6.** "Oscillator" (DS60001112) in the "*PIC32 Family Reference Manual*" for details.

# 27.4.1.2 Configuration Bit Select Lock

As an additional level of safety, the device can be configured to prevent more than one write session to the PMDx registers. The PMDL1WAY Configuration bit (DEVCFG3<28>) blocks the PMDLOCK bit from being cleared after it has been set once. If PMDLOCK remains set, the register unlock procedure does not execute, and the peripheral pin select control registers cannot be written to. The only way to clear the bit and re-enable PMD functionality is to perform a device Reset.

| 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-1               | r-1               | r-1               | r-1               | r-1                        | r-1               | R/P              | R/P              |  |
| 31:24        |                   | _                 | _                 | -                 | —                          | _                 | FWDTWI           | NSZ<1:0>         |  |
| 00.40        | R/P               | R/P               | r-1               | R/P               | R/P                        | R/P               | R/P              | R/P              |  |
| 23:16        | FWDTEN            | WINDIS            |                   |                   | WDTPS<4:0>                 |                   |                  |                  |  |
| 45.0         | R/P               | R/P               | R/P               | R/P               | r-1                        | R/P               | R/P              | R/P              |  |
| 15:8         | FCKSM             | 1<1:0>            | FPBDI             | V<1:0>            | <1:0> — OSCIOFNC POSCMOD<1 |                   |                  |                  |  |
| 7.0          | R/P               | r-1               | R/P               | r-1               | r-1                        | R/P               | R/P              | R/P              |  |
| 7:0          | IESO — FSOSCEN    |                   |                   | _                 | — FNOSC<2:0>               |                   |                  |                  |  |

# REGISTER 28-2: DEVCFG1: DEVICE CONFIGURATION WORD 1

| Legend:           | r = Reserved bit | P = Programmable bit     |                    |  |
|-------------------|------------------|--------------------------|--------------------|--|
| 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-26 Reserved: Write '1'

bit 25-24 FWDTWINSZ<1:0>: Watchdog Timer Window Size bits

- 11 = Window size is 25%
- 10 = Window size is 37.5%
- 01 = Window size is 50%
- 00 = Window size is 75%

# bit 23 FWDTEN: Watchdog Timer Enable bit

- 1 = Watchdog Timer is enabled and cannot be disabled by software
- 0 = Watchdog Timer is not enabled; it can be enabled in software

# bit 22 WINDIS: Watchdog Timer Window Enable bit

- 1 = Watchdog Timer is in non-Window mode
- 0 = Watchdog Timer is in Window mode

#### bit 21 Reserved: Write '1'

#### bit 20-16 WDTPS<4:0>: Watchdog Timer Postscale Select bits

| 10100 <b>= 1:1048576</b>                                     |
|--------------------------------------------------------------|
| 10011 <b>= 1:524288</b>                                      |
| 10010 <b>= 1:262144</b>                                      |
| 10001 = 1:131072                                             |
| 10000 <b>= 1:65536</b>                                       |
| 01111 <b>= 1:32768</b>                                       |
| 01110 <b>= 1:16384</b>                                       |
| 01101 <b>= 1:8192</b>                                        |
| 01100 <b>= 1:4096</b>                                        |
| 01011 <b>= 1:2048</b>                                        |
| 01010 <b>= 1:1024</b>                                        |
| 01001 <b>= 1:512</b>                                         |
| 01000 <b>= 1:256</b>                                         |
| 00111 <b>= 1:128</b>                                         |
| 00110 = 1:64                                                 |
| 00101 <b>= 1:32</b>                                          |
| 00100 <b>= 1:16</b>                                          |
| 00011 = 1:8                                                  |
| 00010 <b>= 1</b> :4                                          |
| 00001 <b>= 1:2</b>                                           |
| 00000 = 1:1                                                  |
| All other combinations not shown result in operation = 10100 |
| ···· · ··· · ··· · ··· · ··· · ···                           |

**Note 1:** Do not disable the Posc (POSCMOD = 11) when using this oscillator source.

# 29.0 INSTRUCTION SET

The PIC32MX330/350/370/430/450/470 family instruction set complies with the MIPS32<sup>®</sup> Release 2 instruction set architecture. The PIC32 device family does not support the following features:

- · Core extend instructions
- Coprocessor 1 instructions
- Coprocessor 2 instructions

Note: Refer to "MIPS32<sup>®</sup> Architecture for Programmers Volume II: The MIPS32<sup>®</sup> Instruction Set" at www.imgtec.com for more information.

| AC CHARACTERISTICS |           | $\begin{array}{llllllllllllllllllllllllllllllllllll$                    |         |                        |         |       |                                                           |
|--------------------|-----------|-------------------------------------------------------------------------|---------|------------------------|---------|-------|-----------------------------------------------------------|
| Param.<br>No.      | Symbol    | Characteristics                                                         | Min.    | Typical <sup>(1)</sup> | Max.    | Units | Conditions                                                |
| Clock P            | arameter  | S                                                                       |         |                        |         |       |                                                           |
| AD50               | TAD       | ADC Clock Period <sup>(2)</sup>                                         | 65      |                        |         | ns    | See Table 31-36                                           |
| Conver             | sion Rate | •                                                                       |         |                        |         |       |                                                           |
| AD55               | TCONV     | Conversion Time                                                         | _       | 12 Tad                 | _       | _     | —                                                         |
| AD56               | FCNV      | Throughput Rate                                                         | _       | _                      | 1000    | ksps  | AVDD = 3.0V to 3.6V                                       |
|                    |           | (Sampling Speed) <sup>(4)</sup>                                         | _       | —                      | 400     | ksps  | AVDD = 2.5V to 3.6V                                       |
| AD57               | TSAMP     | Sample Time                                                             | 2 Tad   | _                      | —       | _     | —                                                         |
| 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<br>from ADC Off to ADC On <sup>(3)</sup> | _       | _                      | 2       | μS    | _                                                         |

# TABLE 31-37: 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: Refer to Table 31-36 for detailed conditions.

| AC CHARACTERISTICS |         |                                   | $\label{eq:conditions: 2.3V to 3.6V} \begin{array}{ c c c c c } \hline Standard Operating Conditions: 2.3V to 3.6V \\ \hline (unless otherwise stated) \\ \hline Operating temperature & 0^{\circ}C \leq TA \leq +70^{\circ}C \text{ for Commercial} \\ -40^{\circ}C \leq TA \leq +85^{\circ}C \text{ for Industrial} \\ -40^{\circ}C \leq TA \leq +105^{\circ}C \text{ for V-temp} \end{array}$ |      |      |       |                                                                                   |
|--------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|-----------------------------------------------------------------------------------|
| Param.<br>No.      | Symbol  | Characteristics <sup>(1)</sup>    | Min.                                                                                                                                                                                                                                                                                                                                                                                             | Тур. | Max. | Units | Conditions                                                                        |
| USB313             | VUSB3V3 | USB Voltage                       | 3.0                                                                                                                                                                                                                                                                                                                                                                                              |      | 3.6  | V     | Voltage on VUSB3V3<br>must be in this range<br>for proper USB<br>operation        |
| USB315             | VILUSB  | Input Low Voltage for USB Buffer  | —                                                                                                                                                                                                                                                                                                                                                                                                | _    | 0.8  | V     | —                                                                                 |
| USB316             | VIHUSB  | Input High Voltage for USB Buffer | 2.0                                                                                                                                                                                                                                                                                                                                                                                              | —    | _    | V     | —                                                                                 |
| USB318             | VDIFS   | Differential Input Sensitivity    | —                                                                                                                                                                                                                                                                                                                                                                                                |      | 0.2  | V     | The difference<br>between D+ and D-<br>must exceed this value<br>while VCM is met |
| USB319             | VCM     | Differential Common Mode Range    | 0.8                                                                                                                                                                                                                                                                                                                                                                                              | _    | 2.5  | V     | —                                                                                 |
| USB320             | Zout    | Driver Output Impedance           | 28.0                                                                                                                                                                                                                                                                                                                                                                                             | —    | 44.0 | Ω     | —                                                                                 |
| USB321             | Vol     | Voltage Output Low                | 0.0                                                                                                                                                                                                                                                                                                                                                                                              | _    | 0.3  | V     | 1.425 kΩ load<br>connected to VUSB3V3                                             |
| USB322             | Vон     | Voltage Output High               | 2.8                                                                                                                                                                                                                                                                                                                                                                                              | —    | 3.6  | V     | 14.25 k $\Omega$ load connected to ground                                         |

# TABLE 31-41: OTG ELECTRICAL SPECIFICATIONS

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

# 64-Terminal Plastic Quad Flat Pack, No Lead (RG) 9x9x0.9 mm Body [QFN] Saw Singulated

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



Microchip Technology Drawing C04-260A Sheet 1 of 2

# PIC32MX330/350/370/430/450/470

| NVMDATA (Flash Program Data)57                      |
|-----------------------------------------------------|
| NVMKEY (Programming Unlock)56                       |
| NVMSRCADDR (Source Data Address)57                  |
| OCxCON (Output Compare x Control) 187               |
| OSCCON (Oscillator Control)76                       |
| PFABT (Prefetch Cache Abort Statistics)             |
| PMADDR (Parallel Port Address)                      |
| PMAEN (Parallel Port Pin Enable)                    |
| PMCON (Parallel Port Control)                       |
| PMMODE (Parallel Port Mode)                         |
| PMSTAT (Parallel Port Status (Slave Modes Only) 221 |
| REFOCON (Reference Oscillator Control)              |
| REFOTRIM (Reference Oscillator Trim)                |
| RPnR (Peripheral Pin Select Output)                 |
| RSWRST (Software Reset)                             |
| RTCCON (RTC Control)                                |
| RTCDATE (RTC Date Value)                            |
| RTCTIME (RTC Time Value)                            |
| SPIxCON (SPI Control)                               |
|                                                     |
| SPIxCON2 (SPI Control 2)                            |
| SPIxSTAT (SPI Status)                               |
| T1CON (Type A Timer Control)                        |
| TxCON (Type B Timer Control) 174                    |
| U1ADDR (USB Address)                                |
| U1BDTP1 (USB BDT Page 1) 133                        |
| U1BDTP2 (USB BDT Page 2)134                         |
| U1BDTP3 (USB BDT Page 3)134                         |
| U1CNFG1 (USB Configuration 1) 135                   |
| U1CON (USB Control)129                              |
| U1EIE (USB Error Interrupt Enable) 127              |
| U1EIR (USB Error Interrupt Status) 125              |
| U1EP0-U1EP15 (USB Endpoint Control) 136             |
| U1FRMH (USB Frame Number High) 132                  |
| U1FRML (USB Frame Number Low)                       |
| U1IE (USB Interrupt Enable)                         |
| U1IR (USB Interrupt)                                |
| U1OTGCON (USB OTG Control) 121                      |
| U1OTGIE (USB OTG Interrupt Enable)                  |
| U1OTGIR (USB OTG Interrupt Status)                  |
| U1OTGSTAT (USB OTG Status)                          |
| U1PWRC (USB Power Control)                          |
| U1SOF (USB SOF Threshold)                           |
| U1STAT (USB Status)                                 |
| U1TOK (USB Token)                                   |
| WDTCON (Watchdog Timer Control)                     |
| Resets                                              |
| Revision History                                    |
| RTCALRM (RTC ALARM Control)                         |
|                                                     |
| S                                                   |

| Serial Peripheral Interface (SPI) | 189 |
|-----------------------------------|-----|
| Software Simulator (MPLAB SIM)    | 277 |
| Special Features                  | 261 |

### т

| 1                                              |  |  |  |  |  |  |
|------------------------------------------------|--|--|--|--|--|--|
| Timer1 Module                                  |  |  |  |  |  |  |
| Timer2/3, Timer4/5 Modules                     |  |  |  |  |  |  |
| Timing Diagrams                                |  |  |  |  |  |  |
| 10-Bit Analog-to-Digital Conversion            |  |  |  |  |  |  |
| (ASAM = 0, SSRC<2:0> = 000)                    |  |  |  |  |  |  |
| 10-Bit Analog-to-Digital Conversion (ASAM = 1, |  |  |  |  |  |  |
| SSRC<2:0> = 111, SAMC<4:0> = 00001) 321        |  |  |  |  |  |  |
| EJTAG                                          |  |  |  |  |  |  |
| External Clock                                 |  |  |  |  |  |  |
| I/O Characteristics                            |  |  |  |  |  |  |
|                                                |  |  |  |  |  |  |
| I2Cx Bus Data (Master Mode)                    |  |  |  |  |  |  |
| I2Cx Bus Data (Slave Mode)                     |  |  |  |  |  |  |
| I2Cx Bus Start/Stop Bits (Master Mode) 310     |  |  |  |  |  |  |
| I2Cx Bus Start/Stop Bits (Slave Mode) 313      |  |  |  |  |  |  |
| Input Capture (CAPx) 302                       |  |  |  |  |  |  |
| OCx/PWM                                        |  |  |  |  |  |  |
| Output Compare (OCx) 303                       |  |  |  |  |  |  |
| Parallel Master Port Read 323                  |  |  |  |  |  |  |
| Parallel Master Port Write 324                 |  |  |  |  |  |  |
| Parallel Slave Port 322                        |  |  |  |  |  |  |
| SPIx Master Mode (CKE = 0)                     |  |  |  |  |  |  |
| SPIx Master Mode (CKE = 1)                     |  |  |  |  |  |  |
| SPIx Slave Mode (CKE = 0)                      |  |  |  |  |  |  |
| SPIx Slave Mode (CKE = 1)                      |  |  |  |  |  |  |
| Timer1, 2, 3, 4, 5 External Clock              |  |  |  |  |  |  |
| UART Reception                                 |  |  |  |  |  |  |
| UART Transmission (8-bit or 9-bit Data)        |  |  |  |  |  |  |
| Timing Requirements                            |  |  |  |  |  |  |
| CLKO and I/O                                   |  |  |  |  |  |  |
|                                                |  |  |  |  |  |  |
| Timing Specifications                          |  |  |  |  |  |  |
| I2Cx Bus Data Requirements (Master Mode)       |  |  |  |  |  |  |
| I2Cx Bus Data Requirements (Slave Mode)        |  |  |  |  |  |  |
| Input Capture Requirements                     |  |  |  |  |  |  |
| Output Compare Requirements                    |  |  |  |  |  |  |
| Simple OCx/PWM Mode Requirements 303           |  |  |  |  |  |  |
| SPIx Master Mode (CKE = 0) Requirements        |  |  |  |  |  |  |
| SPIx Master Mode (CKE = 1) Requirements        |  |  |  |  |  |  |
| SPIx Slave Mode (CKE = 1) Requirements         |  |  |  |  |  |  |
| SPIx Slave Mode Requirements (CKE = 0)         |  |  |  |  |  |  |
|                                                |  |  |  |  |  |  |
| U                                              |  |  |  |  |  |  |
| UART                                           |  |  |  |  |  |  |
| USB On-The-Go (OTG) 113                        |  |  |  |  |  |  |
|                                                |  |  |  |  |  |  |
| V                                              |  |  |  |  |  |  |

| -                           |     |
|-----------------------------|-----|
| VCAP pin                    | 272 |
| Voltage Regulator (On-Chip) | 272 |
| W                           |     |
| WWW Address                 | 359 |

WWW, On-Line Support ..... 14

#### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELoQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, AnyRate, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KeeLoq, KeeLoq logo, Kleer, LANCheck, LINK MD, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC32 logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

ClockWorks, The Embedded Control Solutions Company, ETHERSYNCH, Hyper Speed Control, HyperLight Load, IntelliMOS, mTouch, Precision Edge, and QUIET-WIRE are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PureSilicon, RightTouch logo, REAL ICE, Ripple Blocker, Serial Quad I/O, SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

 $\ensuremath{\mathsf{SQTP}}$  is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademarks of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2012-2016, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-5224-0959-5