

Welcome to E-XFL.COM

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

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

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

#### Details

E·XFl

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

Email: info@E-XFL.COM

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

# TO OUR VALUED CUSTOMERS

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

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com**. We welcome your feedback.

#### Most Current Data Sheet

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

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

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

#### Errata

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

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

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

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

#### **Customer Notification System**

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

# PIC32MX1XX/2XX 28/36/44-PIN FAMILY

| TABLE 1-1 | : PING            | DUT I/O D                         |                     | IONS (CO                        | NTINU       | ED)                  | 1                                                 |
|-----------|-------------------|-----------------------------------|---------------------|---------------------------------|-------------|----------------------|---------------------------------------------------|
|           |                   | Pin Nu                            | mber <sup>(1)</sup> |                                 |             |                      |                                                   |
| Pin Name  | 28-pin<br>QFN     | 28-pin<br>SSOP/<br>SPDIP/<br>SOIC | 36-pin<br>VTLA      | 44-pin<br>QFN/<br>TQFP/<br>VTLA | Pin<br>Type | Buffer<br>Type       | Description                                       |
| SDA1      | 15                | 18                                | 19                  | 1                               | I/O         | ST                   | Synchronous serial data input/output for I2C1     |
| SCL2      | 4                 | 7                                 | 2                   | 24                              | I/O         | ST                   | Synchronous serial clock input/output for<br>I2C2 |
| SDA2      | 3                 | 6                                 | 1                   | 23                              | I/O         | ST                   | Synchronous serial data input/output for I2C2     |
| TMS       | 19 <b>(2)</b>     | 22 <sup>(2)</sup>                 | 25 <sup>(2)</sup>   | 12                              | 1           | ST                   | JTAG Test mode select pin                         |
| _         | 11 <sup>(3)</sup> | 14 <sup>(3)</sup>                 | 15 <b>(3)</b>       | 12                              | 1           | _                    | STAG Test mode select pin                         |
| TCK       | 14                | 17                                | 18                  | 13                              | I           | ST                   | JTAG test clock input pin                         |
| TDI       | 13                | 16                                | 17                  | 35                              | 0           | —                    | JTAG test data input pin                          |
| TDO       | 15                | 18                                | 19                  | 32                              | 0           | —                    | JTAG test data output pin                         |
| RTCC      | 4                 | 7                                 | 2                   | 24                              | 0           | ST                   | Real-Time Clock alarm output                      |
| CVREF-    | 28                | 3                                 | 34                  | 20                              | Ι           | Analog               | Comparator Voltage Reference (low)                |
| CVREF+    | 27                | 2                                 | 33                  | 19                              | I           | Analog               | Comparator Voltage Reference (high)               |
| CVREFOUT  | 22                | 25                                | 28                  | 14                              | 0           | Analog               | Comparator Voltage Reference output               |
| C1INA     | 4                 | 7                                 | 2                   | 24                              | I           | Analog               | Comparator Inputs                                 |
| C1INB     | 3                 | 6                                 | 1                   | 23                              | I           | Analog               |                                                   |
| C1INC     | 2                 | 5                                 | 36                  | 22                              | I           | Analog               |                                                   |
| C1IND     | 1                 | 4                                 | 35                  | 21                              | I           | Analog               |                                                   |
| C2INA     | 2                 | 5                                 | 36                  | 22                              | 1           | Analog               | 7                                                 |
| C2INB     | 1                 | 4                                 | 35                  | 21                              | I           | Analog               |                                                   |
| C2INC     | 4                 | 7                                 | 2                   | 24                              | I           | Analog               |                                                   |
| C2IND     | 3                 | 6                                 | 1                   | 23                              | I           | Analog               |                                                   |
| C3INA     | 23                | 26                                | 29                  | 15                              | I           | Analog               |                                                   |
| C3INB     | 22                | 25                                | 28                  | 14                              | I           | Analog               | 1                                                 |
| C3INC     | 27                | 2                                 | 33                  | 19                              | I           | Analog               | 1                                                 |
| C3IND     | 1                 | 4                                 | 35                  | 21                              | I           | Analog               | 1                                                 |
| C1OUT     | PPS               | PPS                               | PPS                 | PPS                             | 0           | —                    | Comparator Outputs                                |
| C2OUT     | PPS               | PPS                               | PPS                 | PPS                             | 0           | —                    | 1                                                 |
| C3OUT     | PPS               | PPS                               | PPS                 | PPS                             | 0           | —                    | 1                                                 |
|           |                   | MOS compa<br>itt Trigger in       |                     |                                 | •           | Analog =<br>O = Outp | Analog input P = Power<br>but I = Input           |

#### DINOUT 1/0 DECODIDITIONS (CONTINUED)

TTL = TTL input buffer PPS = Peripheral Pin Select Note 1: Pin numbers are provided for reference only. See the "Pin Diagrams" section for device pin availability.

2: Pin number for PIC32MX1XX devices only.

3: Pin number for PIC32MX2XX devices only.

— = N/A

# 4.0 MEMORY ORGANIZATION

Note: This data sheet summarizes the features of the PIC32MX1XX/2XX 28/36/44-pin Family of devices. It is not intended to be a comprehensive reference source.For detailed information, refer to **Section 3.** "Memory Organization" (DS60001115), which is available from the *Documentation* > *Reference Manual* section of the Microchip PIC32 web site (www.microchip.com/pic32).

PIC32MX1XX/2XX 28/36/44-pin Family microcontrollers provide 4 GB unified virtual memory address space. All memory regions, including program, data memory, Special Function Registers (SFRs), and Configuration registers, reside in this address space at their respective unique addresses. The program and data memories can be optionally partitioned into user and kernel memories. In addition, the data memory can be made executable, allowing PIC32MX1XX/2XX 28/36/44-pin Family devices to execute from data memory.

Key features include:

- 32-bit native data width
- Separate User (KUSEG) and Kernel (KSEG0/KSEG1) mode address space
- · Flexible program Flash memory partitioning
- Flexible data RAM partitioning for data and program space
- Separate boot Flash memory for protected code
- Robust bus exception handling to intercept runaway code
- Simple memory mapping with Fixed Mapping Translation (FMT) unit
- Cacheable (KSEG0) and non-cacheable (KSEG1) address regions

# 4.1 PIC32MX1XX/2XX 28/36/44-pin Family Memory Layout

PIC32MX1XX/2XX 28/36/44-pin Family microcontrollers implement two address schemes: virtual and physical. All hardware resources, such as program memory, data memory and peripherals, are located at their respective physical addresses. Virtual addresses are exclusively used by the CPU to fetch and execute instructions as well as access peripherals. Physical addresses are used by bus master peripherals, such as DMA and the Flash controller, that access memory independently of the CPU.

The memory maps for the PIC32MX1XX/2XX 28/36/44-pin Family devices are illustrated in Figure 4-1 through Figure 4-6.

Table 4-1 provides SFR memory map details.

# 6.1 Reset Control Registers

# TABLE 6-1: RESET CONTROL REGISTER MAP

| ess                         |                                 | 0         | Bits  |       |       |       |       |       |      |       |      |      |      |      | s     |      |      |       |           |
|-----------------------------|---------------------------------|-----------|-------|-------|-------|-------|-------|-------|------|-------|------|------|------|------|-------|------|------|-------|-----------|
| Virtual Address<br>(BF80_#) | Register<br>Name <sup>(1)</sup> | Bit Range | 31/15 | 30/14 | 29/13 | 28/12 | 27/11 | 26/10 | 25/9 | 24/8  | 23/7 | 22/6 | 21/5 | 20/4 | 19/3  | 18/2 | 17/1 | 16/0  | All Reset |
| F600                        | RCON                            | 31:16     | _     | _     | _     |       | —     | _     |      | —     | _    | _    |      | _    |       | -    | -    | _     | 0000      |
| 1 000                       | ROOM                            | 15:0      | _     |       | -     |       | _     | -     | CMR  | VREGS | EXTR | SWR  |      | WDTO | SLEEP | IDLE | BOR  | POR   | xxxx(2)   |
| E610                        | RSWRST                          | 31:16     |       | —     | -     | —     | —     | —     | —    | —     |      | —    | —    | _    | —     | _    | —    | —     | 0000      |
| 1010                        | N31/K31                         | 15:0      | _     | _     | _     | -     | _     | _     |      | —     | _    | _    | -    | _    | _     | _    | -    | SWRST | 0000      |

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

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

2: Reset values are dependent on the DEVCFGx Configuration bits and the type of reset.

# 7.0 INTERRUPT CONTROLLER

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

PIC32MX1XX/2XX 28/36/44-pin Family devices generate interrupt requests in response to interrupt events from peripheral modules. The interrupt control module exists externally to the CPU logic and prioritizes the interrupt events before presenting them to the CPU.

The PIC32MX1XX/2XX 28/36/44-pin Family interrupt module includes the following features:

- Up to 64 interrupt sources
- · Up to 44 interrupt vectors
- · Single and multi-vector mode operations
- Five external interrupts with edge polarity control
- Interrupt proximity timer
- Seven user-selectable priority levels for each vector
- Four user-selectable subpriority levels within each priority
- · Software can generate any interrupt
- User-configurable Interrupt Vector Table (IVT) location
- User-configurable interrupt vector spacing

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



### FIGURE 7-1: INTERRUPT CONTROLLER MODULE BLOCK DIAGRAM

Note: The dedicated shadow register set is not present on PIC32MX1XX/2XX 28/36/44-pin Family devices.

| Bit<br>Range | Bit<br>31/23/15/7 | Bit         Bit         Bit         Bit           30/22/14/6         29/21/13/5         28/20/12/4         27/19/11/3         26/18/10/2 |     |       |           | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |       |
|--------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|-----------|------------------|------------------|-------|
| 24.24        | U-0               | U-0                                                                                                                                      | U-0 | R/W-0 | R/W-0     | R/W-0            | R/W-0            | R/W-0 |
| 31:24        | —                 | —                                                                                                                                        | —   |       |           | IS03             | <1:0>            |       |
| 23:16        | U-0               | U-0                                                                                                                                      | U-0 | R/W-0 | R/W-0     | R/W-0            | R/W-0            | R/W-0 |
| 23.10        | _                 | —                                                                                                                                        |     |       | IP02<2:0> |                  | IS02             | <1:0> |
| 15:8         | U-0               | U-0                                                                                                                                      | U-0 | R/W-0 | R/W-0     | R/W-0            | R/W-0            | R/W-0 |
| 15.0         | _                 | —                                                                                                                                        |     |       | IP01<2:0> |                  | IS01·            | <1:0> |
| 7:0          | U-0               | U-0                                                                                                                                      | U-0 | R/W-0 | R/W-0     | R/W-0            | R/W-0            | R/W-0 |
| 7.0          | _                 | _                                                                                                                                        | _   |       | IP00<2:0> |                  | IS00·            | <1:0> |

#### REGISTER 7-6: IPCx: INTERRUPT PRIORITY CONTROL REGISTER

#### Legend:

| Logonal           |                  |                           |                    |
|-------------------|------------------|---------------------------|--------------------|
| 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-29 Unimplemented: Read as '0'
- bit 28-26 IP03<2:0>: Interrupt Priority bits
- 111 = Interrupt priority is 7 010 = Interrupt priority is 2 001 = Interrupt priority is 1 000 = Interrupt is disabled bit 25-24 IS03<1:0>: Interrupt Subpriority bits 11 = Interrupt subpriority is 3 10 = Interrupt subpriority is 2 01 = Interrupt subpriority is 1 00 = Interrupt subpriority is 0 bit 23-21 Unimplemented: Read as '0' bit 20-18 IP02<2:0>: Interrupt Priority bits 111 = Interrupt priority is 7 010 = Interrupt priority is 2 001 = Interrupt priority is 1 000 = Interrupt is disabled bit 17-16 IS02<1:0>: Interrupt Subpriority bits 11 = Interrupt subpriority is 3 10 = Interrupt subpriority is 2 01 = Interrupt subpriority is 1 00 = Interrupt subpriority is 0 bit 15-13 Unimplemented: Read as '0' bit 12-10 IP01<2:0>: Interrupt Priority bits 111 = Interrupt priority is 7 010 = Interrupt priority is 2 001 = Interrupt priority is 1
  - 000 = Interrupt is disabled
- **Note:** This register represents a generic definition of the IPCx register. Refer to Table 7-1 for the exact bit definitions.

# PIC32MX1XX/2XX 28/36/44-PIN FAMILY

| 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        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 31:24        | _                 | —                 | _                 | -                 | _                 | _                 | _                | —                |
| 23:16        | U-0               | U-0               | U-0               | U-0               | U-0               | U-0               | U-0              | U-0              |
| 23.10        | —                 | —                 | _                 | -                 | _                 | _                 | -                | —                |
| 45.0         | 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          |                   |                   |                   | CHPDAT            | [<7:0>            |                   |                  |                  |

# REGISTER 9-18: DCHxDAT: DMA CHANNEL 'x' PATTERN DATA REGISTER

# Legend:

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

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

### bit 7-0 CHPDAT<7:0>: Channel Data Register bits

Pattern Terminate mode: Data to be matched must be stored in this register to allow a "terminate on match".

All other modes: Unused.

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

## **REGISTER 11-3:** CNCONX: CHANGE NOTICE CONTROL FOR PORTX REGISTER (X = A, B, C)

#### Legend:

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

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

- bit 15 **ON:** Change Notice (CN) Control ON bit
  - 1 = CN is enabled
  - 0 = CN is disabled
- bit 14 Unimplemented: Read as '0'
- bit 13 **SIDL:** Stop in Idle Control bit
  - 1 = Idle mode halts CN operation
  - 0 = Idle does not affect CN operation
- bit 12-0 Unimplemented: Read as '0'

NOTES:

#### 15.1 **Input Capture Control Registers**

|                             | LE 15-1:              | IN            | PUT C | APTURE | E 1-INPU | JT CAPI | TURE 5 | REGIST | rer Mai | 2      |        |      |      |      |       |      |          |
|-----------------------------|-----------------------|---------------|-------|--------|----------|---------|--------|--------|---------|--------|--------|------|------|------|-------|------|----------|
| ess                         |                       |               |       |        |          |         |        |        |         | Bi     | ts     |      |      |      |       |      |          |
| Virtual Address<br>(BF80_#) | Register<br>Name      | Bit Range     | 31/15 | 30/14  | 29/13    | 28/12   | 27/11  | 26/10  | 25/9    | 24/8   | 23/7   | 22/6 | 21/5 | 20/4 | 19/3  | 18/2 | 17/1     |
|                             | IC1CON <sup>(1)</sup> | 31:16         |       | _      | —        | —       | —      | —      | _       | —      | —      | —    |      | —    | —     | —    | —        |
| 2000                        | 101001                | 15:0          | ON    | —      | SIDL     | —       | —      | —      | FEDGE   | C32    | ICTMR  | ICI< | 1:0> | ICOV | ICBNE |      | ICM<2:0> |
| 2010                        | IC1BUF                | 31:16<br>15:0 |       |        |          |         |        |        |         | IC1BUF | <31:0> |      |      |      |       |      |          |
| 2200                        | IC2CON <sup>(1)</sup> | 31:16         |       | —      | —        | —       | —      | —      | —       | —      | _      | —    | _    | —    | _     | —    | —        |
| 2200                        | 1020011               | 15:0          | ON    | —      | SIDL     | —       |        | —      | FEDGE   | C32    | ICTMR  | ICI< | 1:0> | ICOV | ICBNE |      | ICM<2:0> |
| 2210                        | IC2BUF                | 31:16<br>15:0 |       |        |          |         |        |        |         | IC2BUF | <31:0> |      |      |      |       |      |          |
| 2400                        | IC3CON <sup>(1)</sup> | 31:16         | -     | _      | _        | _       | -      | _      | —       | _      | —      | -    | _    | —    | _     | _    | —        |
| 2400                        | 1030011               | 15:0          | ON    | —      | SIDL     | —       |        | —      | FEDGE   | C32    | ICTMR  | ICI< | 1:0> | ICOV | ICBNE |      | ICM<2:0> |
| 2410                        | IC3BUF                | 31:16<br>15:0 |       |        |          |         |        |        |         | IC3BUF | <31:0> |      |      |      |       |      |          |
| 2600                        | IC4CON <sup>(1)</sup> | 31:16         | -     | _      | —        | _       | -      | _      | —       | —      | —      | _    | _    | —    | —     | _    | —        |
| 2000                        | 1040010               | 15:0          | ON    | —      | SIDL     | —       |        | —      | FEDGE   | C32    | ICTMR  | ICI< | 1:0> | ICOV | ICBNE |      | ICM<2:0> |
| 2610                        | IC4BUF                | 31:16<br>15:0 |       |        |          |         |        |        |         | IC4BUF | <31:0> |      |      |      |       |      |          |
| 2800                        | IC5CON <sup>(1)</sup> | 31:16         | -     | _      | —        | _       | -      | _      | —       | —      | —      | _    | _    | —    | _     | _    | —        |
| 2000                        | 1030014               | 15:0          | ON    | —      | SIDL     | —       | —      | —      | FEDGE   | C32    | ICTMR  | ICI< | 1:0> | ICOV | ICBNE |      | ICM<2:0> |
| 2810                        | IC5BUF                | 31:16<br>15:0 |       |        |          |         |        |        |         | IC5BUF | <31:0> |      |      |      |       |      |          |

#### Т

Legend:

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

All Resets

0000

0000 xxxx xxxx 0000 0000 xxxx xxxx 0000 0000 xxxx xxxx 0000 0000 xxxx xxxx 0000 0000 xxxx xxxx

16/0

—

# 17.0 SERIAL PERIPHERAL INTERFACE (SPI)

Note: This data sheet summarizes the features of the PIC32MX1XX/2XX 28/36/44-pin Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 23. "Serial Peripheral Interface (SPI)" (DS60001106), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32).

The SPI module is a synchronous serial interface that is useful for communicating with external peripherals and other microcontrollers. These peripheral devices may be Serial EEPROMs, Shift registers, display drivers, Analog-to-Digital Converters (ADC), etc. The PIC32 SPI module is compatible with Motorola<sup>®</sup> SPI and SIOP interfaces. Some of the key features of the SPI module are:

- Master mode and Slave mode support
- Four clock formats
- Enhanced Framed SPI protocol support
- User-configurable 8-bit, 16-bit and 32-bit data width
- Separate SPI FIFO buffers for receive and transmit
   FIFO buffers act as 4/8/16-level deep FIFOs based on 32/16/8-bit data width
- Programmable interrupt event on every 8-bit, 16-bit and 32-bit data transfer
- · Operation during Sleep and Idle modes
- Audio Codec Support:
  - I<sup>2</sup>S protocol
  - Left-justified
  - Right-justified
  - PCM



| REGISTE | R 18-1:           | I2CxCON: I <sup>2</sup> C CONTROL REGISTER (CONTINUED)                                                                                                                |
|---------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 7   | GCEN: Ge          | eneral Call Enable bit (when operating as I <sup>2</sup> C slave)                                                                                                     |
|         | (module           | interrupt when a general call address is received in the I2CxRSR<br>e is enabled for reception)                                                                       |
|         |                   | al call address is disabled                                                                                                                                           |
| bit 6   | STREN: S          | CLx Clock Stretch Enable bit (when operating as I <sup>2</sup> C slave)                                                                                               |
|         |                   | njunction with SCLREL bit.                                                                                                                                            |
|         |                   | e software or receive clock stretching                                                                                                                                |
| L:1 F   |                   | e software or receive clock stretching                                                                                                                                |
| bit 5   |                   | cknowledge Data bit (when operating as I <sup>2</sup> C master, applicable during master receive) is transmitted when the software initiates an Acknowledge sequence. |
|         |                   | a NACK during an Acknowledge sequence                                                                                                                                 |
|         |                   | an ACK during an Acknowledge sequence                                                                                                                                 |
| bit 4   | ACKEN: A receive) | cknowledge Sequence Enable bit (when operating as I <sup>2</sup> C master, applicable during master                                                                   |
|         | Hardwa            | Acknowledge sequence on SDAx and SCLx pins and transmit ACKDT data bit.<br>are clear at end of master Acknowledge sequence.<br>wledge sequence not in progress        |
| bit 3   | RCEN: Re          | ceive Enable bit (when operating as I <sup>2</sup> C master)                                                                                                          |
|         |                   | es Receive mode for I <sup>2</sup> C. Hardware clear at end of eighth bit of master receive data byte.<br>The sequence not in progress                                |
| bit 2   | PEN: Stop         | Condition Enable bit (when operating as I <sup>2</sup> C master)                                                                                                      |
|         |                   | Stop condition on SDAx and SCLx pins. Hardware clear at end of master Stop sequence. ondition not in progress                                                         |
| bit 1   | RSEN: Re          | peated Start Condition Enable bit (when operating as I <sup>2</sup> C master)                                                                                         |
|         |                   | Repeated Start condition on SDAx and SCLx pins. Hardware clear at end of Repeated Start sequence.                                                                     |
|         | 0 = Repeat        | ted Start condition not in progress                                                                                                                                   |
| bit 0   |                   | Condition Enable bit (when operating as I <sup>2</sup> C master)                                                                                                      |
|         |                   | Start condition on SDAx and SCLx pins. Hardware clear at end of master Start sequence. ondition not in progress                                                       |
|         |                   |                                                                                                                                                                       |

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

# PIC32MX1XX/2XX 28/36/44-PIN FAMILY

Figure 19-2 and Figure 19-3 illustrate typical receive and transmit timing for the UART module.







# 21.0 REAL-TIME CLOCK AND CALENDAR (RTCC)

Note: This data sheet summarizes the features of the PIC32MX1XX/2XX 28/36/44-pin Family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 29. "Real-Time Clock and Calendar (RTCC)" (DS60001125), which is available from the Documentation > Reference Manual section of the Microchip PIC32 web site (www.microchip.com/pic32).

The PIC32 RTCC module is intended for applications in which accurate time must be maintained for extended periods of time with minimal or no CPU intervention. Low-power optimization provides extended battery lifetime while keeping track of time. Following are some of the key features of this module:

- · Time: hours, minutes and seconds
- 24-hour format (military time)
- · Visibility of one-half second period
- · Provides calendar: day, date, month and year
- Alarm intervals are configurable for half of a second, one second, 10 seconds, one minute, 10 minutes, one hour, one day, one week, one month and one year
- · Alarm repeat with decrementing counter
- · Alarm with indefinite repeat: Chime
- Year range: 2000 to 2099
- Leap vear correction
- · BCD format for smaller firmware overhead
- Optimized for long-term battery operation
- Fractional second synchronization
- User calibration of the clock crystal frequency with auto-adjust
- Calibration range: ±0.66 seconds error per month
- · Calibrates up to 260 ppm of crystal error
- Requirements: External 32.768 kHz clock crystal
- Alarm pulse or seconds clock output on RTCC pin



| Bit<br>Range | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1    | Bit<br>24/16/8/0    |
|--------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|---------------------|---------------------|
| 21.24        | U-0                 | U-0                 |
| 31:24        |                   | -                 | _                 | -                 | _                 |                   | _                   | _                   |
| 00.40        | U-0                 | U-0                 |
| 23:16        | _                 | _                 | _                 | _                 | _                 | —                 | _                   | _                   |
| 45.0         | R/W-0             | U-0               | R/W-0             | U-0               | U-0               | R/W-0             | R/W-0               | R/W-0               |
| 15:8         | ON <sup>(1)</sup> | _                 | SIDL              | _                 | _                 | F                 | ORM<2:0>            |                     |
| 7.0          | R/W-0             | R/W-0             | R/W-0             | R/W-0             | U-0               | R/W-0             | R/W-0, HSC          | R/C-0, HSC          |
| 7:0          |                   | SSRC<2:0>         |                   | CLRASAM           |                   | ASAM              | SAMP <sup>(2)</sup> | DONE <sup>(3)</sup> |

#### REGISTER 22-1: AD1CON1: ADC CONTROL REGISTER 1

#### Legend:

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

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

- bit 15 **ON:** ADC Operating Mode bit<sup>(1)</sup>
  - 1 = ADC module is operating
  - 0 = ADC module is not operating
- bit 14 **Unimplemented:** Read as '0'
- bit 13 **SIDL:** Stop in Idle Mode bit
  - 1 = Discontinue module operation when device enters Idle mode
  - 0 = Continue module operation when the device enters Idle mode

#### bit 12-11 Unimplemented: Read as '0'

- bit 10-8 **FORM<2:0>:** Data Output Format bits
  - 111 = Signed Fractional 32-bit (DOUT = sddd dddd dd00 0000 0000 0000 0000)
  - 110 = Fractional 32-bit (DOUT = dddd dddd dd00 0000 0000 0000 0000)
  - 101 = Signed Integer 32-bit (DOUT = ssss ssss ssss ssss ssss sssd dddd dddd)
  - 100 = Integer 32-bit (DOUT = 0000 0000 0000 0000 0000 00dd dddd dddd)
  - 011 = Signed Fractional 16-bit (DOUT = 0000 0000 0000 0000 sddd dddd dd00 0000)
  - 010 = Fractional 16-bit (DOUT = 0000 0000 0000 0000 dddd dddd dd00 0000)

  - 000 =Integer 16-bit (DOUT = 0000 0000 0000 0000 0000 00dd dddd dddd)

#### bit 7-5 SSRC<2:0>: Conversion Trigger Source Select bits

- 111 = Internal counter ends sampling and starts conversion (auto convert)
- 110 = Reserved
- 101 = Reserved
- 100 = Reserved
- 011 = CTMU ends sampling and starts conversion
- 010 = Timer 3 period match ends sampling and starts conversion
- 001 = Active transition on INT0 pin ends sampling and starts conversion
- 000 = Clearing SAMP bit ends sampling and starts conversion
- **Note 1:** When using 1:1 PBCLK divisor, the user's software should not read/write the peripheral's SFRs in the SYSCLK cycle immediately following the instruction that clears the module's ON bit.
  - 2: If ASAM = 0, software can write a '1' to start sampling. This bit is automatically set by hardware if ASAM = 1. If SSRC = 0, software can write a '0' to end sampling and start conversion. If SSRC ≠ '0', this bit is automatically cleared by hardware to end sampling and start conversion.
  - **3:** This bit is automatically set by hardware when analog-to-digital conversion is complete. Software can write a '0' to clear this bit (a write of '1' is not allowed). Clearing this bit does not affect any operation already in progress. This bit is automatically cleared by hardware at the start of a new conversion.

## 26.4 Peripheral Module Disable

The Peripheral Module Disable (PMD) registers provide a method to disable a peripheral module by stopping all clock sources supplied to that module. When a peripheral is disabled using the appropriate PMD control bit, the peripheral is in a minimum power consumption state. The control and status registers associated with the peripheral are also disabled, so writes to those registers do not have effect and read values are invalid. To disable a peripheral, the associated PMDx bit must be set to '1'. To enable a peripheral, the associated PMDx bit must be cleared (default). See Table 26-1 for more information.

Note: Disabling a peripheral module while it's ON bit is set, may result in undefined behavior. The ON bit for the associated peripheral module must be cleared prior to disable a module via the PMDx bits.

| TABLE 26-1: | PERIPHERAL MODULE DISABLE BITS AND LOCATIONS |  |
|-------------|----------------------------------------------|--|
|             |                                              |  |

| Peripheral <sup>(1)</sup>    | PMDx bit Name <sup>(1)</sup> | Register Name and Bit Location           PMD1<0> |  |  |
|------------------------------|------------------------------|--------------------------------------------------|--|--|
| ADC1                         | AD1MD                        |                                                  |  |  |
| СТМU                         | CTMUMD                       | PMD1<8>                                          |  |  |
| Comparator Voltage Reference | CVRMD                        | PMD1<12>                                         |  |  |
| Comparator 1                 | CMP1MD                       | PMD2<0>                                          |  |  |
| Comparator 2                 | CMP2MD                       | PMD2<1>                                          |  |  |
| Comparator 3                 | CMP3MD                       | PMD2<2>                                          |  |  |
| Input Capture 1              | IC1MD                        | PMD3<0>                                          |  |  |
| Input Capture 2              | IC2MD                        | PMD3<1>                                          |  |  |
| Input Capture 3              | IC3MD                        | PMD3<2>                                          |  |  |
| Input Capture 4              | IC4MD                        | PMD3<3>                                          |  |  |
| Input Capture 5              | IC5MD                        | PMD3<4>                                          |  |  |
| Output Compare 1             | OC1MD                        | PMD3<16>                                         |  |  |
| Output Compare 2             | OC2MD                        | PMD3<17>                                         |  |  |
| Output Compare 3             | OC3MD                        | PMD3<18>                                         |  |  |
| Output Compare 4             | OC4MD                        | PMD3<19>                                         |  |  |
| Output Compare 5             | OC5MD                        | PMD3<20>                                         |  |  |
| Timer1                       | T1MD                         | PMD4<0>                                          |  |  |
| Timer2                       | T2MD                         | PMD4<1>                                          |  |  |
| Timer3                       | T3MD                         | PMD4<2>                                          |  |  |
| Timer4                       | T4MD                         | PMD4<3>                                          |  |  |
| Timer5                       | T5MD                         | PMD4<4>                                          |  |  |
| UART1                        | U1MD                         | PMD5<0>                                          |  |  |
| UART2                        | U2MD                         | PMD5<1>                                          |  |  |
| SPI1                         | SPI1MD                       | PMD5<8>                                          |  |  |
| SPI2                         | SPI2MD                       | PMD5<9>                                          |  |  |
| I2C1                         | I2C1MD                       | PMD5<16>                                         |  |  |
| I2C2                         | I2C2MD                       | PMD5<17>                                         |  |  |
| USB <sup>(2)</sup>           | USBMD                        | PMD5<24>                                         |  |  |
| RTCC                         | RTCCMD                       | PMD6<0>                                          |  |  |
| Reference Clock Output       | REFOMD                       | PMD6<1>                                          |  |  |
| PMP                          | PMPMD                        | PMD6<16>                                         |  |  |

Note 1: Not all modules and associated PMDx bits are available on all devices. See TABLE 1: "PIC32MX1XX 28/36/44-Pin General Purpose Family Features" and TABLE 2: "PIC32MX2XX 28/36/44-pin USB Family Features" for the lists of available peripherals.

2: The module must not be busy after clearing the associated ON bit and prior to setting the USBMD bit.

# PIC32MX1XX/2XX 28/36/44-PIN FAMILY

| 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        | r-1                   | r-1               | r-1               | r-1               | r-1               | r-1                          | r-1              | r-1              |
| 31:24        | —                     |                   |                   | -                 | _                 |                              | _                | -                |
| 00.40        | r-1                   | r-1               | r-1               | r-1               | r-1               | R/P                          | R/P              | R/P              |
| 23:16        | —                     | _                 | —                 | -                 | —                 | FPLLODIV<2:0>                |                  |                  |
| 45.0         | R/P                   | r-1               | r-1               | r-1               | r-1               | R/P                          | R/P              | R/P              |
| 15:8         | UPLLEN <sup>(1)</sup> |                   | —                 | _                 | _                 | UPLLIDIV<2:0> <sup>(1)</sup> |                  |                  |
| 7.0          | r-1                   | R/P-1             | R/P               | R/P-1             | r-1               | R/P                          | R/P              | R/P              |
| 7:0          | —                     | FPLLMUL<2:0>      |                   |                   | _                 | FPLLIDIV<2:0>                |                  |                  |

#### **DEVCFG2: DEVICE CONFIGURATION WORD 2 REGISTER 27-3:**

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

bit 15

bit 7

bit 18-16 FPLLODIV<2:0>: Default PLL Output Divisor bits

- 111 = PLL output divided by 256 110 = PLL output divided by 64 101 = PLL output divided by 32 100 = PLL output divided by 16 011 = PLL output divided by 8 010 = PLL output divided by 4 001 = PLL output divided by 2 000 = PLL output divided by 1 UPLLEN: USB PLL Enable bit<sup>(1)</sup> 1 = Disable and bypass USB PLL 0 = Enable USB PLL bit 14-11 Reserved: Write '1' bit 10-8 UPLLIDIV<2:0>: USB PLL Input Divider bits<sup>(1)</sup> 111 = 12x divider 110 = 10x divider 101 = 6x divider100 = 5x divider 011 = 4x divider 010 = 3x divider 010 = 3x divider 001 = 2x divider000 = 1x divider Reserved: Write '1'
- bit 6-4 FPLLMUL<2:0>: PLL Multiplier bits
  - 111 = 24x multiplier 110 = 21x multiplier
  - 101 = 20x multiplier
  - 100 = 19x multiplier
  - 011 = 18x multiplier
  - 010 = 17x multiplier
  - 001 = 16x multiplier
  - 000 = 15x multiplier
- bit 3 Reserved: Write '1'

Note 1: This bit is only available on PIC32MX2XX devices.

# 29.2 MPLAB XC Compilers

The MPLAB XC Compilers are complete ANSI C compilers for all of Microchip's 8, 16, and 32-bit MCU and DSC devices. These compilers provide powerful integration capabilities, superior code optimization and ease of use. MPLAB XC Compilers run on Windows, Linux or MAC OS X.

For easy source level debugging, the compilers provide debug information that is optimized to the MPLAB X IDE.

The free MPLAB XC Compiler editions support all devices and commands, with no time or memory restrictions, and offer sufficient code optimization for most applications.

MPLAB XC Compilers include an assembler, linker and utilities. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. MPLAB XC Compiler uses the assembler to produce its object file. Notable features of the assembler include:

- Support for the entire device instruction set
- Support for fixed-point and floating-point data
- Command-line interface
- · Rich directive set
- Flexible macro language
- · MPLAB X IDE compatibility

## 29.3 MPASM Assembler

The MPASM Assembler is a full-featured, universal macro assembler for PIC10/12/16/18 MCUs.

The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code, and COFF files for debugging.

The MPASM Assembler features include:

- · Integration into MPLAB X IDE projects
- User-defined macros to streamline assembly code
- Conditional assembly for multipurpose source files
- Directives that allow complete control over the assembly process

# 29.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler. It can link relocatable objects from precompiled libraries, using directives from a linker script.

The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

# 29.5 MPLAB Assembler, Linker and Librarian for Various Device Families

MPLAB Assembler produces relocatable machine code from symbolic assembly language for PIC24, PIC32 and dsPIC DSC devices. MPLAB XC Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- · Support for the entire device instruction set
- · Support for fixed-point and floating-point data
- Command-line interface
- · Rich directive set
- Flexible macro language
- MPLAB X IDE compatibility

### TABLE 30-32: I2Cx BUS DATA TIMING REQUIREMENTS (MASTER MODE)

| AC CHARACTERISTICS      |         |                               | $\begin{array}{l} \mbox{Standard Operating Conditions: 2.3V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^\circ C \leq TA \leq +85^\circ C \mbox{ for Industrial} \\ & -40^\circ C \leq TA \leq +105^\circ C \mbox{ for V-temp} \end{array}$ |                     |      |       |                                |  |
|-------------------------|---------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|-------|--------------------------------|--|
| Param.<br>No.           | Symbol  | Characteristics               |                                                                                                                                                                                                                                                                                   | Min. <sup>(1)</sup> | Max. | Units | Conditions                     |  |
| IM10                    | TLO:SCL | Clock Low Time                | 100 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     | —    | μs    | —                              |  |
|                         |         |                               | 400 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     | _    | μS    | —                              |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | Трв * (BRG + 2)     | —    | μs    | _                              |  |
| IM11                    | THI:SCL | Clock High Time               | 100 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     | _    | μS    | —                              |  |
|                         |         |                               | 400 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     | —    | μS    | —                              |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | Трв * (BRG + 2)     | —    | μs    | —                              |  |
| IM20                    | TF:SCL  | SDAx and SCLx                 | 100 kHz mode                                                                                                                                                                                                                                                                      | —                   | 300  | ns    | CB is specified to be          |  |
|                         |         | Fall Time                     | 400 kHz mode                                                                                                                                                                                                                                                                      | 20 + 0.1 Св         | 300  | ns    | from 10 to 400 pF              |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | _                   | 100  | ns    |                                |  |
| IM21                    | TR:SCL  | SDAx and SCLx<br>Rise Time    | 100 kHz mode                                                                                                                                                                                                                                                                      | —                   | 1000 | ns    | CB is specified to be          |  |
|                         |         |                               | 400 kHz mode                                                                                                                                                                                                                                                                      | 20 + 0.1 Св         | 300  | ns    | from 10 to 400 pF              |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | _                   | 300  | ns    |                                |  |
| IM25                    | TSU:DAT | Data Input<br>Setup Time      | 100 kHz mode                                                                                                                                                                                                                                                                      | 250                 | _    | ns    |                                |  |
|                         |         |                               | 400 kHz mode                                                                                                                                                                                                                                                                      | 100                 | —    | ns    |                                |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | 100                 | _    | ns    |                                |  |
| IM26                    | THD:DAT | Data Input                    | 100 kHz mode                                                                                                                                                                                                                                                                      | 0                   | _    | μS    | —                              |  |
|                         |         | Hold Time                     | 400 kHz mode                                                                                                                                                                                                                                                                      | 0                   | 0.9  | μs    |                                |  |
|                         |         |                               | 1 MHz mode<br>(Note 2)                                                                                                                                                                                                                                                            | 0                   | 0.3  | μs    |                                |  |
| IM30                    | TSU:STA | Start Condition<br>Setup Time | 100 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     | _    | μS    | Only relevant for              |  |
|                         |         |                               | 400 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     | —    | μS    | Repeated Start condition       |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | Трв * (BRG + 2)     | —    | μs    | condition                      |  |
| IM31                    | THD:STA | Start Condition<br>Hold Time  | 100 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     |      | μS    | After this period, the         |  |
|                         |         |                               | 400 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     | —    | μs    | first clock pulse is generated |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | Трв * (BRG + 2)     | —    | μS    | generaleu                      |  |
| IM33 Tsu:s <sup>-</sup> | Tsu:sto | Stop Condition                | 100 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     |      | μS    |                                |  |
|                         |         | Setup Time                    | 400 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     |      | μs    | ]                              |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | Трв * (BRG + 2)     |      | μs    |                                |  |
| IM34                    | THD:STO | Stop Condition                | 100 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     |      | ns    | —                              |  |
|                         |         | Hold Time                     | 400 kHz mode                                                                                                                                                                                                                                                                      | Трв * (BRG + 2)     |      | ns    | ]                              |  |
|                         |         |                               | 1 MHz mode<br><b>(Note 2)</b>                                                                                                                                                                                                                                                     | Трв * (BRG + 2)     | —    | ns    |                                |  |

**Note 1:** BRG is the value of the  $I^2C$  Baud Rate Generator.

2: Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only).

**3:** The typical value for this parameter is 104 ns.

### TABLE 30-33: I2Cx BUS DATA TIMING REQUIREMENTS (SLAVE MODE) (CONTINUED)

| AC CHARACTERISTICS                   |         |                            |                               |      |       |            |                            |
|--------------------------------------|---------|----------------------------|-------------------------------|------|-------|------------|----------------------------|
| Param.<br>No. Symbol Characteristics |         |                            | Min.                          | Max. | Units | Conditions |                            |
| IS34                                 | THD:STO | Stop Condition             | 100 kHz mode                  | 4000 | _     | ns         | —                          |
|                                      |         | Hold Time                  | 400 kHz mode                  | 600  | —     | ns         |                            |
|                                      |         |                            | 1 MHz mode<br>(Note 1)        | 250  |       | ns         |                            |
| IS40 TAA:SCL                         | TAA:SCL | Output Valid from<br>Clock | 100 kHz mode                  | 0    | 3500  | ns         | —                          |
|                                      |         |                            | 400 kHz mode                  | 0    | 1000  | ns         |                            |
|                                      |         |                            | 1 MHz mode<br><b>(Note 1)</b> | 0    | 350   | ns         |                            |
| IS45 TBF:SDA                         | TBF:SDA | A Bus Free Time            | 100 kHz mode                  | 4.7  | —     | μs         | The amount of time the bus |
|                                      |         |                            | 400 kHz mode                  | 1.3  |       | μS         | must be free before a new  |
|                                      |         |                            | 1 MHz mode<br>(Note 1)        | 0.5  | -     | μS         | transmission can start     |
| IS50                                 | Св      | Bus Capacitive Lo          | ading                         | _    | 400   | pF         | —                          |

**Note 1:** Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only).