PRODUCT OVERVIEW

The 88MW320/322 is a highly integrated, low-power WLAN Microcontroller System-on-Chip (SoC) solution designed for a broad array of smart devices for home, enterprise and industrial automation, smart accessories, and smart energy applications.

A high degree of integration enables very low system costs requiring only a single 3.3V power input, a 38.4 MHz crystal, and SPI Flash. The RF path needs only a low pass filter for antenna connection.

The SoC includes a full-featured WLAN subsystem powered by proven and mature IEEE 802.11b/g/n technology. The WLAN subsystem integrates a WLAN MAC, baseband, and direct-conversion RF radio with integrated PA, LNA, and transmit/receive switch. It also integrates a CPU subsystem with integrated memory to run NXP WLAN firmware to handle real time WLAN protocol processing to off-load many WLAN functions from the main application CPU.

The 88MW320/322 application subsystem is powered by an ARM Cortex-M4F CPU that operates up to 200 MHz. The device supports an integrated 512 KB SRAM, 128 KB mask ROM, and a QSPI interface to external Flash. An integrated Flash Controller with a 32 KB SRAM cache enables eXecute In Place (XIP) support for firmware from Flash.

The SoC is designed for low-power operation and includes several low-power states and fast wake-up times. Multiple power domains and clocks can be individually shut down to save power. The SoC also has a high-efficiency internal PA that can be operated in low-power mode to save power. The microcontroller and WLAN subsystems can be placed into low-power states, independently, supporting a variety of application use cases. An internal DC-DC regulator provides the 1.8V rail for the WLAN subsystem.

The SoC provides a full array of peripheral interfaces including SSP/SPI/I2S (3x), UART (3x), I2C (2x), General Purpose Timers and PWM, ADC, DAC, Analog Comparator, and GPIOs. It also includes a hardware cryptographic engine, a Secure Boot element, RTC, and Watchdog Timer.

The 88MW322 includes a high-speed USB On-The-Go (OTG) interface to enable USB audio, video, and other applications.

A complete set of digital and analog interfaces enable direct interfacing for I/O avoiding the need for external chips. The application CPU can be used to support custom application development avoiding the need for another microcontroller or processor.

Figure 1 shows an overall block diagram of the device.
Applications

- Smart Home—smart outlet, light switch, security camera, thermostat, sprinkler controller, sensor, door lock, door bell, garage door, security system
- Industrial—building automation, smart lighting, Wi-Fi to other radio bridge, Point of Sale (POS) terminals
- Smart Devices—coffee pot, rice cooker, vacuum cleaner, air purifier, pet monitor, weighing scale, glucometer, blood pressure monitor, fitness equipment
- Smart Appliances—refrigerator, washer, dryer, oven range, microwave, dishwasher, water heater, air conditioner
- Smart Accessories—smart speakers, headset, alarm clock, gaming accessory, remote control
- Gateways—Bluetooth Smart Mesh and other radios to Wi-Fi/IP network
**Key Features**

- Highly integrated SoC requiring very few external components for a full system operation
- Multiple low-power modes and fast wake-up times
- Full-featured, single stream 802.11b/g/n WLAN
- High-efficiency PA with a low-power (10 dB) mode
- Cortex-M4F application CPU for applications with integrated 512 KB SRAM and 128 KB mask ROM
- Flash Controller with embedded 32 KB SRAM cache to support XIP from external SPI Flash
- Secure boot
- Full set of digital and analog I/O interfaces

**Power Management**

- Power modes—active, idle, standby, sleep, shutoff, power-down
- Integrated high-efficiency buck DC-DC converter
- Independent power domains
- Brown-out detection
- Integrated POR
- Wake-up through dedicated GPIO, IRQ, and RTC

**Package**

- 88MW320—68-pin QFN, 8x8 mm
  - USB OTG not supported
  - 35 GPIOs
  - 2 GPTs
- 88MW322—88-pin QFN, 10x10 mm
  - USB OTG supported
  - 50 GPIOs
  - 4 GPTs

**Table 1: Package Feature Differences**

<table>
<thead>
<tr>
<th>Feature</th>
<th>68-Pin</th>
<th>88-Pin</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO</td>
<td>35 total GPIO_0 to GPIO_10, GPIO_16, GPIO_22 to GPIO_33, GPIO_39 to GPIO_49</td>
<td>50 total GPIO_0 to GPIO_49</td>
</tr>
<tr>
<td>USB 2.0 OTG</td>
<td>--</td>
<td>1</td>
</tr>
<tr>
<td>GPT</td>
<td>2</td>
<td>4</td>
</tr>
</tbody>
</table>

a. All I/O features are muxed on GPIOs, except WLAN RF TX/RX, USB, reference clock, and reset functionality.

**Temperature**

- Commercial: 0 to 70°C
- Extended: -30 to 85°C
- Industrial: -40 to 105°C
- Storage: -55 to 125°C
Wireless
- IEEE 802.11b/g/n, 1x1 SISO 2.4 GHz and HT20
- Integrated CPU, memory, MAC, DSSS/OFDM baseband, direct conversion RF radio, encryption
- Antenna diversity
- CMOS and low-swing sine wave input clock
- Low-power with deep sleep and standby modes
- Pre-regulated supplies
- Integrated T/R switch, PA, and LNA
- Optional 802.11n features
- One Time Programmable (OTP) memory to eliminate need for external EEPROM

WLAN Rx Path
- Direct conversion architecture eliminates need for external SAW filter
- On-chip gain selectable LNA with optimized noise figure and power consumption
- High dynamic range AGC function in receive mode

WLAN Tx Path
- Integrated PA with power control
- Optimized Tx gain distribution for linearity and noise performance

WLAN Local Oscillator
- Fractional-N for multiple reference clock support
- Fine channel step

WLAN Encryption
- WEP 64- and 128-bit encryption with hardware TKIP processing (WPA)
- AES-CCMP hardware implementation as part of 802.11i security standard (WPA2)
- Enhanced AES engine performance
- AES-Cipher-Based Message Authentication Code (CMAC) as part of the 802.11w security standard
- WLAN Authentication and Privacy Infrastructure (WAPI)
- WPA3 (SAE)

IEEE 802.11 Standards
- 802.11 data rates of 1 and 2 Mbps
- 802.11b data rates of 5.5 and 11 Mbps
- 802.11g data rates 6, 9, 12, 18, 24, 36, 48, and 54 Mbps for multimedia content transmission
- 802.11g/b performance enhancements
- 802.11n compliant with maximum data rates up to 72.2 Mbps (20 MHz channel)
- 802.11d international roaming
- 802.11e quality of service
- 802.11h transmit power control
- 802.11i enhanced security
- 802.11k radio resource measurement
- 802.11n block acknowledgment extension
- 802.11r fast hand-off for AP roaming
- 802.11w protected management frames
- Fully supports clients (stations) implementing IEEE Power Save mode
- Wi-Fi direct connectivity
Microprocessor

Processor
- ARM Cortex-M4F, 32-bit
- 200 MHz main bus clock

Memory
- 128 KB ROM
- 512 KB RAM

Flash Controller
- Supports QSPI Flash devices
- Memory-mapped access to QSPI Flash devices
- 32 KB SRAM cache

Digital Interfaces
- 3x I²S stereo
- 3x SPI master/slave
- 2x I²C master/slave
- 3x UART
- 1x USB OTG 2.0, high-speed
- 1x QSPI
- Up to 50 GPIOs
- 2x wake-up pins

Analog
- 2-step ADC with integrated PGA and configurable resolution/speed
  - 12-bit/2 MHz sample(s) for fast conversion
  - 16-bit/16 kHz sample/s with voice quality
  - 8 single channels or 4 differential channels
- 2-Channel or 1 differential channel DAC, 10-bit/500 ksp
- 2 Analog Comparators with programmable speed/current
- On-die/off-chip temperature sensing and battery monitor

Counters/Timers/PWM
- General Purpose Timers (GPT) with LED PWM support
- Real Time Clock (RTC)
- CM4 system tick
- Watchdog Timer
1 Package

1.1 Signal Diagram

Figure 2: Signal Diagram

1. Signals are muxed on dedicated pins. See Section 1.4, Pin Description, on page 11 for dedicated pin/muxed signal descriptions.

2. Some pins/signals are available on the 88-pin QFN only. See Section 1.4, Pin Description, on page 11.

3. RF_TR, USB OTG, XTAL_IN/OUT, and RESETn pins are dedicated. Others are muxed on GPIOs.

4. See Table 16, Power and Ground, on page 32 for power signals.
1.2 Pinout

1.2.1 Pinout—68-Pin QFN

Figure 3: Pinout—68-Pin QFN

1. Connect pin 17 to ground.
1.2.2 Pinout—88-Pin QFN

1. Connect pin 22 to ground.
1.3 Mechanical Drawing

1.3.1 Mechanical Drawing—68-Pin QFN

Figure 5: Mechanical Drawing—68-Pin QFN

Note: See Section 22.5, Package Thermal Conditions, on page 279 for electrical specifications. See Section 23.2, Package Marking, on page 302 for package marking.
1.3.2 Mechanical Drawing—88-Pin QFN

Figure 6: Mechanical Drawing—88-Pin QFN

**Note:** See Section 22.5, Package Thermal Conditions, on page 279 for electrical specifications. See Section 23.2, Package Marking, on page 302 for package marking.
## 1.4 Pin Description

### Table 2: Pin Types

<table>
<thead>
<tr>
<th>Pin Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>I/O</td>
<td>Digital input/output</td>
</tr>
<tr>
<td>I</td>
<td>Digital input</td>
</tr>
<tr>
<td>O</td>
<td>Digital output</td>
</tr>
<tr>
<td>A, I</td>
<td>Analog input</td>
</tr>
<tr>
<td>A, O</td>
<td>Analog output</td>
</tr>
<tr>
<td>NC</td>
<td>No connect</td>
</tr>
<tr>
<td>DNC</td>
<td>Do not connect</td>
</tr>
<tr>
<td>PWR</td>
<td>Power</td>
</tr>
<tr>
<td>Ground</td>
<td>Ground</td>
</tr>
</tbody>
</table>
### Table 3: WLAN RF Interface

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>21</td>
<td>16</td>
<td>RF_TR</td>
<td>A, I/O</td>
<td>AVDD18</td>
<td>WLAN RF Interface (2.4 GHz Transmit/Receive) Baseband input/output data</td>
</tr>
</tbody>
</table>

### Table 4: WLAN RF Front End Interface

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_44</td>
<td>RF_CNTL1_P</td>
<td>A, O</td>
<td>VDDIO_3</td>
<td>WLAN Radio Control 1 Power-down output high signal</td>
<td></td>
</tr>
<tr>
<td>GPIO_45</td>
<td>RF_CNTL0_N</td>
<td>A, O</td>
<td>VDDIO_3</td>
<td>WLAN Radio Control 0 Power-down output low signal</td>
<td></td>
</tr>
</tbody>
</table>

### Table 5: USB 2.0 OTG Interface

**NOTE:** Available on 88-pin package only (88MW322)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>61</td>
<td>--</td>
<td>USB_VBUS</td>
<td>A, I/O</td>
<td>--</td>
<td>VBUS Selection Input in device mode; unused in host mode.</td>
</tr>
<tr>
<td>62</td>
<td>--</td>
<td>USB_ID</td>
<td>A, I</td>
<td>USB_AVDD33</td>
<td>USB 2.0 OTG IDPIN</td>
</tr>
<tr>
<td>63</td>
<td>--</td>
<td>USB_AVDD33</td>
<td>A, I</td>
<td>--</td>
<td>USB 3.3V Analog Power Supply See Table 16, Power and Ground, on page 32.</td>
</tr>
<tr>
<td>64</td>
<td>--</td>
<td>USB_DP</td>
<td>A, I/O</td>
<td>USB_AVDD33</td>
<td>USB 2.0 Bus Data+</td>
</tr>
<tr>
<td>65</td>
<td>--</td>
<td>USB_DM</td>
<td>A, I/O</td>
<td>USB_AVDD33</td>
<td>USB 2.0 Bus Data–</td>
</tr>
<tr>
<td>66</td>
<td>--</td>
<td>USB_DRV_VBUS</td>
<td>O</td>
<td>VDDIO_3</td>
<td>Drive 5V on VBUS 0 = do not drive VBUS 1 = drive 5V on VBUS The USB_DRV_VBUS port is connected to the SoC pad to drive an external power management chip to provide power for USB VBUS.</td>
</tr>
</tbody>
</table>

1. After POR, if USB is in host mode, USB_DP/USB_DM will be SE0. If USB is in device mode, USB_DP/USB_DM will be High-z.
### Table 6: UART Interface

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_0</td>
<td>UART0_0</td>
<td>UART0_CTSn</td>
<td>I</td>
<td>VDDIO_0</td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td>GPIO_1</td>
<td>UART0_0</td>
<td>UART0_RTSn</td>
<td>O</td>
<td>VDDIO_0</td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td>GPIO_2</td>
<td>UART0_0</td>
<td>UART0_TXD</td>
<td>O</td>
<td>VDDIO_0</td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td>GPIO_3</td>
<td>UART0_0</td>
<td>UART0_RXD</td>
<td>I</td>
<td>VDDIO_0</td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td>GPIO_23</td>
<td>UART0_0</td>
<td>UART0_CTSn</td>
<td>I</td>
<td>VDDIO_AON</td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td>GPIO_24</td>
<td>UART0_0</td>
<td>UART0_RXD</td>
<td>I</td>
<td>VDDIO_AON</td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td>GPIO_30</td>
<td>UART0_0</td>
<td>UART0_CTSn</td>
<td>I</td>
<td>VDDIO_2</td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td>GPIO_31</td>
<td>UART0_0</td>
<td>UART0_RTSn</td>
<td>O</td>
<td>VDDIO_2</td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td>GPIO_32</td>
<td>UART0_0</td>
<td>UART0_TXD</td>
<td>O</td>
<td>VDDIO_2</td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td>GPIO_33</td>
<td>UART0_0</td>
<td>UART0_RXD</td>
<td>I</td>
<td>VDDIO_2</td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td>GPIO_37</td>
<td>UART0_0</td>
<td>UART0_RTSn</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td>GPIO_27</td>
<td>UART0_0</td>
<td>UART0_TXD</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td></td>
<td>UART1_CTSn</td>
<td>UART1_CTSn</td>
<td>I</td>
<td>VDDIO_0</td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td>GPIO_12</td>
<td>UART1_0</td>
<td>UART1_RTSn</td>
<td>O</td>
<td>VDDIO_0</td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td>GPIO_13</td>
<td>UART1_0</td>
<td>UART1_TXD</td>
<td>O</td>
<td>VDDIO_0</td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td>GPIO_14</td>
<td>UART1_0</td>
<td>UART1_RXD</td>
<td>I</td>
<td>VDDIO_0</td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td>GPIO_35</td>
<td>UART1_0</td>
<td>UART1_CTSn</td>
<td>I</td>
<td>VDDIO_3</td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td>GPIO_36</td>
<td>UART1_0</td>
<td>UART1_RTSn</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td>GPIO_38</td>
<td>UART1_0</td>
<td>UART1_TXD</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td>GPIO_39</td>
<td>UART1_0</td>
<td>UART1_RXD</td>
<td>I</td>
<td>VDDIO_3</td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td>GPIO_42</td>
<td>UART1_0</td>
<td>UART1_CTSn</td>
<td>I</td>
<td>VDDIO_3</td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td>GPIO_43</td>
<td>UART1_0</td>
<td>UART1_RTSn</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td>GPIO_44</td>
<td>UART1_0</td>
<td>UART1_TXD</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td>GPIO_45</td>
<td>UART1_0</td>
<td>UART1_RXD</td>
<td>I</td>
<td>VDDIO_3</td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td>88-Pin</td>
<td>68-Pin</td>
<td>Signal Name</td>
<td>Type</td>
<td>Supply</td>
<td>Description</td>
</tr>
<tr>
<td>--------</td>
<td>--------</td>
<td>--------------</td>
<td>------</td>
<td>----------</td>
<td>--------------------</td>
</tr>
<tr>
<td>GPIO_7</td>
<td>UART2_CTSn</td>
<td>I</td>
<td>VDDIO_0</td>
<td>UART 2 CTSn (active low)</td>
<td></td>
</tr>
<tr>
<td>GPIO_8</td>
<td>UART2_RTSn</td>
<td>O</td>
<td>VDDIO_0</td>
<td>UART 2 RTSn (active low)</td>
<td></td>
</tr>
<tr>
<td>GPIO_9</td>
<td>UART2_TXD</td>
<td>O</td>
<td>VDDIO_0</td>
<td>UART 2 TXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_10</td>
<td>UART2_RXD</td>
<td>I</td>
<td>VDDIO_0</td>
<td>UART 2 RXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_46</td>
<td>UART2_CTSn</td>
<td>I</td>
<td>VDDIO_3</td>
<td>UART 2 CTSn (active low)</td>
<td></td>
</tr>
<tr>
<td>GPIO_47</td>
<td>UART2_RTSn</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 2 RTSn (active low)</td>
<td></td>
</tr>
<tr>
<td>GPIO_48</td>
<td>UART2_TXD</td>
<td>O</td>
<td>VDDIO_3</td>
<td>UART 2 TXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_49</td>
<td>UART2_RXD</td>
<td>I</td>
<td>VDDIO_3</td>
<td>UART 2 RXD</td>
<td></td>
</tr>
</tbody>
</table>

1. All UART signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.
### Table 7: GPT Interface

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_0</td>
<td>GPT0_CH0</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td></td>
<td>General Purpose Timer 0, Channel 0</td>
</tr>
<tr>
<td>GPIO_1</td>
<td>GPT0_CH1</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td></td>
<td>General Purpose Timer 0, Channel 1</td>
</tr>
<tr>
<td>GPIO_2</td>
<td>GPT0_CH2</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td></td>
<td>General Purpose Timer 0, Channel 2</td>
</tr>
<tr>
<td>GPIO_3</td>
<td>GPT0_CH3</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td></td>
<td>General Purpose Timer 0, Channel 3</td>
</tr>
<tr>
<td>GPIO_4</td>
<td>GPT0_CH4</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td></td>
<td>General Purpose Timer 0, Channel 4</td>
</tr>
<tr>
<td>GPIO_5</td>
<td>GPT0_CH5</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td></td>
<td>General Purpose Timer 0, Channel 5</td>
</tr>
<tr>
<td>GPIO_35</td>
<td>--</td>
<td>GPT0_CLKIN</td>
<td>I</td>
<td>VDDIO_3</td>
<td>General Purpose Timer 0, Clock Input</td>
</tr>
<tr>
<td>GPIO_28</td>
<td></td>
<td>GPT1_CH0</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose Timer 1, Channel 0</td>
</tr>
<tr>
<td>GPIO_29</td>
<td></td>
<td>GPT1_CH1</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose Timer 1, Channel 1</td>
</tr>
<tr>
<td>GPIO_30</td>
<td></td>
<td>GPT1_CH2</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose Timer 1, Channel 2</td>
</tr>
<tr>
<td>GPIO_31</td>
<td></td>
<td>GPT1_CH3</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose Timer 1, Channel 3</td>
</tr>
<tr>
<td>GPIO_32</td>
<td></td>
<td>GPT1_CH4</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose Timer 1, Channel 4</td>
</tr>
<tr>
<td>GPIO_33</td>
<td></td>
<td>GPT1_CH5</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose Timer 1, Channel 5</td>
</tr>
<tr>
<td>GPIO_24</td>
<td></td>
<td>GPT1_CLKIN</td>
<td>I</td>
<td>VDDIO_AON</td>
<td>General Purpose Timer 1, Clock Input</td>
</tr>
<tr>
<td>GPIO_36</td>
<td>--</td>
<td>GPT1_CLKIN</td>
<td>I</td>
<td>VDDIO_3</td>
<td>General Purpose Timer 1, Clock Input</td>
</tr>
<tr>
<td>GPIO_11</td>
<td></td>
<td>GPT2_CH0</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose Timer 2, Channel 0</td>
</tr>
<tr>
<td>GPIO_12</td>
<td></td>
<td>GPT2_CH1</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose Timer 2, Channel 1</td>
</tr>
<tr>
<td>GPIO_13</td>
<td></td>
<td>GPT2_CH2</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose Timer 2, Channel 2</td>
</tr>
<tr>
<td>GPIO_14</td>
<td></td>
<td>GPT2_CH3</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose Timer 2, Channel 3</td>
</tr>
<tr>
<td>GPIO_15</td>
<td></td>
<td>GPT2_CH4</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose Timer 2, Channel 4</td>
</tr>
<tr>
<td>GPIO_37</td>
<td></td>
<td>GPT2_CH5</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose Timer 2, Channel 5</td>
</tr>
<tr>
<td>GPIO_38</td>
<td>--</td>
<td>GPT2_CLKIN</td>
<td>I</td>
<td>VDDIO_3</td>
<td>General Purpose Timer 2, Clock Input</td>
</tr>
<tr>
<td>GPIO_17</td>
<td></td>
<td>GPT3_CH0</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose Timer 3, Channel 0</td>
</tr>
<tr>
<td>GPIO_18</td>
<td></td>
<td>GPT3_CH1</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose Timer 3, Channel 1</td>
</tr>
<tr>
<td>GPIO_19</td>
<td></td>
<td>GPT3_CH2</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose Timer 3, Channel 2</td>
</tr>
<tr>
<td>GPIO_20</td>
<td></td>
<td>GPT3_CH3</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose Timer 3, Channel 3</td>
</tr>
</tbody>
</table>
### Table 7: GPT Interface¹ (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_21</td>
<td>--</td>
<td>GPT3_CH4</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose Timer 3, Channel 4</td>
</tr>
<tr>
<td>GPIO_34</td>
<td>--</td>
<td>GPT3_CH5</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose Timer 3, Channel 5</td>
</tr>
<tr>
<td>GPIO_39</td>
<td></td>
<td>GPT3_CLKIN</td>
<td>I</td>
<td>VDDIO_3</td>
<td>General Purpose Timer 3, Clock Input</td>
</tr>
</tbody>
</table>

1. All GPT signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.

### Table 8: SSP Interface¹

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_0</td>
<td></td>
<td>SSP0_CLK</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>SSP 0 Serial Clock</td>
</tr>
<tr>
<td>GPIO_1</td>
<td></td>
<td>SSP0_FRM</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>SSP 0 Frame Indicator</td>
</tr>
<tr>
<td>GPIO_2</td>
<td></td>
<td>SSP0_TXD</td>
<td>O</td>
<td>VDDIO_0</td>
<td>SSP 0 TXD</td>
</tr>
<tr>
<td>GPIO_3</td>
<td></td>
<td>SSP0_RXD</td>
<td>I</td>
<td>VDDIO_0</td>
<td>SSP 0 RXD</td>
</tr>
<tr>
<td>GPIO_30</td>
<td></td>
<td>SSP0_CLK</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>SSP 0 Serial Clock</td>
</tr>
<tr>
<td>GPIO_31</td>
<td></td>
<td>SSP0_FRM</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>SSP 0 Frame Indicator</td>
</tr>
<tr>
<td>GPIO_32</td>
<td></td>
<td>SSP0_TXD</td>
<td>O</td>
<td>VDDIO_2</td>
<td>SSP 0 TXD</td>
</tr>
<tr>
<td>GPIO_33</td>
<td></td>
<td>SSP0_RXD</td>
<td>I</td>
<td>VDDIO_2</td>
<td>SSP 0 RXD</td>
</tr>
<tr>
<td>GPIO_11</td>
<td>--</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>GPIO_12</td>
<td>--</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>GPIO_13</td>
<td>--</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>VDDIO_0</td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>GPIO_14</td>
<td>--</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>VDDIO_0</td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>GPIO_18</td>
<td>--</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>GPIO_19</td>
<td>--</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>GPIO_20</td>
<td>--</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>VDDIO_1</td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>GPIO_21</td>
<td>--</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>VDDIO_1</td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>GPIO_35</td>
<td>--</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>GPIO_36</td>
<td>--</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>GPIO_38</td>
<td>--</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>VDDIO_3</td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>88-Pin</td>
<td>68-Pin</td>
<td>Pin Name</td>
<td>Type</td>
<td>Supply</td>
<td>Description</td>
</tr>
<tr>
<td>--------</td>
<td>--------</td>
<td>----------</td>
<td>------</td>
<td>--------</td>
<td>---------------------------</td>
</tr>
<tr>
<td>GPIO_39</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>VDDIO_3</td>
<td>SSP 1 RXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_42</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>SSP 1 Serial Clock</td>
<td></td>
</tr>
<tr>
<td>GPIO_43</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>SSP 1 Frame Indicator</td>
<td></td>
</tr>
<tr>
<td>GPIO_44</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>VDDIO_3</td>
<td>SSP 1 TXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_45</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>VDDIO_3</td>
<td>SSP 1 RXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_7</td>
<td>SSP2_CLK</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>SSP 2 Serial Clock</td>
<td></td>
</tr>
<tr>
<td>GPIO_8</td>
<td>SSP2_FRM</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>SSP 2 Frame Indicator</td>
<td></td>
</tr>
<tr>
<td>GPIO_9</td>
<td>SSP2_TXD</td>
<td>O</td>
<td>VDDIO_0</td>
<td>SSP 2 TXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_10</td>
<td>SSP2_RXD</td>
<td>I</td>
<td>VDDIO_0</td>
<td>SSP 2 RXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_46</td>
<td>SSP2_CLK</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>SSP 2 Serial Clock</td>
<td></td>
</tr>
<tr>
<td>GPIO_47</td>
<td>SSP2_FRM</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>SSP 2 Frame Indicator</td>
<td></td>
</tr>
<tr>
<td>GPIO_48</td>
<td>SSP2_TXD</td>
<td>O</td>
<td>VDDIO_3</td>
<td>SSP 2 TXD</td>
<td></td>
</tr>
<tr>
<td>GPIO_49</td>
<td>SSP2_RXD</td>
<td>I</td>
<td>VDDIO_3</td>
<td>SSP 2 RXD</td>
<td></td>
</tr>
</tbody>
</table>

1. All SSP signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.
Table 9: \( \text{i}^2\text{C} \) Interface\(^1\)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_4</td>
<td>GPIO_7</td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>( \text{i}^2\text{C} ) 0 SDA</td>
</tr>
<tr>
<td>GPIO_5</td>
<td>GPIO_8</td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>( \text{i}^2\text{C} ) 0 SCL</td>
</tr>
<tr>
<td>GPIO_6</td>
<td>GPIO_9</td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>( \text{i}^2\text{C} ) 1 SDA</td>
</tr>
<tr>
<td>GPIO_10</td>
<td></td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>( \text{i}^2\text{C} ) 1 SCL</td>
</tr>
<tr>
<td>GPIO_20</td>
<td></td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>( \text{i}^2\text{C} ) 0 SDA</td>
</tr>
<tr>
<td>GPIO_21</td>
<td></td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>( \text{i}^2\text{C} ) 0 SCL</td>
</tr>
<tr>
<td>GPIO_18</td>
<td></td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>( \text{i}^2\text{C} ) 1 SDA</td>
</tr>
<tr>
<td>GPIO_17</td>
<td>GPIO_19</td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>( \text{i}^2\text{C} ) 1 SCL</td>
</tr>
<tr>
<td>GPIO_25</td>
<td></td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td>VDDIO_AON</td>
<td>( \text{i}^2\text{C} ) 1 SDA</td>
</tr>
<tr>
<td>GPIO_26</td>
<td></td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td>VDDIO_AON</td>
<td>( \text{i}^2\text{C} ) 1 SCL</td>
</tr>
<tr>
<td>GPIO_28</td>
<td></td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>( \text{i}^2\text{C} ) 1 SDA</td>
</tr>
<tr>
<td>GPIO_29</td>
<td></td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>( \text{i}^2\text{C} ) 1 SCL</td>
</tr>
</tbody>
</table>

\(^1\) All \( \text{i}^2\text{C} \) signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.

Table 10: QSPI Interface\(^1\)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_28</td>
<td></td>
<td>QSPI_SSn</td>
<td>O</td>
<td>VDDIO_2</td>
<td>QSPI Chip Select (active low)</td>
</tr>
<tr>
<td>GPIO_29</td>
<td></td>
<td>QSPI_CLK</td>
<td>O</td>
<td>VDDIO_2</td>
<td>QSPI Clock</td>
</tr>
<tr>
<td>GPIO_30</td>
<td></td>
<td>QSPI_D0</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>QSPI Data 0</td>
</tr>
<tr>
<td>GPIO_31</td>
<td></td>
<td>QSPI_D1</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>QSPI Data 1</td>
</tr>
<tr>
<td>GPIO_32</td>
<td></td>
<td>QSPI_D2</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>QSPI Data 2</td>
</tr>
<tr>
<td>GPIO_33</td>
<td></td>
<td>QSPI_D3</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>QSPI Data 3</td>
</tr>
</tbody>
</table>

\(^1\) QSPI signals are used for external Flash only. All QSPI signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.
## Table 11: GPIO Interface

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>GPIO_0</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT0_CH0</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 0, Channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_CTSn</td>
<td>I</td>
<td></td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 0 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td>GPIO_1</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT0_CH1</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 0, Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_RTSn</td>
<td>O</td>
<td></td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP 0 Frame Indicator</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
<td>GPIO_2</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT0_CH2</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 0, Channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_TXD</td>
<td>O</td>
<td></td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_TXD</td>
<td>O</td>
<td></td>
<td>SSP 0 TXD</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td>GPIO_3</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT0_CH3</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 0, Channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_RXD</td>
<td>I</td>
<td></td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_RXD</td>
<td>I</td>
<td></td>
<td>SSP 0 RXD</td>
</tr>
<tr>
<td>6</td>
<td>6</td>
<td>GPIO_4</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT0_CH4</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 0, Channel 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td></td>
<td>I²C 0 SDA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>AUDIO_CLK</td>
<td>O</td>
<td></td>
<td>Audio Clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>AUPLL Audio clock output provided by Audio PLL for external codec.</td>
</tr>
<tr>
<td>7</td>
<td>7</td>
<td>GPIO_5</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT0_CH5</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 0, Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td></td>
<td>I²C 0 SCL</td>
</tr>
</tbody>
</table>
### Table 11: GPIO Interface 12 (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>8</td>
<td>GPIO_6</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>TDO</td>
<td>O</td>
<td></td>
<td>JTAG Test Data</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td></td>
<td>I2C 1 SDA</td>
</tr>
<tr>
<td>9</td>
<td>9</td>
<td>GPIO_7</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>TCK</td>
<td>I</td>
<td></td>
<td>JTAG Test Clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_CTSn</td>
<td>I</td>
<td></td>
<td>UART 2 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 2 Serial Clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td></td>
<td>I2C 0 SDA</td>
</tr>
<tr>
<td>10</td>
<td>10</td>
<td>GPIO_8</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 8</td>
</tr>
<tr>
<td></td>
<td></td>
<td>TMS</td>
<td>I/O</td>
<td></td>
<td>JTAG Controller Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_RTSn</td>
<td>O</td>
<td></td>
<td>UART 2 RTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP_2 Frame Indicator</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td></td>
<td>I2C 0 SCL</td>
</tr>
<tr>
<td>11</td>
<td>11</td>
<td>GPIO_9</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 9</td>
</tr>
<tr>
<td></td>
<td></td>
<td>TDI</td>
<td>I</td>
<td></td>
<td>JTAG Test Data</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_TXD</td>
<td>O</td>
<td></td>
<td>UART 2 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_TXD</td>
<td>O</td>
<td></td>
<td>SSP 2 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td></td>
<td>I2C 1 SDA</td>
</tr>
<tr>
<td>12</td>
<td>12</td>
<td>GPIO_10</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>TRSTn</td>
<td>I</td>
<td></td>
<td>JTAG Test Reset (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_RXD</td>
<td>I</td>
<td></td>
<td>UART 2 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_TXD</td>
<td>O</td>
<td></td>
<td>SSP 2 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td></td>
<td>I2C 1 SCL</td>
</tr>
</tbody>
</table>
### Table 11: GPIO Interface (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13</td>
<td>--</td>
<td>GPIO_11</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 11</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT2_CH0</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 2, Channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_CTSn</td>
<td>I</td>
<td></td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>14</td>
<td>--</td>
<td>GPIO_12</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 12</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT2_CH1</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 2, Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_RTSn</td>
<td>O</td>
<td></td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>15</td>
<td>--</td>
<td>GPIO_13</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 13</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT2_CH2</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 2, Channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_TXD</td>
<td>O</td>
<td></td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_TXD</td>
<td>O</td>
<td></td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>16</td>
<td>--</td>
<td>GPIO_14</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 14</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT2_CH3</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 2, Channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_RXD</td>
<td>I</td>
<td></td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_RXD</td>
<td>I</td>
<td></td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>17</td>
<td>--</td>
<td>GPIO_15</td>
<td>I/O</td>
<td>VDDIO_0</td>
<td>General Purpose I/O 15</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT2_CH4</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 2, Channel 4</td>
</tr>
<tr>
<td>35</td>
<td>30</td>
<td>GPIO_16</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose I/O 16</td>
</tr>
<tr>
<td></td>
<td></td>
<td>CON[5]</td>
<td>I/O</td>
<td></td>
<td>Configuration Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td>AUDIO_CLK</td>
<td>O</td>
<td></td>
<td>Audio Clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>See Table 17, Configuration Pins, on page 33.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Audio Clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>AUPPLL Audio clock output provided by Audio PLL for external codec.</td>
</tr>
</tbody>
</table>
### Table 11: GPIO Interface (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>36</td>
<td>--</td>
<td>GPIO_17</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose I/O 17</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT3_CH0</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 3, Channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td></td>
<td>(i^2C) 1 SCL</td>
</tr>
<tr>
<td>37</td>
<td>--</td>
<td>GPIO_18</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose I/O 18</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT3_CH1</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 3, Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td></td>
<td>(i^2C) 1 SDA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>38</td>
<td>--</td>
<td>GPIO_19</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose I/O 19</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT3_CH2</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 3, Channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td></td>
<td>(i^2C) 1 SDA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>39</td>
<td>--</td>
<td>GPIO_20</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose I/O 20</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT3_CH3</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 3, Channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td></td>
<td>(i^2C) 0 SDA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_TXD</td>
<td>O</td>
<td></td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>40</td>
<td>--</td>
<td>GPIO_21</td>
<td>I/O</td>
<td>VDDIO_1</td>
<td>General Purpose I/O 21</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT3_CH4</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 3, Channel 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td></td>
<td>(i^2C) 0 SCL</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_RXD</td>
<td>I</td>
<td></td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>46</td>
<td>36</td>
<td>GPIO_22</td>
<td>I/O</td>
<td>VDDIO_AON</td>
<td>General Purpose I/O 22</td>
</tr>
<tr>
<td></td>
<td></td>
<td>WAKE_UP0</td>
<td>I</td>
<td></td>
<td>Wake-Up 0</td>
</tr>
<tr>
<td>88-Pin</td>
<td>68-Pin</td>
<td>Pin/Signal Name</td>
<td>Type</td>
<td>Supply</td>
<td>Description</td>
</tr>
<tr>
<td>--------</td>
<td>--------</td>
<td>-----------------------</td>
<td>----------</td>
<td>------------------</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td>47</td>
<td>37</td>
<td>GPIO_23</td>
<td>I/O</td>
<td>VDDIO_AON</td>
<td>General Purpose I/O 23</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_CTSn</td>
<td>I</td>
<td></td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>WAKE_UP1</td>
<td>I</td>
<td></td>
<td>Wake-Up 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>COMP_IN_P</td>
<td>I</td>
<td></td>
<td>LDO18 Comparator Input, Positive</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Positive input to LDO18 comparator.</td>
</tr>
<tr>
<td>48</td>
<td>38</td>
<td>GPIO_24</td>
<td>I/O</td>
<td>VDDIO_AON</td>
<td>General Purpose I/O 24</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_RXD</td>
<td>I</td>
<td></td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CH5</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 1, Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td>COMP_IN_N</td>
<td>I</td>
<td></td>
<td>LDO18 Comparator Input, Negative</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Negative input to LDO18 comparator.</td>
</tr>
<tr>
<td>49</td>
<td>39</td>
<td>GPIO_25</td>
<td>I/O</td>
<td>VDDIO_AON</td>
<td>General Purpose I/O 25</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XTAL32K_IN</td>
<td>I</td>
<td></td>
<td>32.768 kHz Crystal Input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td></td>
<td>I²C 1 SDA</td>
</tr>
<tr>
<td>50</td>
<td>40</td>
<td>GPIO_26</td>
<td>I/O</td>
<td>VDDIO_AON</td>
<td>General Purpose I/O 26</td>
</tr>
<tr>
<td></td>
<td></td>
<td>XTAL32K_OUT</td>
<td>O</td>
<td></td>
<td>32.768 kHz Crystal Output</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td></td>
<td>I²C 1 SCL</td>
</tr>
<tr>
<td>51</td>
<td>42</td>
<td>GPIO_27</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 27</td>
</tr>
<tr>
<td></td>
<td></td>
<td>-- USB_DRV_VBUS</td>
<td>O</td>
<td></td>
<td>Drive 5V on VBUS</td>
</tr>
<tr>
<td>51</td>
<td>42</td>
<td>UART0_TXD</td>
<td>O</td>
<td></td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td>51</td>
<td>42</td>
<td>CON[4]</td>
<td>I/O</td>
<td></td>
<td>Configuration Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>See Table 17, Configuration Pins, on page 33.</td>
</tr>
<tr>
<td>52</td>
<td>42</td>
<td>GPIO_28</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose I/O 28</td>
</tr>
<tr>
<td></td>
<td></td>
<td>QSPI_SSns</td>
<td>O</td>
<td></td>
<td>QSPI Chip Select (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td></td>
<td>I²C 0 SDA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CH0</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 1, Channel 0</td>
</tr>
</tbody>
</table>
## Table 11: GPIO Interface \(^2\) (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>53</td>
<td>43</td>
<td>GPIO_29</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose I/O 29</td>
</tr>
<tr>
<td></td>
<td></td>
<td>QSPI_CLK</td>
<td>O</td>
<td></td>
<td>QSPI Clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td></td>
<td>I(^2)C 0 SCL</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CH1</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 1, Channel 1</td>
</tr>
<tr>
<td>54</td>
<td>44</td>
<td>GPIO_30</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose I/O 30</td>
</tr>
<tr>
<td></td>
<td></td>
<td>QSPI_D0</td>
<td>I/O</td>
<td></td>
<td>QSPI Data 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_CTSn</td>
<td>I</td>
<td></td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 0 Serial Clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CH2</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 1, Channel 2</td>
</tr>
<tr>
<td>55</td>
<td>45</td>
<td>GPIO_31</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose I/O 31</td>
</tr>
<tr>
<td></td>
<td></td>
<td>QSPI_D1</td>
<td>I/O</td>
<td></td>
<td>QSPI Data 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_RTSn</td>
<td>O</td>
<td></td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP 0 Frame Indicator</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CH3</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 1, Channel 3</td>
</tr>
<tr>
<td>56</td>
<td>46</td>
<td>GPIO_32</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose I/O 32</td>
</tr>
<tr>
<td></td>
<td></td>
<td>QSPI_D2</td>
<td>I/O</td>
<td></td>
<td>QSPI Data 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_TXD</td>
<td>O</td>
<td></td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_TXD</td>
<td>O</td>
<td></td>
<td>SSP 0 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CH4</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 1, Channel 4</td>
</tr>
<tr>
<td>57</td>
<td>47</td>
<td>GPIO_33</td>
<td>I/O</td>
<td>VDDIO_2</td>
<td>General Purpose I/O 33</td>
</tr>
<tr>
<td></td>
<td></td>
<td>QSPI_D3</td>
<td>I/O</td>
<td></td>
<td>QSPI Data 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_RXD</td>
<td>I</td>
<td></td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP0_RXD</td>
<td>I</td>
<td></td>
<td>SSP 0 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CH5</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 1, Channel 5</td>
</tr>
</tbody>
</table>
### Table 11: GPIO Interface (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>67</td>
<td>--</td>
<td>GPIO_34</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 34</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT3_CH5</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 3, Channel 5</td>
</tr>
<tr>
<td>68</td>
<td>--</td>
<td>GPIO_35</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 35</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT0_CLKIN</td>
<td>I</td>
<td></td>
<td>General Purpose Timer 0, Clock Input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_CTSn</td>
<td>I</td>
<td></td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>69</td>
<td>--</td>
<td>GPIO_36</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 36</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT1_CLKIN</td>
<td>I</td>
<td></td>
<td>General Purpose Timer 1, Clock Input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_RTSn</td>
<td>O</td>
<td></td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>70</td>
<td>--</td>
<td>GPIO_37</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 37</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT2_CH5</td>
<td>I/O</td>
<td></td>
<td>General Purpose Timer 2, Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART0_RTSn</td>
<td>O</td>
<td></td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td>71</td>
<td>--</td>
<td>GPIO_38</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 38</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT2_CLKIN</td>
<td>I</td>
<td></td>
<td>General Purpose Timer 2, Clock Input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_TXD</td>
<td>O</td>
<td></td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_TXD</td>
<td>O</td>
<td></td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>72</td>
<td>52</td>
<td>GPIO_39</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 39</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPT3_CLKIN</td>
<td>I</td>
<td></td>
<td>General Purpose Timer 2, Clock Input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_RXD</td>
<td>I</td>
<td></td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_RXD</td>
<td>I</td>
<td></td>
<td>SSP 1 RXD</td>
</tr>
</tbody>
</table>
### Table 11: GPIO Interface (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>75</td>
<td>55</td>
<td>GPIO_40</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 40</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC_DAC_TRIGGER0</td>
<td>I</td>
<td></td>
<td>ADC/DAC External Trigger 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ACOMP0_GPIO_OUT</td>
<td>O</td>
<td></td>
<td>ACOMP0 GPIO Output ACOMP0 output synchronous or asynchronous level signals.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ACOMP1_GPIO_OUT</td>
<td>O</td>
<td></td>
<td>ACOMP1 GPIO Output ACOMP1 output synchronous or asynchronous level signals.</td>
</tr>
<tr>
<td>76</td>
<td>56</td>
<td>GPIO_41</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 41</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC_DAC_TRIGGER1</td>
<td>I</td>
<td></td>
<td>ADC/DAC External Trigger 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ACOMP0_EDG_PULSE</td>
<td>O</td>
<td></td>
<td>ACOMP Edge Pulse 0 Output pulse aligned with synchronized comparison result.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ACOMP1_EDG_PULSE</td>
<td>O</td>
<td></td>
<td>ACOMP Edge Pulse 1 Output pulse aligned with synchronized comparison result.</td>
</tr>
<tr>
<td>78</td>
<td>58</td>
<td>GPIO_42</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 42</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_0 / ACOMP0 / TS_INP / VOICE_P</td>
<td>A, I</td>
<td></td>
<td>ADC0 Channel 0 ACOMP0 Channel 0 ACOMP1 Channel 0 Temperature sensor remote sensing positive input Voice sensing positive input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_CTSn</td>
<td>I</td>
<td></td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Serial Clock</td>
</tr>
</tbody>
</table>
### Table 11: GPIO Interface (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>79</td>
<td>59</td>
<td>GPIO_43</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 43</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_1 / ACOMP1 / TS_INN / DACB / VOICE_N</td>
<td>A, I/O</td>
<td></td>
<td>ADC0 Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Temperature sensor remote sensing negative input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Voice sensing negative input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_RTSn</td>
<td>O</td>
<td></td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>80</td>
<td>60</td>
<td>GPIO_44</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 44</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_2 / ACOMP2 / DACA</td>
<td>A, I/O</td>
<td></td>
<td>ADC0 Channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAC Channel A output</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_TXD</td>
<td>O</td>
<td></td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_TXD</td>
<td>O</td>
<td></td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>RF_CNTL1_P</td>
<td>O</td>
<td></td>
<td>WLAN Radio Control 1</td>
</tr>
<tr>
<td>81</td>
<td>61</td>
<td>GPIO_45</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 45</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_3 / ACOMP3 / EXT_VREF</td>
<td>A, I</td>
<td></td>
<td>ADC0 Channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ADC or DAC external voltage reference input</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART1_RXD</td>
<td>I</td>
<td></td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP1_RXD</td>
<td>I</td>
<td></td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>RF_CNTL0_N</td>
<td>O</td>
<td></td>
<td>WLAN Radio Control 0</td>
</tr>
<tr>
<td>82</td>
<td>62</td>
<td>GPIO_46</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 46</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_4 / ACOMP4</td>
<td>A, I</td>
<td></td>
<td>ADC0 Channel 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_CTSn</td>
<td>I</td>
<td></td>
<td>UART 2 CTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_CLK</td>
<td>I/O</td>
<td></td>
<td>SSP 2 Serial Clock</td>
</tr>
</tbody>
</table>
### Table 11: GPIO Interface \(^2\) (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>83</td>
<td>63</td>
<td>GPIO_47</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 47</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_5 / ACOMP5</td>
<td>A, I</td>
<td></td>
<td>ADC0 Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_RTSn</td>
<td>O</td>
<td></td>
<td>UART 2 RTSn (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_FRM</td>
<td>I/O</td>
<td></td>
<td>SSP 2 Frame Indicator</td>
</tr>
<tr>
<td>84</td>
<td>64</td>
<td>GPIO_48</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 48</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_6 / ACOMP6</td>
<td>A, I</td>
<td></td>
<td>ADC0 Channel 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_TXD</td>
<td>O</td>
<td></td>
<td>UART 2 TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_TXD</td>
<td>O</td>
<td></td>
<td>SSP 2 TXD</td>
</tr>
<tr>
<td>85</td>
<td>65</td>
<td>GPIO_49</td>
<td>I/O</td>
<td>VDDIO_3</td>
<td>General Purpose I/O 49</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ADC0_7 / ACOMP7</td>
<td>A, I</td>
<td></td>
<td>ADC0 Channel 7</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 7</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>UART2_RXD</td>
<td>I</td>
<td></td>
<td>UART 2 RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SSP2_RXD</td>
<td>I</td>
<td></td>
<td>SSP 2 RXD</td>
</tr>
</tbody>
</table>

1. GPIO\_11 to GPIO\_15, GPIO\_17 to GPIO\_21, GPIO\_34 to GPIO\_38 I/O and associated muxing available on 88-pin QFN only.
2. All GPIO pins are pull-up high after POR.

### Table 12: Clock/Control Interface \(^1\)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>26</td>
<td>21</td>
<td>XTAL_IN</td>
<td>A, I</td>
<td>AVDD18</td>
<td>Crystal Oscillator Input</td>
</tr>
<tr>
<td>27</td>
<td>22</td>
<td>XTAL_OUT</td>
<td>A, O</td>
<td>AVDD18</td>
<td>Crystal Oscillator Output Connect to ground when an external oscillator used.</td>
</tr>
<tr>
<td>GPIO_25</td>
<td></td>
<td>XTAL32K_IN</td>
<td>A, I</td>
<td>VDDIO_AON</td>
<td>32.768 kHz Crystal Input</td>
</tr>
<tr>
<td>GPIO_26</td>
<td></td>
<td>XTAL32K_OUT</td>
<td>A, O</td>
<td>VDDIO_AON</td>
<td>32.768 kHz Crystal Output</td>
</tr>
<tr>
<td>GPIO_22</td>
<td></td>
<td>WAKE_UP0</td>
<td>I</td>
<td>VDDIO_AON</td>
<td>Wake-Up 0</td>
</tr>
<tr>
<td>GPIO_23</td>
<td></td>
<td>WAKE_UP1</td>
<td>I</td>
<td>VDDIO_AON</td>
<td>Wake-Up 1</td>
</tr>
</tbody>
</table>
### Table 12: Clock/Control Interface (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin/Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_4</td>
<td></td>
<td>AUDIO_CLK</td>
<td></td>
<td>VDDIO_0</td>
<td>Audio Clock</td>
</tr>
<tr>
<td>GPIO_16</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>AUPLL audio clock output provided by audio PLL for external codec.</td>
</tr>
<tr>
<td>45</td>
<td>35</td>
<td>RESETn</td>
<td>I</td>
<td>VDDIO_AON</td>
<td>Chip Reset (active low)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Has internal hardwired non-programmable 10 kohm pull-up to VDDIO_AON.</td>
</tr>
</tbody>
</table>

1. The XTAL32K_IN/OUT and WAKE_UP0/1 signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.
<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_40 |       | ACOMP0_GPIO_OUT | O    | VDDIO_3 | ACOMP0 GPIO Output  
|        |       |               |      |        | ACOMP0 output synchronous or asynchronous level signals                      |
|        |       | ACOMP1_GPIO_OUT | O    | VDDIO_3 | ACOMP1 GPIO Output  
|        |       |               |      |        | ACOMP1 output synchronous or asynchronous level signals                      |
|        |       | ADC_DAC_TRIGGER0 | I    | VDDIO_3 | ADC/DAC External Trigger 0                                                  |
| GPIO_41 |       | ACOMP0_EDGE_PULSE | O    | VDDIO_3 | ACOMP Edge Pulse 0  
|        |       |               |      |        | Output pulse aligned with synchronized comparison result.                   |
|        |       | ACOMP1_EDGE_PULSE | O    | VDDIO_3 | ACOMP Edge Pulse 1  
|        |       |               |      |        | Output pulse aligned with synchronized comparison result.                   |
|        |       | ADC_DAC_TRIGGER1 | I    | VDDIO_3 | ADC/DAC External Trigger 1                                                  |
| GPIO_49 |       | ADC0_7 / ACOMP7 | A, I | VDDIO_3 | ADC0 Channel 7  
|        |       |               |      |        | ACOMP0 Channel 7  
|        |       |               |      |        | ACOMP1 Channel 7                                                          |
| GPIO_48 |       | ADC0_6 / ACOMP6 | A, I | VDDIO_3 | ADC0 Channel 6  
|        |       |               |      |        | ACOMP0 Channel 6  
|        |       |               |      |        | ACOMP1 Channel 6                                                          |
| GPIO_47 |       | ADC0_5 / ACOMP5 | A, I | VDDIO_3 | ADC0 Channel 5  
|        |       |               |      |        | ACOMP0 Channel 5  
|        |       |               |      |        | ACOMP1 Channel 5                                                          |
| GPIO_46 |       | ADC0_4 / ACOMP4 | A, I | VDDIO_3 | ADC0 Channel 4  
|        |       |               |      |        | ACOMP0 Channel 4  
|        |       |               |      |        | ACOMP1 Channel 4                                                          |
| GPIO_45 |       | ADC0_3 / ACOMP3 / EXT_VREF | A, I | VDDIO_3 | ADC0 Channel 3  
|        |       |               |      |        | ACOMP0 Channel 3  
|        |       |               |      |        | ACOMP1 Channel 3                                                          
|        |       |               |      |        | ADC or DAC external voltage reference input                                 |
| GPIO_44 |       | ADC0_2 / ACOMP2 / DACA | A, I | VDDIO_3 | ADC0 Channel 2  
|        |       |               |      |        | ACOMP0 Channel 2  
|        |       |               |      |        | ACOMP1 Channel 2                                                          
|        |       |               |      |        | DAC Channel A output                                                       |
### Table 13: ADC/DAC/ACOMP Interface\(^1\) (Continued)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_43 | | ADC0_1 / ACOMP01 / TS_INN / DACB / VOICE_N | A, I | VDDIO_3 | ADC0 Channel 1  
| | | | | | ACOMP0 Channel 1  
| | | | | | ACOMP1 Channel 1  
| | | | | | Temperature sensor remote sensing  
| | | | | | negative input  
| | | | | | Voice sensing negative input  
| GPIO_42 | | ADC0_0 / ACOMP0 / TS_INP / VOICE_P | A, I | VDDIO_3 | ADC0 Channel 0  
| | | | | | ACOMP0 Channel 0  
| | | | | | ACOMP1 Channel 0  
| | | | | | Temperature sensor remote sensing  
| | | | | | positive input  
| | | | | | Voice sensing positive input  

1. All ADC/DAC/ACOMP signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.

### Table 14: LDO18 Comparator Interface\(^1\)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_23 | | COMP_IN_P | A, I | VDDIO_AON | LDO18 Comparator Input, Positive  
| | | | | | Positive input to LDO18 comparator.  
| GPIO_24 | | COMP_IN_N | A, I | VDDIO_AON | LDO18 Comparator Input, Negative  
| | | | | | Positive input to LDO18 comparator.  

1. All COMP signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.

### Table 15: JTAG Interface\(^1\)

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Signal Name</th>
<th>Type</th>
<th>Supply</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_6 | | TDO | O | VDDIO_0 | JTAG Test Data  
| GPIO_7 | | TCK | I | VDDIO_0 | JTAG Test Clock  
| GPIO_8 | | TMS | I/O | VDDIO_0 | JTAG Controller Select  
| GPIO_9 | | TDI | I | VDDIO_0 | JTAG Test Data  
| GPIO_10 | | TRSTn | I | VDDIO_0 | JTAG Test Reset I/O (active low)  

1. All JTAG signals are muxed on GPIO pins. See Table 11, GPIO Interface, on page 19 for GPIO muxing.
### Table 16: Power and Ground

**NOTE:** See Section 22.2, Recommended Operating Conditions, on page 270 for ratings.

<table>
<thead>
<tr>
<th>88-Pin</th>
<th>68-Pin</th>
<th>Pin Name</th>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>33 59</td>
<td>28 49</td>
<td>VDD11</td>
<td>PWR</td>
<td>1.1V Core Power Supply Input</td>
</tr>
<tr>
<td>5</td>
<td>5</td>
<td>VDDIO_0</td>
<td>PWR</td>
<td>1.8V/2.5V/3.3V Digital I/O Power Supply</td>
</tr>
<tr>
<td>34</td>
<td>29</td>
<td>VDDIO_1</td>
<td>PWR</td>
<td></td>
</tr>
<tr>
<td>58</td>
<td>48</td>
<td>VDDIO_2</td>
<td>PWR</td>
<td></td>
</tr>
<tr>
<td>77</td>
<td>57</td>
<td>VDDIO_3</td>
<td>PWR</td>
<td></td>
</tr>
<tr>
<td>73</td>
<td>53</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>51</td>
<td>41</td>
<td>VDDIO_AON</td>
<td>PWR</td>
<td></td>
</tr>
<tr>
<td>60</td>
<td>50</td>
<td>VTR_VDD33</td>
<td>PWR</td>
<td>3.3V OTP Write Operation or Floating for OTP Read Operation</td>
</tr>
<tr>
<td>63</td>
<td>--</td>
<td>USB_AVDD33</td>
<td>PWR</td>
<td>3.3V USB Analog Power Supply</td>
</tr>
<tr>
<td>74</td>
<td>54</td>
<td>ISENSE</td>
<td>--</td>
<td>USB Current Source Connect pin to ground with resistance.</td>
</tr>
<tr>
<td>20</td>
<td>15</td>
<td>AVDD33</td>
<td>PWR</td>
<td>3.3V Analog Power Supply</td>
</tr>
<tr>
<td>18 19 23 24 25 28</td>
<td>13 14 18 19 20 23</td>
<td>AVDD18</td>
<td>PWR</td>
<td>1.8V Analog Power Supply</td>
</tr>
<tr>
<td>41</td>
<td>31</td>
<td>LDO11_VOUT</td>
<td>PWR</td>
<td>1.1V LV LDO Voltage Output</td>
</tr>
<tr>
<td>42</td>
<td>32</td>
<td>LDO11_V18</td>
<td>--</td>
<td>BUCK18 Inductor Connection</td>
</tr>
<tr>
<td>43</td>
<td>33</td>
<td>BUCK18_VX</td>
<td>--</td>
<td>BUCK18 Inductor Connection</td>
</tr>
<tr>
<td>44</td>
<td>34</td>
<td>BUCK18_VBAT_IN</td>
<td>PWR</td>
<td>BUCK18 Input 2.4V to 4.3V</td>
</tr>
<tr>
<td>87</td>
<td>67</td>
<td>VBAT_IN</td>
<td>PWR</td>
<td>LDO18 VBAT Input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This pin connects to VBAT source 1.84V to 3.6V.</td>
</tr>
<tr>
<td>86</td>
<td>66</td>
<td>FLY18</td>
<td>--</td>
<td>1.8V LDO Fly Capacitor to Ground Connection</td>
</tr>
<tr>
<td>88</td>
<td>68</td>
<td>FLY11</td>
<td>--</td>
<td>1.1V LDO Fly Capacitor to Ground Connection</td>
</tr>
<tr>
<td>22</td>
<td>17</td>
<td>NC</td>
<td>NC</td>
<td>No Connect</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>NOTE: CONNECT THESE PINS to GROUND.</td>
</tr>
<tr>
<td>29 30 31 32</td>
<td>24 25 26 27</td>
<td>DNC</td>
<td>DNC</td>
<td>Do Not Connect</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Do not connect these pins. Leave these pins floating.</td>
</tr>
</tbody>
</table>
1.5 Configuration Pins

Table 17 shows the pins used as configuration inputs to set parameters following a reset. The definition of these pins changes immediately after reset to their usual function.

To set a configuration bit to 0, attach a resistor value of 10 kΩ or less from the pin to ground. No external circuitry is required to set a configuration bit to 1.

Table 17: Configuration Pins

<table>
<thead>
<tr>
<th>Configuration Bits</th>
<th>Pin Name</th>
<th>Configuration Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>CON[5]</td>
<td>GPIO_16</td>
<td>Boot Options</td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 = boot from UART</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 = boot from USB</td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 = boot from Flash (default)</td>
</tr>
<tr>
<td>CON[4]</td>
<td>GPIO_27</td>
<td></td>
</tr>
</tbody>
</table>
2 Core and System Control

2.1 Overview
The 88MW320/322 integrates a full-featured ARM Cortex-M4F core processor.

2.2 Cortex-M4F Core
The ARM Cortex-M4F processor provides a high performance and low-cost platform. It offers many new features, including a Thumb-2 instruction set, low interrupt latency, hardware division, memory protection unit, etc.

Details of the ARM Cortex-M4F core are available in the ARM Cortex-M4F r2p1 technical reference manual.

2.2.1 Features
- 32-bit ARM Cortex-M4F architecture optimized for embedded applications
- Cortex-M4F core can operate at up to 200 MHz
- Thumb-2 mixed 16/32-bit instruction set
- Hardware division and fast multiplier
- Little-endian memory space
- Memory protection unit (MPU) for protected operating system functionality
- Includes Nested Vectored Interrupt Controller (NVIC)
- SysTick Timer provided by Cortex-M4F core
- Wake-up Interrupt Controller (WIC) for waking up the CPU from reduced power modes
- Standard JTAG debug interface
- Serial Wire JTAG debug port (SWJ-DP)
- Enhanced system debug with extensive breakpoint

2.2.2 Memory Protection Unit (MPU)
The Memory Protection Unit (MPU) is used to improve the reliability of an embedded system by protecting critical data in the applications.

The MPU separates the memory into distinct regions and implements protection by preventing disallowed accesses. The MPU can manage as many as 8 protection regions. The protection area sizes are between 32 bytes and all 4 gigabytes of addressable memory.

The MPU is optional and can be bypassed for applications that do not need it.
2.2.3 Nested Vectored Interrupt Controller (NVIC)

The NVIC is integrated in the Cortex-M4F core. The tight coupling to the CPU allows for low interrupt latency and efficient processing of interrupts. Features include:

- Supports up to 63 interrupts
- Supports 16 interrupt priority levels, Level 0 is the highest interrupt priority
- Control system exceptions and peripheral interrupts
- Supports interrupt tail chaining
- Non-maskable interrupt

See Section 2.4, Memory Map, on page 36 for a detailed description of the interrupts.

2.2.4 SysTick Timer

The ARM Cortex-M4F includes a system tick timer (SysTick). This timer is dedicated to real-time operating systems, but could also be used as a standard downcounter. Features include:

- 24-bit downcounter
- Auto reload capability
- Maskable system interrupt generation when counter reaches 0
- Programmable clock source

2.3 System Control

The 88MW320/322 System Control unit provides several system features and control registers for memory space configuration, DMA handshake interface mapping, peripheral software reset, and USB control.

These registers must be configured correctly to ensure correct functionality of memories, DMA, USB, and other peripherals on-chip.

- DMA handshake interface mapping – The DMA_HS register enables mapping the DMA handshaking interface to the required DMA channel in order to perform DMA transfers for different peripherals on-chip.
- Peripheral software reset – The PERI_SW_RST register is used to program reset for various peripherals on the chip. Writing 0 to certain bits resets the corresponding module. It resets only the function clock domain.

See Section 24.21.2, System Control Registers for a detailed description of the registers.
2.4 Memory Map

The 88MW320/322 includes 128 KB Boot ROM and ROM, 4 KB SRAM in AON domain, and 512 KB of SRAM on-chip. ROM is allocated on the CODE space. The 512 KB SRAM is allocated to the CODE and SRAM space.

The Cortex-M4F CPU accesses the CODE memory space using the ICODE or DCODE AHB bus interface, and accesses the SRAM space with the SYS AHB bus interface.

The 512 KB SRAM memory consists of 4 segments:

- RAM0, 192 KB
- RAM1, 192 KB
- RAM2, 64 KB
- RAM3, 64 KB

RAM0 and RAM1 are part of the CODE space, and RAM2 and RAM3 are part of the SRAM space. 192 KB of SRAM memory can be in Retention mode even in PM3 low-power mode. With this 192 KB retention SRAM, the chip can implement the fast wake-up from PM3 mode.

The 4 KB SRAM in the AON domain is mapped to the peripheral address space and begins at address 0x480C_0000. The on-chip peripherals are mapped to the peripheral address space. Accessing reserved portions of the peripheral address space does not cause a data abort or error response but does provide undetermined data.

Figure 7 and Table 18 show the system memory map.
Figure 7: System Memory Map Diagram
<table>
<thead>
<tr>
<th>Module</th>
<th>Start Address</th>
<th>End Address</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Memory</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ROM</td>
<td>0x0000_0000</td>
<td>0x0001_FFFF</td>
</tr>
<tr>
<td>Code RAM</td>
<td>0x0010_0000</td>
<td>0x0015_FFFF</td>
</tr>
<tr>
<td>Flash Memory</td>
<td>0x1F00_0000</td>
<td>0x1FFF_FFFF</td>
</tr>
<tr>
<td>SRAM RAM</td>
<td>0x2000_0000</td>
<td>0x2001_FFFF</td>
</tr>
<tr>
<td>SRAM Flash Controller</td>
<td>0x2002_0000</td>
<td>0x2002_7FFF</td>
</tr>
<tr>
<td><strong>AHB</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DMAC</td>
<td>0x4400_0000</td>
<td>0x4400_0FFF</td>
</tr>
<tr>
<td>USB</td>
<td>0x4400_1000</td>
<td>0x4400_1FFF</td>
</tr>
<tr>
<td>Flash Controller</td>
<td>0x4400_3000</td>
<td>0x4400_3FFF</td>
</tr>
<tr>
<td>AES</td>
<td>0x4400_4000</td>
<td>0x4400_4FFF</td>
</tr>
<tr>
<td>CRC</td>
<td>0x4400_5000</td>
<td>0x4400_5FFF</td>
</tr>
<tr>
<td><strong>APB0</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>I2C0</td>
<td>0x4600_0000</td>
<td>0x4600_0FFF</td>
</tr>
<tr>
<td>QSPI</td>
<td>0x4601_0000</td>
<td>0x4601_0FFF</td>
</tr>
<tr>
<td>SSP0</td>
<td>0x4602_0000</td>
<td>0x4602_0FFF</td>
</tr>
<tr>
<td>UART0</td>
<td>0x4604_0000</td>
<td>0x4604_0FFF</td>
</tr>
<tr>
<td>GPIO</td>
<td>0x4606_0000</td>
<td>0x4606_0FFF</td>
</tr>
<tr>
<td>GPT0</td>
<td>0x4607_0000</td>
<td>0x4607_0FFF</td>
</tr>
<tr>
<td>GPT1</td>
<td>0x4608_0000</td>
<td>0x4608_0FFF</td>
</tr>
<tr>
<td>Reserved</td>
<td>0x4609_0000</td>
<td>0x4609_0FFF</td>
</tr>
<tr>
<td>RC32M</td>
<td>0x460A_0000</td>
<td>0x460A_0FFF</td>
</tr>
<tr>
<td>ADC</td>
<td>0x460B_0000</td>
<td>0x460B_0FFF</td>
</tr>
<tr>
<td>DAC</td>
<td>0x460B_0200</td>
<td>0x460B_02FF</td>
</tr>
<tr>
<td>ACOMP</td>
<td>0x460B_0400</td>
<td>0x460B_04FF</td>
</tr>
<tr>
<td>UART1</td>
<td>0x460C_0000</td>
<td>0x460C_0FFF</td>
</tr>
<tr>
<td>SSP1</td>
<td>0x460D_0000</td>
<td>0x460D_0FFF</td>
</tr>
<tr>
<td><strong>APB1</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SSP2</td>
<td>0x4800_0000</td>
<td>0x4800_0FFF</td>
</tr>
</tbody>
</table>
### Table 18: System Address Memory Map (Continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Start Address</th>
<th>End Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pin Mux</td>
<td>0x4801_0000</td>
<td>0x4801_0FFF</td>
</tr>
<tr>
<td>UART2</td>
<td>0x4802_0000</td>
<td>0x4802_0FFF</td>
</tr>
<tr>
<td>Watchdog Timer</td>
<td>0x4804_0000</td>
<td>0x4804_0FFF</td>
</tr>
<tr>
<td>I2C1</td>
<td>0x4805_0000</td>
<td>0x4805_0FFF</td>
</tr>
<tr>
<td>Reserved</td>
<td>0x4806_0000</td>
<td>0x4806_0FFF</td>
</tr>
<tr>
<td>GPT2</td>
<td>0x4807_0000</td>
<td>0x4807_0FFF</td>
</tr>
<tr>
<td>GPT3</td>
<td>0x4808_0000</td>
<td>0x4808_0FFF</td>
</tr>
<tr>
<td>RTC</td>
<td>0x4809_0000</td>
<td>0x4809_0FFF</td>
</tr>
<tr>
<td>PMU</td>
<td>0x480A_0000</td>
<td>0x480A_0FFF</td>
</tr>
<tr>
<td>SYS_CTL</td>
<td>0x480B_0000</td>
<td>0x480B_0FFF</td>
</tr>
<tr>
<td>4k_MEM</td>
<td>0x480C_0000</td>
<td>0x480C_0FFF</td>
</tr>
</tbody>
</table>
Accesses to unmapped addresses of RAM1 and RAM2 are provided with an error response. Writes to the ROM space, if any, also yield an error response.

Table 19 shows the available RAM blocks.

### Table 19: RAM Blocks

<table>
<thead>
<tr>
<th>RAM Blocks</th>
<th>Start Address</th>
<th>End Address</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>RAM0</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bank0</td>
<td>0x0010_0000</td>
<td>0x0010_7FFF</td>
</tr>
<tr>
<td>Bank1</td>
<td>0x0010_8000</td>
<td>0x0010_FFFF</td>
</tr>
<tr>
<td>Bank2</td>
<td>0x0011_0000</td>
<td>0x0011_7FFF</td>
</tr>
<tr>
<td>Bank3</td>
<td>0x0011_8000</td>
<td>0x0011_FFFF</td>
</tr>
<tr>
<td>Bank4</td>
<td>0x0012_0000</td>
<td>0x0012_7FFF</td>
</tr>
<tr>
<td>Bank5</td>
<td>0x0012_8000</td>
<td>0x0012_FFFF</td>
</tr>
<tr>
<td><strong>RAM1</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bank6</td>
<td>0x0013_0000</td>
<td>0x0013_7FFF</td>
</tr>
<tr>
<td>Bank7</td>
<td>0x0013_8000</td>
<td>0x0013_FFFF</td>
</tr>
<tr>
<td>Bank8</td>
<td>0x0014_0000</td>
<td>0x0014_7FFF</td>
</tr>
<tr>
<td>Bank9</td>
<td>0x0014_8000</td>
<td>0x0014_FFFF</td>
</tr>
<tr>
<td>Bank10</td>
<td>0x0015_0000</td>
<td>0x0015_7FFF</td>
</tr>
<tr>
<td>Bank11</td>
<td>0x0015_8000</td>
<td>0x0015_FFFF</td>
</tr>
<tr>
<td><strong>RAM2</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bank12</td>
<td>0x2000_0000</td>
<td>0x2000_7FFF</td>
</tr>
<tr>
<td>Bank13</td>
<td>0x2000_8000</td>
<td>0x2000_FFFF</td>
</tr>
<tr>
<td><strong>RAM3</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bank14</td>
<td>0x2001_0000</td>
<td>0x2001_7FFF</td>
</tr>
<tr>
<td>Bank15</td>
<td>0x2001_8000</td>
<td>0x2001_FFFF</td>
</tr>
</tbody>
</table>

Section 24.21.2, System Control Registers shows a detailed description of the memory configuration register.

192 KB of the 512 KB SRAM can be in Retention mode in PM3 low-power mode. 160 KB retention SRAM is located in the CODE space, starting from address 0x0010_0000.
# 2.5 External Interrupts

## 2.5.1 Interrupts Accepted

The 88MW320/322 can accept external interrupts through the NVIC module in the Cortex-M4F processor. Table 20 shows the interrupts.

<table>
<thead>
<tr>
<th>Name</th>
<th>Source</th>
<th>Type</th>
<th>Polarity</th>
<th>Map</th>
</tr>
</thead>
<tbody>
<tr>
<td>WD Timeout</td>
<td>WDT</td>
<td>Level</td>
<td>Active High</td>
<td>INTNMI</td>
</tr>
<tr>
<td>LOCKUP</td>
<td>Cortex-M4F</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Ext. Pin 0</td>
<td>External</td>
<td>Configurable</td>
<td>Active High</td>
<td>INTIRQ[0]</td>
</tr>
<tr>
<td>Ext. Pin 1</td>
<td>External</td>
<td>Configurable</td>
<td>Active High</td>
<td>INTIRQ[1]</td>
</tr>
<tr>
<td>RTC INT</td>
<td>RTC</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[2]</td>
</tr>
<tr>
<td>CRC INT</td>
<td>CRC</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[3]</td>
</tr>
<tr>
<td>AES INT</td>
<td>AES</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[4]</td>
</tr>
<tr>
<td>I2C0 INT</td>
<td>I2C 0</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[5]</td>
</tr>
<tr>
<td>I2C1 INT</td>
<td>I2C 1</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[6]</td>
</tr>
<tr>
<td>DMAC INT</td>
<td>DMAC</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[8]</td>
</tr>
<tr>
<td>GPIO INT</td>
<td>GPIO</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[9]</td>
</tr>
<tr>
<td>SSP0 INT</td>
<td>SSP 0</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[10]</td>
</tr>
<tr>
<td>SSP1 INT</td>
<td>SSP 1</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[11]</td>
</tr>
<tr>
<td>SSP2 INT</td>
<td>SSP 2</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[12]</td>
</tr>
<tr>
<td>QSPI INT</td>
<td>QSPI</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[13]</td>
</tr>
<tr>
<td>GPT0 INT</td>
<td>GPT 0</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[14]</td>
</tr>
<tr>
<td>GPT1 INT</td>
<td>GPT 1</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[15]</td>
</tr>
<tr>
<td>GPT2 INT</td>
<td>GPT 2</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[16]</td>
</tr>
<tr>
<td>GPT3 INT</td>
<td>GPT 3</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[17]</td>
</tr>
<tr>
<td>UART0 INT</td>
<td>UART 0</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[18]</td>
</tr>
<tr>
<td>UART1 INT</td>
<td>UART 1</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[19]</td>
</tr>
<tr>
<td>UART2 INT</td>
<td>UART 2</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[20]</td>
</tr>
<tr>
<td>WDT INT</td>
<td>WDT</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[22]</td>
</tr>
<tr>
<td>ADC0 INT</td>
<td>GAU</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[24]</td>
</tr>
<tr>
<td>DAC INT</td>
<td>GAU</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[25]</td>
</tr>
</tbody>
</table>
Table 20: External Interrupts (Continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Source</th>
<th>Type</th>
<th>Polarity</th>
<th>Map</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACOMP Wake-up INT</td>
<td>GAU</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[26]</td>
</tr>
<tr>
<td>ACOMP INT</td>
<td>GAU</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[27]</td>
</tr>
<tr>
<td>USB INT</td>
<td>USB</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[29]</td>
</tr>
<tr>
<td>PLL INT</td>
<td>PMU</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[31]</td>
</tr>
<tr>
<td>RC32M INT Func</td>
<td>RC32M</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[33]</td>
</tr>
<tr>
<td>External Pin INT</td>
<td>PMU</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[58:34]</td>
</tr>
<tr>
<td>ULP_COMP</td>
<td>PMU</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[60]</td>
</tr>
<tr>
<td>Brnout INT</td>
<td>Brnout</td>
<td>Level</td>
<td>Active High</td>
<td>INTIRQ[61]</td>
</tr>
</tbody>
</table>

External pin interrupts connected to INTIRQ[58:34] are generated using GPIOs in the design by programming the PMU.EXT_SEL_REG register bits to the required value.
### 2.5.2 GPIO Mapping of Interrupts

The PMU.EXT_SEL_REG0 register is used to select the GPIO connected to an external interrupt on the Cortex-M4F.

See Section 24.20, PMU Address Block for information on register programming.

Table 21 shows the GPIO mapping of the external interrupts.

#### Table 21: GPIO Mapping to External Interrupts

<table>
<thead>
<tr>
<th>External Interrupt Bit</th>
<th>GPIO Connected</th>
<th>External Select Register Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>34</td>
<td>GPIO[0]</td>
<td>ext_sel_reg0[0] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[1]</td>
<td>ext_sel_reg0[0] = 0</td>
</tr>
<tr>
<td></td>
<td>GPIO[3]</td>
<td>ext_sel_reg0[1] = 0</td>
</tr>
<tr>
<td>38</td>
<td>GPIO[8]</td>
<td>ext_sel_reg0[4] = 1</td>
</tr>
<tr>
<td>40</td>
<td>GPIO[12]</td>
<td>ext_sel_reg0[6] = 1</td>
</tr>
<tr>
<td>41</td>
<td>GPIO[14]</td>
<td>ext_sel_reg0[7] = 1</td>
</tr>
<tr>
<td>42</td>
<td>GPIO[16]</td>
<td>ext_sel_reg0[8] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[17]</td>
<td>ext_sel_reg0[8] = 0</td>
</tr>
<tr>
<td>43</td>
<td>GPIO[18]</td>
<td>ext_sel_reg0[9] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[19]</td>
<td>ext_sel_reg0[9] = 0</td>
</tr>
<tr>
<td>44</td>
<td>GPIO[20]</td>
<td>ext_sel_reg0[10] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[21]</td>
<td>ext_sel_reg0[10] = 0</td>
</tr>
<tr>
<td>45</td>
<td>GPIO[22]</td>
<td>ext_sel_reg0[11] = 1</td>
</tr>
<tr>
<td>46</td>
<td>GPIO[24]</td>
<td>ext_sel_reg0[12] = 1</td>
</tr>
</tbody>
</table>
Table 21: GPIO Mapping to External Interrupts (Continued)

<table>
<thead>
<tr>
<th>External Interrupt Bit</th>
<th>GPIO Connected</th>
<th>External Select Register Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>47</td>
<td>GPIO[25]</td>
<td>ext_sel_reg0[12] = 0</td>
</tr>
<tr>
<td></td>
<td>GPIO[26]</td>
<td>ext_sel_reg0[13] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[27]</td>
<td>ext_sel_reg0[13] = 0</td>
</tr>
<tr>
<td>48</td>
<td>GPIO[28]</td>
<td>ext_sel_reg0[14] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[29]</td>
<td>ext_sel_reg0[14] = 0</td>
</tr>
<tr>
<td></td>
<td>GPIO[31]</td>
<td>ext_sel_reg0[15] = 0</td>
</tr>
<tr>
<td>50</td>
<td>GPIO[32]</td>
<td>ext_sel_reg0[16] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[33]</td>
<td>ext_sel_reg0[16] = 0</td>
</tr>
<tr>
<td>51</td>
<td>GPIO[34]</td>
<td>ext_sel_reg0[17] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[35]</td>
<td>ext_sel_reg0[17] = 0</td>
</tr>
<tr>
<td>52</td>
<td>GPIO[36]</td>
<td>ext_sel_reg0[18] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[37]</td>
<td>ext_sel_reg0[18] = 0</td>
</tr>
<tr>
<td>53</td>
<td>GPIO[38]</td>
<td>ext_sel_reg0[19] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[39]</td>
<td>ext_sel_reg0[19] = 0</td>
</tr>
<tr>
<td>54</td>
<td>GPIO[40]</td>
<td>ext_sel_reg0[20] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[41]</td>
<td>ext_sel_reg0[20] = 0</td>
</tr>
<tr>
<td>55</td>
<td>GPIO[42]</td>
<td>ext_sel_reg0[21] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[43]</td>
<td>ext_sel_reg0[21] = 0</td>
</tr>
<tr>
<td>56</td>
<td>GPIO[44]</td>
<td>ext_sel_reg0[22] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[45]</td>
<td>ext_sel_reg0[22] = 0</td>
</tr>
<tr>
<td>57</td>
<td>GPIO[46]</td>
<td>ext_sel_reg0[23] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[47]</td>
<td>ext_sel_reg0[23] = 0</td>
</tr>
<tr>
<td>58</td>
<td>GPIO[48]</td>
<td>ext_sel_reg0[24] = 1</td>
</tr>
<tr>
<td></td>
<td>GPIO[49]</td>
<td>ext_sel_reg0[24] = 0</td>
</tr>
</tbody>
</table>
2.6 AHB Bus Fabric

The 88MW320/322 AHB Bus Matrix is a low latency bus matrix which enables parallel access to a number of shared AHB slaves from a number of different AHB masters. The bus matrix routes the control data signals between the masters and slaves based on the address map (see Section 2.4, Memory Map, on page 36). The sparse connectivity feature allows for the configuration of only the necessary master/slave connections, thus providing reduced area and multiplexer delays.

The AHB Bus Fabric connects 6 masters and 9 slaves. The master ports connected to the bus matrix include ICODE, DCODE, and SYSTEM bus from Cortex-M4F, DMA Controller, and USB Controller. The slave ports connected to the bus matrix include the BOOT ROM, Flash memory, RAM0, RAM1, RAM2, RAM3, APB0, APB1 (APB0 and APB1 contain the instances of the APB peripherals in the system) and AHB Decode (decodes addresses to the various AHB peripherals in the system).

APB0 and APB1 are top-level blocks that contain the APB peripherals. The AHB Decode block maps to registers in the DMA Controller, USB Controller, AES-CRC, and Flash Controller blocks. Figure 8 shows the connection between the various masters and slaves in the system.

Figure 8: Bus Matrix Interconnection

2.7 Register Description

See Section 24.21.2, System Control Registers for a detailed description of the registers.
3 Power, Reset, and Clock Control

3.1 Overview
The 88MW320/322 power supply, power mode, and on-chip DC-DC converter, clocking, reset, and wake-up signals are managed by the Power Management Unit (PMU), which is in the Always ON (AON) power domain.

3.2 Power

3.2.1 Power Supplies

3.2.1.1 Power Supply Blocks
Figure 9 shows both power supply blocks with internal signals:
- PSU — Power Supply block for WLAN subsystem
- PMIP — Power Management block (PMIP) for Microcontroller (MCI) subsystem

Figure 9: Power Supply Blocks
3.2.1.2 Power-up Requirements

See Table 16, Power and Ground, on page 69 for the power pins.

Figure 10 shows the device power supplies.

Figure 11 shows the device power-up sequence.

- External VBAT_IN
- Internal AVDD18/VDD11 from on-chip LDOs and BUCK

The following requirements must be met for correct power-up:

- External 3.3V is used for VDDIO_0:3, VDDIO_AON, and VBAT_IN, as needed by the platform
- VBAT_IN is used as input to LDO18, which will further input into LDO11
- BUCK18_VBAT_IN is used as input to BUCK18, which will further input into LDO11

Figure 10: Power Option
Figure 11: Power-Up Sequence

3.3V

VBAT_IN

VDDIO_AON

RESETn
PIN_PSU_PDn

3.3V/2.5V/1.8V

VDDIO_0/3

PORn

1.8V

FLY18

1.1V

FLY11

Controlled by software. Could be longer.

MCU_WL_PDn

AVDD18
(on-chip BUCK.18)

1.8V

VDD11

1.1V

Internal POR
3.2.2 Power Domains

The 88MW320/322 provides several independent power domains, including:

- **VDDIO_AON** – PMU, RTC, low-power comparator, and 4K memory brown-out detection logic are in the VDDIO_AON power domain. They are operational in all power modes.
- **VDD_MEM** – 192 KB of SRAM and Flash Controller sits on this power domain. It is on in PM0, PM1, PM2, and PM3.
- **VDD_MCU** – Cortex-M4F, RC32M digital and ADC/DAC/ACOMP digital control logic and the remainder of the 320 KB SRAM (Table 22), all AHB and APB peripherals and PINMUX are in this power domain. It is on in PM0, PM1, and PM2 power modes.
- **VDDIO_0** domain: GPIO_0 to GPIO_15
- **VDDIO_1** domain: GPIO_16 to GPIO_21
- **VDDIO_2** domain: GPIO_28 to GPIO_33
- **VDDIO_3** domain: GPIO_34 to GPIO_49, GPIO_27

Table 22: VDD_MCU Address Memory

<table>
<thead>
<tr>
<th>Flash</th>
<th>Code</th>
<th>SRAM</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x1F00_0000 to 0x1FFF_FFFF (16 MB)</td>
<td>0x0010_0000 to 0x0015_7FFF (384 KB)</td>
<td>0x2000_0000 to 0x2001_FFFF (64 KB)</td>
</tr>
</tbody>
</table>
3.2.3 I/O Power Configuration

The 88MW320/322 has configurable I/O domains. All domains support independent power-off functionality.

- VDDIO_0 domain: GPIO_0 to GPIO_15
- VDDIO_1 domain: GPIO_16 to GPIO_21
- VDDIO_2 domain: GPIO_28 to GPIO_33
- VDDIO_3 domain: GPIO_34 to GPIO_49, GPIO_27
- VDDIO_AON domain: GPIO_22 to GPIO_26, RESETn

Configuration is controlled by the PMU register, IO_PAD_PWR_CFG. See Section 24.20, PMU Address Block for a detailed description of the registers.

Table 23 shows the configurable options.

<table>
<thead>
<tr>
<th>I/O Power Domain</th>
<th>Corresponding GPIOs</th>
<th>Register Field</th>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDDIO_0</td>
<td>GPIO_0 to GPIO_15</td>
<td>PMU.IO_PAD_PWR_CFG.GPIO0_V18</td>
<td>0 (default)</td>
<td>1.8V/2.5V/3.3V</td>
</tr>
<tr>
<td>VDDIO_1</td>
<td>GPIO_16 to GPIO_21</td>
<td>PMU.IO_PAD_PWR_CFG.GPIO1_V18</td>
<td>0 (default)</td>
<td>1.8V/2.5V/3.3V</td>
</tr>
<tr>
<td>VDDIO_2</td>
<td>GPIO_28 to GPIO_33</td>
<td>PMU.IO_PAD_PWR_CFG.GPIO2_V18</td>
<td>0 (default)</td>
<td>1.8V/2.5V/3.3V</td>
</tr>
<tr>
<td>VDDIO_3</td>
<td>GPIO_34 to GPIO_49, GPIO_27</td>
<td>PMU.IO_PAD_PWR_CFG.GPIO3_V18</td>
<td>0 (default)</td>
<td>1.8V/2.5V/3.3V</td>
</tr>
<tr>
<td>VDDIO_AON</td>
<td>GPIO_22 to GPIO_26, RESETn</td>
<td>PMU.IO_PAD_PWR_CFG.GPIO_AON_V18</td>
<td>0 (default)</td>
<td>1.8V/2.5V/3.3V</td>
</tr>
</tbody>
</table>

Note: The real power supply to VDD_IOx_y power pin should match the corresponding configuration of the IO_PAD_PWR_CFG register.

After the 88MW320/322 is powered on, all I/O domains are turned on (controlled by IO_PAD_PWR_CONFIG.IO_PAD_PWR_CFG.IO_PAD_PWR_CFG.GPIO[domain].LOW_VDDB). The default I/O is applied to 3.3V (controlled by IO_PAD_PWR_CFG.IO_PAD_PWR_CFG.GPIO[domain].V18). The default pad regulator works in normal mode (controlled by IO_PAD_PWR_CFG.IO_PAD_PWR_CFG.IO_PAD_PWR_CFG.GPIO[domain].PDB).

Firmware could configure the power voltage of the corresponding I/O domain at any time to apply to different devices. Also, firmware could configure the corresponding domain, where the pad regulator is located in power-down mode to save power consumption.

Firmware must power on the I/O domain first before the I/O data transfer starts. The pad value is tri-stated before the I/O is powered on. In Sleep mode, or for power consumption savings, firmware must also power off the I/O domains before entering Sleep mode. Otherwise, the pad value is unknown.

Note: No matter the I/O function, the input level of I/O pins should not exceed the corresponding I/O domain power supply.
3.2.4 AON Domain

The PMU, RTC, ultra low-power comparator, brown-out detection logic, and 4K_MEM are in the AON domain. These modules can be powered in all power modes.

The PMU module manages the different power modes, power mode transition, and wake-up from low-power mode. The 4K_MEM is 4 KB-size SRAM and located from 0x480C_0000 memory space. Even in the lowest power mode, the content of 4K_MEM can be retained so it can be used to store critical application data. A 32-bit RTC is included in the AON domain.

See Section 9, Real Time Clock (RTC), on page 144 for a detailed description.

3.2.4.1 Ultra Low-Power Comparator

The low-power comparator can operate in differential mode and in single-ended mode.

In differential mode, COMP_IN_N (muxed with GPIO_24) and COMP_IN_P (muxed with GPIO_23) are compared to each other by the comparator. In single-ended mode, the comparator compares reference voltage GPIO_23 input. The reference voltage is controlled by the PMIP_CMP_CTRL.COMP_REF_SEL bit registers. When using the comparator in differential mode, both GPIO_24 and GPIO_23 have to be in hi-Z state. For single-ended mode, GPIO_23 must be in hi-Z state. It can generate an interrupt or wake-up, which is controlled by the PMIP_CMP_CTRL register.

3.2.4.2 Brown-out Detection

The 88MW320/322 contains VBAT brown-out detection circuits. It can generate a reset when a voltage supply is below a pre-set threshold. The Cortex-M4F core and all peripherals except the PMU and low-power comparator are reset by this event. The brown-out reset event is disabled by default. To enable this reset event, first program the PMIP_BRNDET_VBAT register to set the brown-out threshold and enable brown-out circuits, then set the brown-out PMU reset enable register, PMIP_BRN_CFG.

See Section 22.7.2, Brown-Out Detection (BOD) Specifications, on page 283 for electrical specifications.
3.3 Power Modes

3.3.1 System Power Modes

To optimize power consumption for different system configurations, the device can be set to different low-power modes by the PMU. Table 24 shows the system power modes and associated MCI and WLAN subsystem power states.

Table 24: System Power Modes

<table>
<thead>
<tr>
<th>Power Mode</th>
<th>Description</th>
<th>MCI Power State</th>
<th>WLAN Power State</th>
</tr>
</thead>
<tbody>
<tr>
<td>MW_PM00</td>
<td>PM0+WPM0</td>
<td>active</td>
<td>active</td>
</tr>
<tr>
<td>MW_PM01</td>
<td>PM0+WPM1</td>
<td>active</td>
<td>deep-sleep</td>
</tr>
<tr>
<td>MW_PM02</td>
<td>PM0+WPM2</td>
<td>active</td>
<td>WLAN shut-down</td>
</tr>
<tr>
<td>MW_PM10</td>
<td>PM1+WPM0</td>
<td>idle</td>
<td>active</td>
</tr>
<tr>
<td>MW_PM11</td>
<td>PM1+WPM1</td>
<td>idle</td>
<td>deep-sleep</td>
</tr>
<tr>
<td>MW_PM12</td>
<td>PM1+WPM2</td>
<td>idle</td>
<td>WLAN shut-down</td>
</tr>
<tr>
<td>MW_PM20</td>
<td>PM2+WPM0</td>
<td>standby</td>
<td>active</td>
</tr>
<tr>
<td>MW_PM21</td>
<td>PM2+WPM1</td>
<td>standby</td>
<td>deep-sleep</td>
</tr>
<tr>
<td>MW_PM22</td>
<td>PM2+WPM2</td>
<td>standby</td>
<td>WLAN shut-down</td>
</tr>
<tr>
<td>MW_PM30</td>
<td>PM3+WPM0</td>
<td>sleep</td>
<td>active</td>
</tr>
<tr>
<td>MW_PM31</td>
<td>PM3+WPM1</td>
<td>sleep</td>
<td>deep-sleep</td>
</tr>
<tr>
<td>MW_PM32</td>
<td>PM3+WPM2</td>
<td>sleep</td>
<td>WLAN shut-down</td>
</tr>
<tr>
<td>MW_PM40</td>
<td>PM4+WPM0</td>
<td>deep-sleep</td>
<td>active</td>
</tr>
<tr>
<td>MW_PM41</td>
<td>PM4+WPM1</td>
<td>deep-sleep</td>
<td>deep-sleep</td>
</tr>
<tr>
<td>MW_PM42</td>
<td>PM4+WPM2</td>
<td>deep-sleep</td>
<td>WLAN shut-down</td>
</tr>
<tr>
<td>MW_PM52</td>
<td>PM5+WPM2</td>
<td>shut-down</td>
<td>WLAN shut-down</td>
</tr>
</tbody>
</table>
3.3.2 MCI Subsystem Power Modes

Table 25 shows the MCI subsystem power modes.

**Table 25: MCI Subsystem Power Modes**

<table>
<thead>
<tr>
<th>Subsystem</th>
<th>PM0</th>
<th>PM1</th>
<th>PM2</th>
<th>PM3</th>
<th>PM4</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cortex-M4F</td>
<td>C0</td>
<td>C1</td>
<td>C2</td>
<td>C3</td>
<td>C3</td>
</tr>
<tr>
<td>SRAM</td>
<td>M0</td>
<td>M0</td>
<td>M2</td>
<td>M2&lt;sup&gt;1&lt;/sup&gt;</td>
<td>M3</td>
</tr>
<tr>
<td>Flash</td>
<td>active standby</td>
<td>active standby</td>
<td>power-down</td>
<td>off</td>
<td>off</td>
</tr>
<tr>
<td>RTC</td>
<td>on</td>
<td>on</td>
<td>on</td>
<td>on</td>
<td>on</td>
</tr>
<tr>
<td>Peripherals</td>
<td>on&lt;sup&gt;2&lt;/sup&gt;</td>
<td>on2</td>
<td>state retentive</td>
<td>off</td>
<td>off</td>
</tr>
<tr>
<td>XTAL</td>
<td>on/off</td>
<td>on/off</td>
<td>on/off</td>
<td>off</td>
<td>off</td>
</tr>
<tr>
<td>SFLL</td>
<td>on/off</td>
<td>on/off</td>
<td>off</td>
<td>off</td>
<td>off</td>
</tr>
<tr>
<td>AUPLL</td>
<td>on/off</td>
<td>on/off</td>
<td>off</td>
<td>off</td>
<td>off</td>
</tr>
</tbody>
</table>

1. All memories are in state retention mode in PM2 power state and 192 KB out of 512 KB of SRAM, plus 32 KB Flash memory will be in state retention mode in PM3 power mode. Table 26 shows the memory addresses in state retention mode in PM3.

2. When in PM0 and PM1 modes, functional clocks for peripherals can be shut off by programming the PMU.PERI_CLK_EN registers.

**Table 26: Address of Memories Available in State Retention Mode**

<table>
<thead>
<tr>
<th>Flash Memory</th>
<th>CODE</th>
<th>SRAM</th>
</tr>
</thead>
<tbody>
<tr>
<td>CODE</td>
<td>0x00000000 to 0x20000000 (32 KB)</td>
<td></td>
</tr>
<tr>
<td>CODE</td>
<td>0x00012_7FFF (160 KB)</td>
<td></td>
</tr>
<tr>
<td>CODE</td>
<td>0x20000000 to 0x20000000 (32 KB)</td>
<td></td>
</tr>
</tbody>
</table>

**3.3.2.1 PM0 – Active Mode**

The 88MW320/322 enters PM0 state upon the completion of the POR reset sequence and a wake-up from PM2, PM3, and PM4 states. When in PM0 state, all internal power domains and external power supplies may be fully powered and functional. Each peripheral function clocks can be gated off by programming the PMU clock enable registers.

**3.3.2.2 PM1 – Idle Mode**

In PM1 mode, the clock to the Cortex-M4F core is stopped. All other on-chip functions may continue operation in idle mode. The core can be quickly reactivated and resume execution by a generated interrupt.

Entering into the PM1 mode is performed by the Cortex-M4F core executing the WFI instruction with clearing the Cortex-M4F System Control Register SLEEPDEEP bit. The Cortex-M4F NVIC continues monitoring interrupts and wakes up the Cortex-M4F when an interrupt is detected.
### 3.3.2.3 PM2 – Standby Mode

The PM2 state offers lower power consumption by placing the Cortex-M4F core, most of the 88MW320/322 peripherals, and SRAM arrays in a low-power mode. In this mode, the core state and registers, peripheral registers, and internal SRAM values are preserved, and the state of the I/Os is kept. Flash memory is in PWDN mode. NXP recommends disabling BOD before entering PM2.

Entering into PM2 state is performed by writing PMU PWR_MODE registers to the PM2 state (01). The sequence for entering PM2 state is as follows:

1. Set Cortex-M4F System Control Register SLEEPDEEP bit.
2. Program PMU_CLK_SRC register to switch source clock to RC32M if system source clock is not RC32M.
3. Program PMU_SFLL_CTRL0 to disable PLLs and WLAN_CTRL registers to disable all 3 reference clock requests.
4. Turn I/O domains off.
5. Set PMU_PWR_MODE registers to PM2 state.
6. Execute WFI instruction.

Exiting the PM2 state occurs when the PMU detects any wake-up that is enabled before entering the PM2 state. The sequence is as follows:

1. PMU detects a wake-up event.
2. Cortex-M4F wakes up through interrupt.
3. If corresponding bit in NVIC is set, the ISR subroutine is executed.
4. Continue the instruction that follows WFI.

### 3.3.2.4 PM3 – Sleep Mode

In PM3 mode, all the power supplies except the power supplies for AON domain and Memory modules are turned off. RTC can be still running with a 32 kHz clock and 4K_MEM in AON domain is in retention mode. 192 KB SRAM is in Retention mode (see Table 26, Address of Memories Available in State Retention Mode, on page 53).

During this mode, all functional clocks except the RTC clock are gated off.

Wake-up from PM3 mode occurs by any of the wake-up sources in Table 30, Low-Power Mode Wake-Up Sources, on page 58.

NXP recommends disabling the BOD and ULP Comparator before entering PM3.

The system can be programmed to enter PM3 mode by programming the PMU_PWR_MODE.pwr_mode register to 2'b10. The sequence for entering PM3 state is as follows:

1. Set Cortex-M4F System Control Register SLEEPDEEP bit.
2. Program PMU_CLK_SRC register to switch source clock to RC32M if system source clock is not RC32M.
3. Program PMU_SFLL_CTRL0 to disable PLLs and WLAN_CTRL registers to disable all 3 reference clock requests.
4. Power off I/O domain (IO_PAD_PWR_CFG.POR_LVL_[domain]_LOW_VDDB_CORE) except AON domain to save power consumption and prevent IO pads entering unknown state, and power off the regulators of all IO domains (IO_PAD_PWR_CFG.VDD_[domain]_REG_PDB_CORE) to save power consumption as well.

**Note:** Exiting the PM3 state occurs when the PMU detects any wake-ups that are enabled before entering the PM3 state. The sequence is as follows:

a) PMU detects a wake-up event.
b) Cortex-M4F wakes up, and a Boot from SRAM occurs.
5. Software enables RC32 or XTAL32K if it is not enabled.
6. Set PMU_PWR_MODE registers to PM3 state.
7. Execute WFI instruction.

Exiting the PM3 state occurs when the PMU detects any wake-ups that are enabled before entering the PM3 state. The sequence is as follows:
1. PMU detects wake-up event.
2. Cortex-M4F wakes up and resets all except AON domain.

### 3.3.2.5 PM4 – Shutoff Mode

In PM4 mode, the power is shut off to the entire chip with the exception of the AON domain. RTC can still be running with a 32 kHz clock and 4K_MEM in retention mode.

Wake-up from PM4 mode occurs by any of the wake-up sources in Table 30, Low-Power Mode Wake-Up Sources, on page 58.

NXP suggests disabling the BOD and ULP Comparator before entering PM4.

Entering into the PM4 state is performed by writing the power mode registers to the PM4 state (2'b11). The sequence to enter the PM4 state is as follows:
1. Set Cortex-M4F System Control Register DEEPSLEEP bit.
2. Enable RC32K or XTAL32K clock if not already enabled.
3. Program PMU_CLK_SRC register to switch source clock to RC32M if system source clock is not RC32M.
4. Program PMU_SFLL_CTRL to disable PLLs and WLAN_CTRL registers to disable all 3 reference clock requests.
5. Power off all I/O domains (IO_PAD_PWR_CFG.POR_LVL_[domain]_LOW_VDDB_CORE) except AON domain to save power and prevent IO pads entering unknown state, and power off the regulators of all I/O domains (IO_PAD_PWR_CFG.VDD_[domain]_REG_PDB_CORE) to save power as well.
6. Set PMUPWR_MODE registers to the PM4 state.
7. Execute WFI instruction.

Exiting the PM4 state occurs when the PMU detects any wake-ups that are enabled before entering PM4 state. The sequence is as follows:
1. PMU detects a wake-up event.
2. Cortex-M4F wakes up and resets all except AON domain.
3.3.2.6 MCI Power Mode Transitions

Figure 12 shows the state machine for the MCI power mode state transitions.

Figure 12: Power Mode Transitions

3.3.3 WLAN Power States

3.3.3.1 WPM0 – Active

The WLAN enters WPM0 state when the WLAN feature is enabled from the WPM2 state or a wake-up from the WPM1 state. When in the WPM0 state, all internal power domains and external power supplies are fully powered and functional.

3.3.3.2 WPM1 – Deep Sleep

In WPM1 state, all power supplies, except the power supplies to the WLAN AON domains and memory modules, are turned off. Exiting WPM1 occurs when the MCI host wake-up interrupt or an internal WLAN beacon timer interrupt is received.

3.3.3.3 WPM2 – Shut Down

In WPM2 state, all power supplies are tuned off. Entering the WPM2 state is performed by writing the power mode register (PMU register from MCI). Exiting the WPM2 state occurs when this bit is de-asserted.
3.3.4 Core and SRAM Power States

In different power modes, the 88MW320/322 core and memory may be in different power states.

3.3.4.1 Cortex-M4F Core Power States

Table 27: Cortex-M4F Core Power States

<table>
<thead>
<tr>
<th>Cortex-M4F State</th>
<th>Definition</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>RUN (C0)</td>
<td>HCLK on, FCLK on</td>
<td>--</td>
</tr>
<tr>
<td>IDLE (C1)</td>
<td>HCLK off, FCLK on</td>
<td>--</td>
</tr>
<tr>
<td>STDBY (C2)</td>
<td>HCLK off, FCLK off</td>
<td>State retentive mode</td>
</tr>
<tr>
<td>OFF (C3)</td>
<td>Power is removed</td>
<td>--</td>
</tr>
</tbody>
</table>

3.3.4.2 Memory Power States

Table 28: SRAM Memory Power States

<table>
<thead>
<tr>
<th>SRAM State</th>
<th>Definition</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>RUN (M0)</td>
<td>CLK on</td>
<td>--</td>
</tr>
<tr>
<td>STDBY (M2)</td>
<td>PWDN</td>
<td>State retentive mode</td>
</tr>
<tr>
<td>OFF (M3)</td>
<td>Power is removed</td>
<td>--</td>
</tr>
</tbody>
</table>

Table 29: Flash Memory Power Modes

<table>
<thead>
<tr>
<th>Flash State</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>Active</td>
<td>Ready for access</td>
</tr>
<tr>
<td>STDBY</td>
<td>Chip select is de-asserted</td>
</tr>
<tr>
<td>PWDN</td>
<td>Leakage reduction mode</td>
</tr>
<tr>
<td>OFF</td>
<td>Power is removed</td>
</tr>
</tbody>
</table>
3.4  **Reset/Wake-up Sources**

3.4.1  **Wake-up from PM1 Mode**

Any enabled interrupt can wake up the core from Idle mode.

See Section 2.5, External Interrupts, on page 41 for a detailed list of all interrupts.

3.4.2  **Wake-up from PM2/3/4 Modes**

The 88MW320/322 supports internal and external wake-up sources when exiting from Standby or Sleep modes. Table 30 shows the sources.

The PMU supports both active-high and active-low wake-up from WAKE_UP0 and WAKE_UP1. It is programmed with the PMU WAKEUP_EDGE_DETECT registers.

See Section 24.20, PMU Address Block.

**Table 30: Low-Power Mode Wake-Up Sources**

<table>
<thead>
<tr>
<th>Source</th>
<th>PM2</th>
<th>PM3</th>
<th>PM4</th>
</tr>
</thead>
<tbody>
<tr>
<td>RTC</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>WAKE_UP0</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>WAKE_UP1</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>ULP_COMP</td>
<td>yes</td>
<td>yes</td>
<td>yes</td>
</tr>
</tbody>
</table>

3.4.3  **Reset Controller**

The 88MW320/322 has the following reset sources:

- Power-On Reset (POR) – PMU detects power supply ramping from 0 volt to VBAT voltage level. Entire SoC is reset in this event.
- 1 dedicated PIN reset – PMU detects a PIN reset. Entire SoC is reset in this event.
- Low-power mode exit reset – When PMU detects wake-up while in PM3 and PM4 modes, it resets Cortex-M4F core and all peripherals except for AON domain.
- Warm reset – Cortex-M4F core and all peripherals are reset except PMU, low-power comparator, and core debug logic:
  - Triggered when LOCKUP
  - PMIP brown-out reset – generated when voltage level of VBAT is detected as dropping below a pre-set threshold level (brown-out source must be enabled for it to function)
  - Cortex-M4F – triggered soft reset
  - WDT timeout
3.5 Clock Controller

3.5.1 Overview

The 88MW320/322 clock controller unit controls system source clock, clock frequencies for Cortex-M4F, AHB and APB bus clocks, and all peripheral function clocks. There are 4 different clock sources and 3 PLLs:

- MAINXTAL – External crystal oscillator (38.4 MHz)
- XTAL32K – External crystal oscillator 32.768 kHz
- RC32M – Internal RC32M
- RC32K – Internal RC32K
- SFLL – System PLL
- AUPLL – Audio PLL
- USB PLL

There are 2 external clock sources:

- 38.4 MHz crystal oscillator
- 32.768 kHz crystal oscillator

There are 2 internal RCs:

- 32 MHz (approximate) clock
- 32 kHz clock

There are 3 PLLs:

- SFLL
- AUPLL
- USB PLL

The SFLL generates a maximum of 200 MHz clock to support the Cortex-M4F core, AHB bus clocks, and most of the peripherals. Programmable dividers divide the 200 MHz clock to support all peripheral function clocks, as well as APB bus clocks. The AUPLL is used to generate clocks for audio and GAU (ADC/DAC/ACOMP). The USB PLL generates 480 MHz clock for the USB module.

Users can switch the clock source to internal the RC32M clock or the 38.4 MHz oscillator by programming the PMU clock source select registers for low performance applications. Dynamic source clock change is supported between RC32M and MAINXTAL or RC32M and SFLL. Switching source clocks between MAINXTAL and SFLL is not allowed, and vice versa. Users should always switch to RC32M first. All peripheral function clocks can be shut off by the peripheral clock enable registers when not used for the application.

Table 31 shows the clock sources. Table 32 shows the clock frequencies.

See Section 22.6.1, RC32K Specifications, on page 281 for electrical specifications.
### 3.5.2 Clock Sources

Table 31: Clock Sources

<table>
<thead>
<tr>
<th>Clock Name</th>
<th>Frequency (MHz)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAINXTAL</td>
<td>38.4</td>
<td>External crystal</td>
</tr>
<tr>
<td>XTAL32K</td>
<td>32.768 k</td>
<td>External crystal</td>
</tr>
<tr>
<td>RC32M</td>
<td>32 (±50%)</td>
<td>On-chip RC OSC, before calibration</td>
</tr>
<tr>
<td></td>
<td>32 (±1%)</td>
<td>On-chip RC OSC, after calibration</td>
</tr>
<tr>
<td>RC32K</td>
<td>32 k (±50%)</td>
<td>On-chip RC OSC, before calibration</td>
</tr>
<tr>
<td></td>
<td>32 k (±2%)</td>
<td>On-chip RC OSC, after calibration</td>
</tr>
<tr>
<td>SFLL</td>
<td>200</td>
<td>Output frequency is programmable</td>
</tr>
<tr>
<td>AUPLL</td>
<td>Audio bit clock</td>
<td>Output frequency is programmable</td>
</tr>
<tr>
<td>USB PLL</td>
<td>480</td>
<td>--</td>
</tr>
</tbody>
</table>
Figure 13: High-Level Clocking Diagram
### SFLL

SFLL is the main source clock for the fast system clock. The output frequency can be programmed by the PMU SFLL_CTRL0 and SFLL_CTRL1 registers.

\[
\text{SFLL output frequency} = \left( \frac{\text{reference clock frequency}}{\text{REFDIV}} \right) \times 2 \times \frac{\text{FBDIV}}{\text{POSTDIV}}
\]

### Table 32: Clock Frequency

<table>
<thead>
<tr>
<th>Module</th>
<th>Maximum Frequency (MHz)</th>
<th>Clock Source</th>
<th>Programmable Divider</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cortex-M4F HCLK</td>
<td>200</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>Cortex-M4F FCLK</td>
<td>200</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>AHB BUS</td>
<td>200</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>APB1 BUS</td>
<td>50</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>APB0 BUS</td>
<td>50</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>Memory</td>
<td>200</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>AES/CRC</td>
<td>200</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>USB</td>
<td>60</td>
<td>USB PLL</td>
<td>no</td>
</tr>
<tr>
<td>SSP</td>
<td>25</td>
<td>SFLL/AUPLL</td>
<td>yes</td>
</tr>
<tr>
<td>SSP Audio</td>
<td>24.587</td>
<td>AUPLL</td>
<td>yes</td>
</tr>
<tr>
<td>UART</td>
<td>58.9</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>GPT</td>
<td>50</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>RTC</td>
<td>32 kHz</td>
<td>OSC / RC32K</td>
<td>no</td>
</tr>
<tr>
<td>QSPI</td>
<td>50</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>I2C</td>
<td>100</td>
<td>SFLL</td>
<td>yes</td>
</tr>
<tr>
<td>GAU</td>
<td>programmable (up to 67 MHz)</td>
<td>AUPLL</td>
<td>yes</td>
</tr>
</tbody>
</table>
3.5.4 **Cortex-M4F Core Clock and Bus Clock**

The 88MW320/322 PMU clock control unit generates clocks for Cortex-M4 core, as well as AHB and APB bus clocks. All clocks are always from the same clock source. The core (HCLK, FCLK, and AHB) bus clocks are always running at the same frequency. The APB bus clock supports 1:1, 2:1, 4:1, and 8:1 divider ratios.

To select the source clock from RC32M, SFLL, and MAINXTAL program the PMU.CLK_SRC registers. Program the PMU.MCU_CORE_CLK_DIV register to divide the frequency from the source clock.

The APB bus clock divider ratio is controlled by the PMU.PERI1_CLK_DIV register.

Table 33 and Table 34 show the APB clock divider ratios for different values of the PMU.PERI1_CLK_DIV register bits.

**Table 33: APB0 Bus Clock Divider Ratio**

<table>
<thead>
<tr>
<th>PER1_CLK_DIV[17:16]</th>
<th>APB0 CLK Divider Ratio</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>1:1</td>
</tr>
<tr>
<td>01</td>
<td>2:1</td>
</tr>
<tr>
<td>10</td>
<td>4:1</td>
</tr>
<tr>
<td>11</td>
<td>8:1</td>
</tr>
</tbody>
</table>

**Table 34: APB1 Bus Clock Divider Ratio**

<table>
<thead>
<tr>
<th>PER1_CLK_DIV[19:17]</th>
<th>APB1 CLK Divider Ratio</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>1:1</td>
</tr>
<tr>
<td>01</td>
<td>2:1</td>
</tr>
<tr>
<td>10</td>
<td>4:1</td>
</tr>
<tr>
<td>11</td>
<td>8:1</td>
</tr>
</tbody>
</table>
3.5.5 UART Clocks

Select the UART frequency by the PMU.UART_CLK_SEL register. There are 2 programmable fractional dividers that generate the preferred UART clock frequencies. The fractional divisors are changed by programming the nominator and denominator fields in the PMU.UART_FAST_CLK_DIV and PMU.UART_SLOW_CLK_DIV registers based on source clock frequency, which is selected by the PMU.CLK_SRC register to obtain the preferred UART clock frequency.

Table 35 shows the programming.

Table 35: UART Slow and Fast Clock Programming

<table>
<thead>
<tr>
<th>UART_FAST_CLK_DIV, UART_SLOW_CLK_DIV</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit [10:0] denominator</td>
</tr>
<tr>
<td>Bit [23:11] numerator</td>
</tr>
</tbody>
</table>

The relation between source clock and output clock frequencies is as follows:

\[
\frac{\text{numerator}}{\text{denominator}} = \frac{\text{source clock}}{\text{output clock}}
\]

3.5.6 AUPLL for Audio Clock and GAU Clock

The 88MW320/322 has a dedicated AUPLL to generate the audio bit clock for the SSP module and to provide a low jitter GAU main clock. When the SSP works in I²S mode, the I²S audio clock can be from the AUPLL only. Program the FRACT field in PMU.AUPLL_CTRL0 and DIV_MCLK and DIV_FBCCLK fields in PMU.AUPLL_CTRL1 to obtain the necessary PLL VCO frequency.

Table 36 shows the VCO frequencies supported.

Table 36: VCO Frequency Select

<table>
<thead>
<tr>
<th>Master Clock (MHz)</th>
<th>DIV_MCLK Nmclk (integer/hex)</th>
<th>Fref (MHz)</th>
<th>DIV_FBCCLK Nfbc (integer/hex)</th>
<th>FRACT</th>
<th>Nfbc (effective)</th>
<th>Fvco (MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>38.4</td>
<td>10/0xA</td>
<td>3.84</td>
<td>35/0x23</td>
<td>0x08208</td>
<td>35.28</td>
<td>135.4752</td>
</tr>
<tr>
<td>38.4</td>
<td>10/0xA</td>
<td>3.84</td>
<td>38/0x26</td>
<td>0x0AAAA</td>
<td>38.4</td>
<td>147.4560</td>
</tr>
<tr>
<td>38.4</td>
<td>9/0x9</td>
<td>4.2667</td>
<td>31/0x1F</td>
<td>0xE54B</td>
<td>31.44</td>
<td>134.14</td>
</tr>
<tr>
<td>38.4</td>
<td>6/0x6</td>
<td>6.4</td>
<td>20/0x14</td>
<td>0x0</td>
<td>20</td>
<td>128</td>
</tr>
</tbody>
</table>

\[
Fref = \frac{\text{Master clock}}{\text{DIV_MCLK}}
\]

\[
Nfbc = \frac{\text{DIV_FBCCLK}}{(1 - \text{FRACT} / 4194304)}
\]

\[
Fvco = Fref \times Nfbc
\]

\[
Fout = Fvco / \text{POSTDIV}
\]
The AUPLL is disabled after POR. It is important to set the preferred parameters before setting the AUPLL power-up bit in the PMU.AUPLL_CTRL0 register.

### 3.5.7 GAU Clock

The AUPLL provides the GAU main clock (used for ADC, DAC, and ACOMP) to allow for a low jitter clock for high accuracy analog applications. See Table 36, VCO Frequency Select, on page 64 and Table 37, AUPLL Post Divider Programming, on page 65 for configuration.

Users can turn off this clock by the PMU GAU Clock Gate register.

<table>
<thead>
<tr>
<th>POSTDIV Divider Ratio</th>
<th>DIV_OCLK_MODULO[2:0]</th>
<th>DIV_OCLK_PATTERN[1:0]</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>011</td>
<td>00</td>
</tr>
<tr>
<td>2</td>
<td>101</td>
<td>00</td>
</tr>
<tr>
<td>4</td>
<td>000</td>
<td>00</td>
</tr>
<tr>
<td>6</td>
<td>001</td>
<td>01</td>
</tr>
<tr>
<td>8</td>
<td>001</td>
<td>00</td>
</tr>
<tr>
<td>9</td>
<td>001</td>
<td>10</td>
</tr>
<tr>
<td>12</td>
<td>010</td>
<td>01</td>
</tr>
<tr>
<td>16</td>
<td>010</td>
<td>00</td>
</tr>
<tr>
<td>18</td>
<td>010</td>
<td>10</td>
</tr>
<tr>
<td>24</td>
<td>100</td>
<td>01</td>
</tr>
<tr>
<td>36</td>
<td>100</td>
<td>10</td>
</tr>
<tr>
<td>48</td>
<td>110</td>
<td>01</td>
</tr>
<tr>
<td>72</td>
<td>110</td>
<td>10</td>
</tr>
</tbody>
</table>
3.5.8 GPT Clock

The PMU provides the clock source for the GPT. When the CLK_SRC bit in the CLK_CNTL register of the GPT is set to 0, the GPT selects the clock source from the PMU. To enable the GPTx clock, set the GPTx_CLK_EN bit in the PERI_CLK_EN register to 0. The GPT clock can be programmed to select from the following clocks by GPTx_CLK_SEL0 (x = 0, 1, 2, 3) and GPTx_CLK_SEL1 bits in the GPTx_CTRL register of PMU module:

- System clock
- RC32M
- MAINXTAL
- XTAL32K
- RC32K

The clock can be divided if the system clock/RC32M/MAINXTAL is selected. For GPT0, GPT1 and GPT2, the clock can be divided through the GPTx_CLK_DIV bits in the GPTx_CTRL register of PMU module (x = 0, 1, 2). For GPT3, the clock can be divided through GPT3_CLK_DIV_2_0 and GPT3_CLK_DIV_5_3 in the PERI2_CLK_DIV register.

3.5.8.1 GPT Sampling Clock

When GPT is in the input function, the PMU provides the sampling clock to GPT to sample input signals. The sampling clock source is the system clock, and it can be divided by the GPT_SAMPLE_CLK_DIV bits in the PERI2_CLK_DIV register.

3.5.9 Clock Output

XTAL32K/RC32K/RC32M/AUPLL/SFLL can be output through the corresponding GPIO pins.

See Section 6.2, I/O Configuration, on page 108 and Section 6.2.1, PINMUX Alternate Functions, on page 108 for details.

See Section 22.6, Clock Specifications, on page 281 for electrical specifications.

3.6 Register Description

See Section 24, 88MW320/322 Register Set for a detailed description of the registers.
4 Boot ROM

4.1 Overview
The 88MW320/322 Boot ROM is located in memory from 0x00 to 0x7FFF.

4.2 Features

4.2.1 Multiple Boot Sources
There are several boot source options based on the boot pin (GPIO_16 and GPIO_27) settings, including:
- QSPI Flash
- UART
- USB DISK
- USB DFU

4.2.2 Secure Boot
Encrypted and/or signed images stored in QSPI Flash may be used for a secure boot. On-board One Time Programmable (OTP) memory is used to store configuration flags, encryption keys, and so on. This allows for the ability to:
- Keep JTAG always disabled
- Boot encrypted image (using AES)
- Boot signed image (using RSA)
- Bypass the boot pins to boot from QSPI Flash
4.3 Boot Source Selection

Boot ROM is automatically activated by applying a reset.

Depending on the input value of the boot pin, either the Flash or a peripheral communication interface is selected as the boot interface.

Table 38 shows the boot pin configuration options. Also see Section 4.12.1, Boot ROM GPIOs, on page 97 for more Boot ROM GPIO information.

Table 38: Boot Pin Configuration

<table>
<thead>
<tr>
<th>Boot Pin1 Input Level (GPIO_16)</th>
<th>Boot Pin0 Input Level (GPIO_27)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>Load code image to SRAM from QSPI interface Flash</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>Load code image to SRAM from UART interface</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Load code image to SRAM/Flash from USB interface</td>
</tr>
</tbody>
</table>

Note: If errors occur when booting from the QSPI interface (GPIO_16 = 1, GPIO_27 = 1), the Boot ROM will automatically switch the boot source to the UART interface regardless of the input level of the boot pins.

4.4 OTP Content

Table 39 shows the OTP content.

Table 39: OTP Content

<table>
<thead>
<tr>
<th>Name</th>
<th>Purpose</th>
<th>Default Value</th>
<th>Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>security_flag</td>
<td>0 = JTAG enabled after boot and UART/USB slave boot without password 1 = JTAG never enabled after boot and UART/USB slave boot with password</td>
<td>0</td>
<td>1 bit</td>
</tr>
<tr>
<td>non_flash_boot</td>
<td>0 = UART/USB boot enabled 1 = UART/USB boot disabled</td>
<td>0</td>
<td>1 bit</td>
</tr>
<tr>
<td>encrypted_boot</td>
<td>0 = encrypted boot off 1 = encrypted boot on</td>
<td>0</td>
<td>1 bit</td>
</tr>
<tr>
<td>signed_boot</td>
<td>0 = signed boot off 1 = signed boot on</td>
<td>0</td>
<td>1 bit</td>
</tr>
<tr>
<td>aes_key / mainPassword</td>
<td>AES CCM* key / UART/USB slave boot password</td>
<td>All 0s</td>
<td>32 bytes</td>
</tr>
<tr>
<td>rsa_hash</td>
<td>SHA256 hash (of OEM's RSA public key)</td>
<td>All 0s</td>
<td>32 bytes</td>
</tr>
</tbody>
</table>
4.5  Data Format in AON Memory

The 88MW320/322 includes 4 KB (kilobyte) Always ON (AON) memory, which is located in 0x480C0000. This memory module belongs to the VDDIO_AON domain, so its data can be reserved in all power modes. The first 16 bytes of this memory area is used by Boot ROM.

Table 40 shows the data structure.

Table 40: AON Data Structure

<table>
<thead>
<tr>
<th>Offset Address</th>
<th>Size</th>
<th>Field Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00 to 0x03</td>
<td>32 bits</td>
<td>pm3EntryAddr</td>
<td>Address of Entry Function for PM3 Mode Wake-up Needs to be written by software before going into PM3 state.</td>
</tr>
<tr>
<td>0x04 to 0x07</td>
<td>32 bits</td>
<td>bootMode</td>
<td>Select Boot Mode Written by Boot ROM.</td>
</tr>
<tr>
<td>0x08 to 0x0B</td>
<td>32 bits</td>
<td>powerMode</td>
<td>Store Power Mode Status Indicates which low-power mode MCU just exited. Written by Boot ROM.</td>
</tr>
<tr>
<td>0x0C to 0x0F</td>
<td>32 bits</td>
<td>errorCode</td>
<td>Boot ROM Error Code Storage Written by Boot ROM.</td>
</tr>
</tbody>
</table>

Table 41 shows the bootMode sub-field.

Table 41: Sub-Field in bootMode

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td>1:0</td>
<td>bootMode</td>
<td>Boot Mode 0x00 = boot from UART 0x01 = reserved 0x10 = boot from USB 0x11 = boot from QSPI Flash</td>
</tr>
</tbody>
</table>

Table 42 shows the powerMode sub-field.

Table 42: Sub-Field in powerMode

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td>1:0</td>
<td>powerMode</td>
<td>Power Mode</td>
</tr>
</tbody>
</table>
Table 43 shows the errorCode sub-field.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:20</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>aesTimeOut</td>
<td>AES Timeout Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = AES timeout error</td>
</tr>
<tr>
<td>18</td>
<td>loadImageFail</td>
<td>Load Image Fail</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = Flash load image fail</td>
</tr>
<tr>
<td>17</td>
<td>secHeaderFail</td>
<td>Section Header Fail</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = load section header fail</td>
</tr>
<tr>
<td>16</td>
<td>magicCodeErr</td>
<td>Magic Code Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = magic code in bootInfo header check fail</td>
</tr>
<tr>
<td>15</td>
<td>MicError</td>
<td>MIC Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = decryption failure (MIC mismatch at end of decryption)</td>
</tr>
<tr>
<td>14</td>
<td>imageLenErr</td>
<td>Image Length Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = encrypted image not present in Flash (length field all 0s)</td>
</tr>
<tr>
<td>13</td>
<td>aesKeyCrcErr</td>
<td>AES Key CRC Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = CRC mismatch for 256-bit AES key in OTP</td>
</tr>
<tr>
<td>12</td>
<td>aesKeyflag</td>
<td>AES Key Flag</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = AES key present in OTP</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = AES key not present in OTP</td>
</tr>
<tr>
<td>11:10</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>sigFail</td>
<td>Signature Fail</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = signature verification fail</td>
</tr>
<tr>
<td>8</td>
<td>digSigFlag</td>
<td>Digital Signature Flag</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = digital signature not present in Flash (all 0s)</td>
</tr>
<tr>
<td>7</td>
<td>pubKeyErr</td>
<td>Public Key Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = hash public key in Flash does not match key stored in OTP</td>
</tr>
<tr>
<td>6</td>
<td>pubKeyFlag</td>
<td>Public Key Flag</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = no error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = public key not present in Flash (all 0s)</td>
</tr>
</tbody>
</table>
## Table 43: Sub-Field in errorCode (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Description</th>
</tr>
</thead>
</table>
| 5    | pubKeyCrcErr   | Public Key CRC Error  
|      |                | 0 = no error  
|      |                | 1 = CRC mismatch for hash of RSA public key in OTP |
| 4    | pubKeyHashFlag | Public Key Hash Flag  
|      |                | 0 = RSA public key hash present in OTP  
|      |                | 1 = RSA public key hash not present in OTP |
| 3    | aesKeyErr      | AES Key Error  
|      |                | 0 = no error  
|      |                | 1 = length of AES key error |
| 2    | pubKeyHashErr  | Public Key Hash Error  
|      |                | 0 = no error  
|      |                | 1 = length of RSA public key hash error |
| 1    | flashAccessFail| Flash Access Fail  
|      |                | 0 = no error  
|      |                | 1 = Flash not accessible |
| 0    | otpAccessFail  | OTP Access Fail  
|      |                | 0 = no error  
|      |                | 1 = OTP not accessible |
4.6 Boot ROM Flow Charts

4.6.1 POR Reset

Figure 14: Boot ROM Flow, POR Reset

POR RESET
RC32M ready
Reset Deassertion

Read PWR_MODE_STATUS register

PM3 mode?

Y

Load PM3 entry point from AON RAM

Jump to entry point

security_flag == 1?

Y

Open JTAG

N

non_Flash_boot == 0?

Y

QSPI loading

N

Code loading
4.6.2 Code Loading

Figure 15: Boot ROM Flow, Code Loading

- **Y (cold Boot)**: Read bootMode from pin-strap
  - Store value into memory 0x480C_0004
  - Load bootMode from memory 0x480C_0004

- **N (wake-up from PM4)**: Switch on bootMode
  - 10: USB loading
  - 11: QSPI loading
  - 00: UART loading
4.6.3 QSPI Loading

Figure 16: Boot ROM Flow, QSPI Loading

- **QSPI loading**
- Init QSPI for Flash reading
- Read from the beginning of Flash
- Read Flash Succ?
  - Yes: Load publicKey, Digital signature, Length of encrypted image, Nonce
  - No: sysErr = FLASH_ACCESS_FAIL
- Boot mode confirmed to be QSPI loading
- sysException
4.6.4 Boot Mode Confirmed to be QSPI Loading

Figure 17: Boot ROM Flow, Boot Mode Confirmed to be QSPI Loading

Note: The step "Decrypt and Check the image", the ciphertext is in Flash, and the decrypted plaintext is in SRAM.

The step "Verify TIM while loading it into RAM", means loading the code from Flash into SRAM. If the image is signed, it will verify the signature for TIM. Otherwise, it will copy the code without signature verification.

"Signed_Boot" and "Encrypted_Boot" are 2 independent Boot options in OTP memory.
4.6.5 Normal Boot

Figure 18: Boot ROM Flow, Normal Boot

```
Normal Boot
  \|-- Handle BootInfo header
      \|-- BOOTINFO_FAIL
        \|-- Handle Section header
            \|-- SECHDR_FAIL
                \|-- SUCC
                    \|-- Jump to entry point
                        \|-- sysException
```

4.6.6 System Exception

Figure 19: Boot ROM Flow, System Exception

```
sysException
  \|-- Write Error Code to 0x480C_000C
      \|-- Non_Flash_Boot == 0?
          \|-- Y
              \|-- UART loading
          \|-- N
              \|-- Infinite loop
```
4.6.7 UART Loading

Figure 20: Boot ROM Flow, UART Loading

- UART loading
- UART auto baud rate detection OK?
- UART0 setup
- Send detection ACK
- security_flag == 1?
- Load image from UART to SRAM
- Valid code?
- Jump to pre-defined entry point
- Exception
- Read choice via UART
  - Choice = ?
  - Erase Flash
  - Enter password
  - Password ok?
  - Open JTAG connection
  - Exceed maximum retry?
  - Erase Flash
  - Stop
- Password
- Else
- Stop
Note: The maximum value of "Exceed maximum retry" is 10, and the retry counter will reset when power ON or hardware reset.

If the password is verified as correct, the image can be loaded from the UART path. Meanwhile, JTAG is available for debug or re-Flash operation.

"Erase Flash" erases the entire Flash against hacking attempts.

4.6.8 USB Slave Loading

Figure 21: Boot ROM Flow, USB Loading as Slave
4.6.9 USB Host Loading

Figure 22: Boot ROM Flow, USB Loading as Host
4.7 Boot from QSPI Flash

4.7.1 Code Image

The code image is in binary, which is generated by the Cortex-M4 tool chain, for example, ARM RVCT or IAR compiler and linker. A code image can be loaded into the space from:

- 0x10_0000 to 0x15_7FFF through the DBus
- 0x2000_0000 to 0x2001_FFFF through the system bus
- 32 K optional Flash_SRAM memory

It is not suggested to load all code images using Boot ROM. Instead, Boot ROM can load a boot loader into RAM and launch it to perform more sophisticated boot loading tasks.

The memory space from 0x2000_0000 to 0x2000_5657 is occupied by Boot ROM as the STACK and data sections. When Boot ROM starts upon reset, it will initialize this memory space.

Table 44 shows the memory usage.

<table>
<thead>
<tr>
<th>Address</th>
<th>Usage</th>
<th>Occupied by Boot ROM when Wake-up from PM3</th>
<th>Occupied by Boot ROM when Wake-up from PM4 or on POR</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x2000_0000–0x2000_0039 0x2000_1000–0x2000_2656</td>
<td>data</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>0x2000_2658–0x2000_5657</td>
<td>heap</td>
<td>no</td>
<td>yes</td>
</tr>
<tr>
<td>0x2000_0040–0x2000_0FFF</td>
<td>stack</td>
<td>yes</td>
<td>yes</td>
</tr>
</tbody>
</table>

The user’s code sections (excluding the data sections) should not cover this region. Otherwise, it may flush the Boot ROM STACK and data and cause errors.
4.7.2 Code Image Format

The format of the code image consists of:

- OEM public key—always located at the beginning of the image
- Digital signature
- Length of encrypted image
- Boot header (comprised of bootInfoHeader and SectionHeader)—includes important information employed during SoC boot
- User data—immediately follows SectionHeader; includes primary firmware code (PFC, containing OS and driver) and possible customer applications

MIC

For QSPI boot, all the fields are valid.

For USB boot, only the boot header and user data are valid. All other fields are reserved.

Figure 23 shows a code image format.

**Figure 23: Code Image Memory Mapping**

<table>
<thead>
<tr>
<th>MIC</th>
</tr>
</thead>
<tbody>
<tr>
<td>User data</td>
</tr>
<tr>
<td>SectionHeader</td>
</tr>
<tr>
<td>BootInfoHeader</td>
</tr>
<tr>
<td>Nonce</td>
</tr>
<tr>
<td>Length of encrypted image</td>
</tr>
<tr>
<td>Digital signature</td>
</tr>
<tr>
<td>OEM public key</td>
</tr>
</tbody>
</table>

0x0000_0000
Table 45 shows a code image format. All fields are little endian.

**Table 45: Code Image Fields**

<table>
<thead>
<tr>
<th>Section Name</th>
<th>Address</th>
<th>Size</th>
<th>Field Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>OEM public key</td>
<td>0x00 to 0x125</td>
<td>294 bytes</td>
<td>publicKey</td>
<td>OEM Public Key for Digital Signature This field is only valid for QSPI boot when signedflag = 1.</td>
</tr>
<tr>
<td>Digital signature</td>
<td>0x126 to 0x225</td>
<td>256 bytes</td>
<td>Digital signature</td>
<td>Digital Signature for Hash of bootinfo header, sectionheader, and Code Image (includes the 4-byte CRC check field) This field is only valid for QSPI boot when signedflag = 1.</td>
</tr>
<tr>
<td>Length of encrypted image</td>
<td>0x226 to 0x229</td>
<td>4 bytes</td>
<td>Length of encrypted image</td>
<td>Length of Encrypted Image Includes the length of the bootInfo Header, section Header and Code image (includes 4-byte CRC field). This field is only valid for QSPI boot when encryptedFlag = 1.</td>
</tr>
<tr>
<td>Nonce(IV)</td>
<td>0x22A to 0x239</td>
<td>16 bytes</td>
<td>Nonce</td>
<td>Nonce of AES Decryption This field is only valid for QSPI boot when encryptedFlag = 1.</td>
</tr>
</tbody>
</table>
### Table 45: Code Image Fields (Continued)

<table>
<thead>
<tr>
<th>Section Name</th>
<th>Address</th>
<th>Size</th>
<th>Field Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>bootInfoHeader</td>
<td>0x23A</td>
<td>32 bits</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x23E</td>
<td>32 bits</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x242</td>
<td>32 bits</td>
<td>commonCfg0</td>
<td>Common Configuration 0</td>
</tr>
<tr>
<td></td>
<td>0x246</td>
<td>32 bits</td>
<td>magicCode</td>
<td>Magic Code 0x4D52564C (MRVL) means the code image is valid. Otherwise, Boot ROM regards this image as invalid.</td>
</tr>
<tr>
<td></td>
<td>0x24A</td>
<td>32 bits</td>
<td>entryAddr</td>
<td>Address of Entry Function</td>
</tr>
<tr>
<td></td>
<td>0x24E</td>
<td>32 bits</td>
<td>sfllCfg</td>
<td>Configure Frequency of SPLL</td>
</tr>
<tr>
<td></td>
<td>0x252</td>
<td>32 bits</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x256</td>
<td>32 bits</td>
<td>flashcCfg0</td>
<td>Flash Controller Configuration0 This field is ignored if encryptedFlag = 1 or signedflag = 1 or boot from USB.</td>
</tr>
<tr>
<td></td>
<td>0x25A</td>
<td>32 bits</td>
<td>flashcCfg1</td>
<td>Flash Controller Configuration1 This field is ignored if encryptedFlag = 1 or signedflag = 1 or boot from USB.</td>
</tr>
<tr>
<td></td>
<td>0x25E</td>
<td>32 bits</td>
<td>flashcCfg2</td>
<td>Flash Controller Configuration2 This field is ignored if encryptedFlag = 1 or signedflag = 1.</td>
</tr>
<tr>
<td></td>
<td>0x262</td>
<td>32 bits</td>
<td>flashcCfg3</td>
<td>Flash Controller Configuration3 Flash Address Offset value. Default value is 0x0. When flashcCfg0.flashOffsetEn =1 then this register specifies the address offset from Flash base address that is used for all Flash memory accesses. This field is ignored if encryptedFlag = 1 or signedflag = 1 or boot from USB.</td>
</tr>
<tr>
<td></td>
<td>0x266 to 0x285</td>
<td>32 bytes</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x286</td>
<td>32 bits</td>
<td>CRCCheck</td>
<td>CRC Check for bootInfoHeader Boot ROM will calculate a CRC value on this bootInfoHeader (excluding CRCCheck) with CRC mode CRC-16-CCITT. If the calculated CRC value matches CRCCheck, then CRC checking passes. The 16-bit CRC value is stored in the lowest 2 bytes (0x286-0x287) of this field. The highest 2 bytes (0x288-0x289) are always 0.</td>
</tr>
<tr>
<td>Section Name</td>
<td>Address</td>
<td>Size</td>
<td>Field Name</td>
<td>Description</td>
</tr>
<tr>
<td>---------------</td>
<td>---------</td>
<td>------</td>
<td>-------------</td>
<td>------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Section Header</td>
<td>0x28A</td>
<td>32 bits</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x28E</td>
<td>32 bits</td>
<td>codeLen</td>
<td>Code Length</td>
</tr>
<tr>
<td></td>
<td>0x292</td>
<td>32 bits</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x296</td>
<td>32 bits</td>
<td>destStartAddr</td>
<td>Start Address in SRAM where PFC is Loaded To</td>
</tr>
<tr>
<td></td>
<td>0x29A</td>
<td>32 bits</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x29E</td>
<td>32 bits</td>
<td>bootCfg0</td>
<td>Boot Configuration 0</td>
</tr>
<tr>
<td></td>
<td>0x2A2</td>
<td>32 bits</td>
<td>bootCfg1</td>
<td>Boot Configuration 1</td>
</tr>
<tr>
<td></td>
<td>0x286 to 0x2B5</td>
<td>16 bytes</td>
<td>n/a</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>0x2B6</td>
<td>32 bits</td>
<td>CRCCheck</td>
<td>CRC Check for sectionHeader Boot ROM will calculate a CRC value on this</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>sectionHeader (excluding CRCCheck) with CRC mode CRC-16-CCITT. If the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>calculated CRC value matches CRCCheck, then CRC checking passes. The 16-bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CRC value is stored in the lowest 2 bytes of this field. The highest 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>bytes are always 0.</td>
</tr>
<tr>
<td>Code image</td>
<td>0x2BA</td>
<td>Decided by code of user</td>
<td>Code image</td>
<td>Image to be Executed</td>
</tr>
<tr>
<td>MIC</td>
<td>After code image of user</td>
<td>128 bits</td>
<td>MIC</td>
<td>MIC of AES Decryption, Authentication Using AES-CCM</td>
</tr>
</tbody>
</table>
### Table 46: Sub-Field in commonCfg0

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:23</td>
<td>n/a</td>
<td>All 1’s</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 22:18 | flashIntPrescaler| 5'b00100/5'b0001 | Flash Interface Module (QSPI and FlashC) Clock Prescaler  
The default value of this field is related to the clock source.  
If the clock source is PLL, the default value of this field is 5'b00100.  
Otherwise, it is 5'b00001.  |
| 17    | flashIntPrescalerOff | 1         | Prescaler Select  
0 = use flashIntPrescaler  
1 = use default prescaler                                                                 |
| 16:10 | n/a              | All 1’s   | Reserved                                                                                                                                  |
| 9:8   | clockSel         | 2'b11     | Set System Clock Source  
00 = use SFLL_200M for system clock; SFLL reference clock is MAINXTAL  
01 = use SFLL_200M for system clock; SFLL reference clock is RC32M  
10 = use MAINXTAL for system clock  
11 = use RC32M for system clock                                                                 |
| 7:1   | n/a              | All 1’s   | Reserved                                                                                                                                  |
| 0     | dmaEn            | 1         | DMA Enable  
0 = do not use DMA when loading code to SRAM  
1 = enable DMA when loading code to SRAM  
This field is ignored if encryptedFlag = 1 or signedflag = 1 or boot from USB.    |

### Table 47: Sub-Field in sfllCfg

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:25</td>
<td>n/a</td>
<td>All 1’s</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 24:16 | sfllRefdiv       | 0x60 / 0x50| Reference Divider  
Default value is 0x50 when reference clock is RC32M.  
Default value is 0x60 when reference clock is MAINXTAL.                                                                 |
| 15:7  | sfllFbddiv       | 0xF0      | Feedback Divider                                                                                                                            |
| 6:1   | n/a              | All 1’s   | Reserved                                                                                                                                  |
| 0     | sfllCfgOff       | 1         | SFLL Configuration  
0 = use configuration in sfllCfg  
1 = use default SFLL configuration                                                                 |
# Table 48: Sub-Field in flashcCfg0

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31   | flashCcfgOff   | 1       | Flash Controller Configuration  
|      |                |         | 0 = use configuration in flashCcfg0, flashCcfg1, flashCcfg2, flashCcfg3  
|      |                |         | 1 = use default Flash Controller configuration |
| 30   | flashCacheEn   | 1       | Enable Cache Mode  
|      |                |         | Controls whether the read data from the Flash device is cached or not.  
|      |                |         | 0 = read Data from Flash does not use the Flash cache  
|      |                |         | 1 = read data from Flash through the Flash cache |
| 29:24| n/a            | All 1's | Reserved |
| 23   | flashOffsetEn  | 0       | Address Offset Enable  
|      |                |         | 0 = all Flash Memory accesses do not use Address Offset  
|      |                |         | 1 = using Address Offset defined in flashCcfg3 is enabled for all Flash memory accesses |
| 22:21| flashClkOutDly | 2'b00   | Add Delay on Outgoing Clock to Flash |
| 20   | flashCapEdge   | 0       | Serial Interface Data Capture Clock Edge  
|      |                |         | Capture serial interface input data on either the rising or falling edge of the serial interface clock. This bit is used to allow more time to capture the input data. |
| 19:18| flashClkInDly  | 2'b01   | Add delay on the Clock that the front end flip flops that capture read data from Flash |
| 17:16| flashDataDly   | 2'b01   | Add delay on Incoming Data from Flash  
|      |                |         | This needs to be used to tune the timing of the data capture inside the Flash Controller. |
| 15   | flashClkPha    | 0       | Serial Interface Clock Phase  
|      |                |         | Selects the serial interface clock phase.  
|      |                |         | 0 = data is captured on the rising edge of the serial clock when flashClkPol =0 and on the falling edge when CLK_POL=1  
|      |                |         | 1 = data is captured on the falling edge of the serial clock when flashClkPol =0 and on the rising edge when CLK_POL=1 |
| 14   | flashClkPol    | 0       | Serial Interface Clock Polarity  
|      |                |         | Selects the serial interface clock as HIGH or LOW when inactive.  
|      |                |         | 0 = serial Interface clock is LOW when inactive  
|      |                |         | 1 = serial Interface clock is HIGH when inactive |
| 13:4 | n/a            | all 1's | Reserved |
### Table 48: Sub-Field in flashCfg0 (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
</table>
| 3:0    | flashCmdType     | 4'b0101    | Serial Flash Command Type  
The Flash Controller will automatically build the necessary Instruction, followed by Address, dummy clocks etc., based on this Command Type field for Winbond devices.  
0x0 = read data  
0x1 = fast read  
0x2 = fast read dual output  
0x3 = fast read quad output  
0x4 = fast read dual I/O  
0x5 = fast read dual I/O with continuous read mode  
0x6 = fast read quad I/O  
0x7 = fast read quad I/O with continuous read mode  
0x8 = word read quad I/O  
0x9 = word read quad I/O with continuous read mode  
0xA = octal word read quad I/O  
0xB = octal word read quad I/O with continuous read mode  
Others = reserved |

### Table 49: Sub-Field in flashCfg1

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31     | flashUseCfgOvrd  | 0       | Use Configuration Override  
This bit when set by software, overrides the built-in hardware Flash transfer generation defined through flashCfg0.flashCmdType. Software has control over Instruction, Address, and other configuration. Software needs to program all the necessary fields in FCCR2 to successfully complete a transfer to Flash.  
0 = use flashCfg0.flashCmdType to determine/build Flash command/transfer  
1 = use flashCfg1 and flashCfg2 to determine/build Flash Command/transfer |
| 30:29  | flashDataPin     | 0x0     | Data Transfer Pins  
Number of pins used to transfer data.  
0x0 = use 1 pin for data  
0x1 = use 2 pins for data  
0x2 = use 4 pins for data  
0x3 = reserved |
| 28     | flashAddrPin     | 0x0     | Address Transfer Pins  
Number of pins used to transfer the Flash address.  
0 = use 1 pin  
1 = use number of pins as indicated by DATA_PIN field in this register |
| 27     | flashByteLen     | 0x0     | Byte Length  
Number of bytes in each serial transfer.  
0 = 1 byte  
1 = 4 bytes |
| 26:14  | n/a              | All 1’s  | Reserved |
### Table 49: Sub-Field in flashCfg1 (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13:12</td>
<td>flashcDummyCnt</td>
<td>0x0</td>
<td>Dummy Count&lt;br&gt;Defines the number of dummy bytes that need to be sent to Flash. The data shifted out is always 0.&lt;br&gt;0x0 = 0 bytes&lt;br&gt;0x1 = 1 byte&lt;br&gt;0x2 = 2 bytes&lt;br&gt;0x3 = reserved</td>
</tr>
<tr>
<td>11:10</td>
<td>n/a</td>
<td>All 1's</td>
<td>Reserved</td>
</tr>
<tr>
<td>9:8</td>
<td>flashcRmCnt</td>
<td>0x0</td>
<td>Read Mode Count&lt;br&gt;Number of Read Mode bytes (as defined in flashCfg2.flashRdmode) that are sent out to Flash.&lt;br&gt;0x0 = 0 bytes&lt;br&gt;0x1 = 1 byte&lt;br&gt;0x2 = 2 bytes&lt;br&gt;0x3 = reserved</td>
</tr>
<tr>
<td>7</td>
<td>n/a</td>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>6:4</td>
<td>flashcAddrCnt</td>
<td>0x0</td>
<td>Address Count&lt;br&gt;Number of bytes of address that is sent to Flash.&lt;br&gt;0x0 = 0 bytes&lt;br&gt;0x1 = 1 byte&lt;br&gt;0x2 = 2 bytes&lt;br&gt;0x3 = 3 bytes&lt;br&gt;0x4 = 4 bytes&lt;br&gt;Others = reserved</td>
</tr>
<tr>
<td>3:2</td>
<td>n/a</td>
<td>All 1's</td>
<td>Reserved</td>
</tr>
<tr>
<td>1:0</td>
<td>flashcInstrCnt</td>
<td>0x0</td>
<td>Instruction Count&lt;br&gt;Number of bytes of Instruction (defined in flashCfg2.flashInstr) to send to Flash.&lt;br&gt;0x0 = 0 bytes&lt;br&gt;0x1 = 1 byte&lt;br&gt;0x2 = 2 bytes&lt;br&gt;0x3 = reserved</td>
</tr>
</tbody>
</table>
### Table 50: Sub-Field in flashCfg2

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:16 | flashRdmode    | 0x0     | Flash Read Mode  
Determined the Read Mode information that gets sent to the Flash device after Address cycle.  
When flashCfg1.flashRmCnt =0, this register content is not sent out.  
When flashCfg1.flashRmCnt = 1, bits [7:0] of this register are sent out.  
When flashCfg1.flashRmCnt =2, bits [15:8] of this register are sent out first followed by bits [7:0]. |
| 15:0  | flashInstr     | 0x0     | Flash Instruction  
The contents of this register define the instruction Op code that gets sent to the Flash device.  
When flashCfg1.flashInstrCnt =0, this register content is not sent out.  
When flashCfg1.flashInstrCnt =1, bits [7:0] of this register are sent out.  
When flashCfg1.flashInstrCnt =2, bits [15:8] of this register are sent out first followed by bits [7:0]. |

### Table 51: Sub-Field in bootCfg0

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31    | emptyCfg       | 1       | emptyCfg  
0 = bootCfg1 is applied  
1 = bootCfg1 is ignored |
| 30:0  | n/a            | All 1's | Reserved |

### Table 52: Sub-Field in bootCfg1

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:21</td>
<td>n/a</td>
<td>All 1's</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 20    | flashOff       | 1       | Decide Whether to Enable Flash Controller to Support XIP  
This field is valid only when encryptedFlag = 0 and signedFlag = 0 and boot from QSPI.  
0 = enable Flash Controller and XIP is supported  
1 = disable Flash Controller and code cannot be executed directly in Flash |
| 19:16 | n/a            | All 1's | Reserved |
| 15    | flashProgMode  | 0       | Decide internal Flash Program Mode  
This field is valid only for USB host boot.  
0 = internal Flash normal page program  
1 = internal Flash quad page program |
| 14    | locationMode   | 0       | Decide Load Code Image to SRAM or Internal Flash  
This field is valid only for USB host boot.  
0 = load code to SRAM  
1 = load code to Flash |
### Table 52: Sub-Field in bootCfg1 (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Sub-Field Name</th>
<th>Default</th>
<th>Description</th>
</tr>
</thead>
</table>
| 13   | LEDEnable      | 1       | LED Enable  
This field is valid only for USB host boot. 
If locationMode = 1, this bit can decide if LED is on after copying code to internal Flash. 
0 = no pulse is on GPIO_16 
1 = GPIO_16 outputs a pulse after copying code to internal Flash. If connect a LED to GPIO_16, it can indicate when the code loading is finished. |
| 12:9 | n/a            | All 1's | Reserved    |
| 8:6  | flashReadMode  | 3'b000  | Flash Read Mode 
3'b000 = normal read mode 
3'b001 = fast read mode 
3'b010 = fast read dual out mode 
3'b011 = fast read quad out mode 
Others = normal read mode |
| 5:1  | n/a            | All 1's | Reserved    |
| 0    | sramModeEn     | 0       | 32 KB FLASH_SRAM Mode Enable 
This field is valid only for the first section header in the section chain. 
Controls whether the 32 KB optional memory is used as Flash Cache or SRAM. This field is corresponding to the register FCCR.SRAM_MODE_EN, which is in the Flash Controller module. 
0 = use the 32 KB memory as Flash Cache 
1 = use the 32 KB memory as SRAM 
flashcCacheEn needs to be '0' when sramModeEn =1 
flashcCacheEn and sramModeEn can not be set to '1' at the same time |

### Table 53: User Data Format

<table>
<thead>
<tr>
<th>Byte</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>...</th>
<th>codeLen-1</th>
<th>codeLen</th>
<th>codeLen+1</th>
<th>codeLen+2</th>
<th>codeLen+3</th>
</tr>
</thead>
</table>
| content | User data | | | | | | | | | CRC Signature for User Data with CRC Mode CRC-16-CCITT 
For 16-bit CRC mode, the lowest 2 bytes are valid. The highest 2 bytes are always 0. If encrypted mode is enable, CRC is not calculated, and this field is reserved. |
4.8 Boot from UART

When UART is selected as the boot interface, code can be loaded through UART. This section shows the Boot ROM UART download protocol and UART packet format.

See Section 4.12.3, Sample of Code Loading Through UART, on page 101 for an example of loading code through UART, which is based on this download protocol.

Terms used are as follows:
- Host—external device with UART interface
- Device—88MW320/322

The basic download process is as follows:
1. Host sends detection byte until Device acknowledges it.

Figure 24 shows the Detection and Detection Acknowledgment (ACK) packets.

**Figure 24: Detection and Detection Acknowledgment Packets**

<table>
<thead>
<tr>
<th>Host Detection</th>
<th>0x55</th>
</tr>
</thead>
<tbody>
<tr>
<td>Device Detection Acknowledgment</td>
<td>Version (4 bytes)</td>
</tr>
</tbody>
</table>

Version = version number of Boot ROM

ACK:
- 0xA3 = detection return without password request
- 0xAC = detection return with password request for security mode

A Detection packet is sent by the Host. A Detection Acknowledge packet is sent by the Device.

Since the Device needs time to process the detection packet from the Host, the Host should provide an interval before sending out the next detection byte when not receiving a Device Detection Acknowledgment. The recommended interval is 10 ms or more.

There are 2 kinds of ACKs from the Device, 0xA3 and 0xAC.
- If the security_flag in the OTP is not set, the device will return 0xA3 as acknowledgment.
- If the security_flag in the OTP is set, the device will return 0xAC indicating that the user needs to input a password for further operation.

Alternatively, the user can select to erase all Flash content.
1. If the ACK field of the Detection Acknowledgment packet is 0xAC, Host sends a Security or Erase packet. If the ACK field of the Detection Acknowledgment packet is 0xA3, go to Step3. Figure 25 shows the Security/Erase and acknowledgment packets.

**Figure 25: Security/Erase and Acknowledgment Packets**

| Host Security | 0x5E | Password (32 bytes) |
| Device Security Acknowledgment | ACK |
| Host Erase | 0x51 |
| Device Erase Acknowledgment | ACK |

**ACK:**
- 0xA3 = password in Security packet is equal to mainPassword
- 0xAC = password in Security packet is not correct

If the Host sends an Erase packet, the Device erases the Flash and sends an Erase Acknowledgment packet according to the result. If the Host sends a Security packet, the Device compares the received password with mainPassword and sends a Security Acknowledgment packet with the comparison result. If it returns 0xAC, the flow goes to Step3. Otherwise, it repeats Step2.

2. Device sends a Header Request packet with LEN = 16. After receiving Header Request, Host sends a Header Request Acknowledgment. See Figure 26.

**Figure 26: Header Request and Acknowledgment Packet**

| Device Header Request | 0xA5 | LEN (2 bytes) | Check (2 bytes) |
| Host Header Request Acknowledgment | ACK |

**LEN** = the length of the next packet requested to be sent by host
**CHECK** = 1’s compliment of LEN

**ACK:**
- 0x53 = Header Request packet is processed correctly and a Header packet is sent following this ACK byte
- 0x5C = Header Request packet is not handled correctly
3. Host sends a Data Header packet after the Header Request Acknowledgment. See Figure 27.

Figure 27: Data Header Packet

<table>
<thead>
<tr>
<th>Host Data Header</th>
<th>Type (1 byte)</th>
<th>CRC Mode (1 byte)</th>
<th>Reserved (2 bytes)</th>
<th>Address (4 bytes)</th>
<th>Length (4 bytes)</th>
<th>CRC or Dummy (4 bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- **Type** = type of packet
  - 0x01 = Data Header packet with CRC check (this packet and next Data packet are with CRC check)
  - 0x02 = Data Header packet without CRC check (this packet and next Data packet are without CRC check)

- **CRC Mode** = CRC mode of this packet and the following data packet
  - 0 = CRC-16-CCITT with polynomial 0x8408
  - 1 = CRC-16-IBM with polynomial 0xA001
  - 2 = CRC-16-T10-DIF with polynomial 0xEDD1
  - 3 = CRC-32-IEEE with polynomial 0xEDB88320
  - Others = reserved

- **Address** = start address, where the data in the following Data packet are placed
- **Length** = length of the following Data packet (include the 4-byte CRC check)
- **CRC** =
  - If Type = 0x01, this field is the CRC signature of this packet, which is calculated on the first 12 bytes of the packet.
  - If Type = 0x02, the value of this field is ignored.

4. Device sends Header Request. The LEN field is equal to the length field of the Data Header packet received. See Figure 26, Header Request and Acknowledgment Packet, on page 92.

5. After receiving Header Request packet, Host sends an ACK packet (see Figure 26, Header Request and Acknowledgment Packet, on page 92) followed by a Data packet (see Figure 28, Data Packet, on page 93). The length is equal to the LEN field of the Header Request packet sent by Device.

Figure 28: Data Packet

<table>
<thead>
<tr>
<th>Host Data</th>
<th>2 – 508 even bytes of data</th>
<th>CRC or Dummy (4 bytes)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- **CRC** =
  - If Type field of the previous Data Header packet is 0x01, this field is the CRC signature of this packet, which is calculated on the whole packet excluding the last 4 bytes.
  - If Type = 0x02, the value of this field is ignored.

6. Repeat Step3 to Step6 until all data bytes are downloaded to the Device.

7. Device sends another Header Request with length = 16.
8. Host receives Header Request, and then sends an ACK packet (see Figure 26, Header Request and Acknowledgment Packet, on page 92), followed by an Entry Address Header packet (see Figure 29, Entry Address Header Packet, on page 94).

Figure 29: Entry Address Header Packet

<table>
<thead>
<tr>
<th>Type (1 byte)</th>
<th>CRC Mode (1 byte)</th>
<th>Reserved (2 bytes)</th>
<th>Address (4 bytes)</th>
<th>Length = 0 (4 bytes)</th>
<th>CRC or Dummy (4 bytes)</th>
</tr>
</thead>
</table>
| Type = the type of this packet
  - 0x04 = Entry Address Header packet with CRC check
  - 0x08 = Entry Address Header packet without CRC check
  - Others = reserved
| CRC Mode = CRC mode of this packet
  - 0 = CRC-16-CCITT with polynomial 0x8408
  - 1 = CRC-16-IBM with polynomial 0xA001
  - 2 = CRC-16-T10-DIF with polynomial 0xEDD1
  - 3 = CRC-32-IEEE with polynomial 0xEDB88320
  - Others = reserved
| Address = entry address
| Length = for Entry Address Header, this field is always 0
| CRC =
  - If Type = 0x04, this field is the CRC signature of this packet, which is calculated on the first 12 bytes of the packet.
  - If Type = 0x08, the value of this field is ignored.

9. Device sets the entry address according to the received Entry Address Header.

10. Device sends out the last Header Request with LEN = 0 (0xA5 0x00 0x00 0xFF 0xFF). This tells the Host that this is the last request from Boot ROM.

11. Host sends an ACK packet, then terminates.

12. Device jumps to the entry address.
4.9 USB Disk

This section shows the method for booting from a USB disk. In this boot method, the 88MW320/322 acts as a USB host.

4.9.1 Requirements

Requirements for booting from a USB disk include:
- USB disk (which is used as the boot media) should get enumerated as a USB Mass Storage Class device
- File system on the USB disk should be FAT32
- Image to be booted should be present in root folder
- Name of image to be booted should be boot.bin

4.9.2 Options

The image must have a header as described in Section 4.7, Boot from QSPI Flash, on page 80. The image can either be written to Flash or downloaded to SRAM and run directly from there. The following bits in the bootcfg1 section of the Section Header must be set correctly:
- flashProgMode
- locationMode

4.9.3 Procedure

The procedure for booting from a USB disk is as follows:
1. Set the boot configuration pins for booting from USB (see Section 4.3, Boot Source Selection, on page 68).
2. Copy boot.bin (with valid header) to the USB disk root folder.
3. Ensure that the file system on the USB disk is FAT32.
4. Connect the USB disk to the USB OTG port.
5. Reset the processor.
6. The processor should boot from the USB disk.
4.10 USB DFU

Table 54: DFU Request Type

<table>
<thead>
<tr>
<th>bmRequestType</th>
<th>bRequest</th>
<th>wValue</th>
<th>wIndex</th>
<th>wLength</th>
<th>Data</th>
</tr>
</thead>
<tbody>
<tr>
<td>0010 0001b</td>
<td>DFU_DETACH</td>
<td>wTimeout</td>
<td>0</td>
<td>none</td>
<td></td>
</tr>
<tr>
<td>0010 0001b</td>
<td>DFU_DNLOAD</td>
<td>wBlock</td>
<td>interface</td>
<td>6</td>
<td>status</td>
</tr>
<tr>
<td>1010 0001b</td>
<td>DFU_UPLOAD</td>
<td>wBlock</td>
<td>interface</td>
<td>NXP-specific</td>
<td></td>
</tr>
<tr>
<td>1010 0001b</td>
<td>DFU_GETSTATUS</td>
<td>0</td>
<td>interface</td>
<td>status</td>
<td></td>
</tr>
<tr>
<td>0010 0001b</td>
<td>DFU_CLRSTATUS</td>
<td>0</td>
<td>interface</td>
<td>none</td>
<td></td>
</tr>
<tr>
<td>1010 0001b</td>
<td>DFU_GETSTATE</td>
<td>0</td>
<td>interface</td>
<td>status</td>
<td></td>
</tr>
<tr>
<td>0010 0001b</td>
<td>DFU_ABORT</td>
<td>0</td>
<td>interface</td>
<td>none</td>
<td></td>
</tr>
</tbody>
</table>

Table 55: DFU Requests

<table>
<thead>
<tr>
<th>DFU Request</th>
<th>Command</th>
<th>wValue</th>
<th>wLength</th>
<th>Data</th>
</tr>
</thead>
<tbody>
<tr>
<td>DFU_UPLOAD</td>
<td>Read Memory 0x0001 to 0xFFFF</td>
<td>1 to 2048</td>
<td>address = (wValue-1)*2048 + offset (set by set address pointer command)</td>
<td></td>
</tr>
<tr>
<td>DFU_DNLOAD</td>
<td>Write Memory 0x0001 to 0xFFFF</td>
<td>1 to 2048</td>
<td>0x21 + bMemoryType</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Set Memory Type</td>
<td>0</td>
<td>2</td>
<td>0x22 + dwAddressPointer</td>
</tr>
<tr>
<td></td>
<td>Set Address Pointer</td>
<td>0</td>
<td>5</td>
<td>0x23</td>
</tr>
<tr>
<td></td>
<td>Chip Erase</td>
<td>0</td>
<td>1</td>
<td>0x24 + dwPassword</td>
</tr>
<tr>
<td></td>
<td>Sector Erase</td>
<td>0</td>
<td>5</td>
<td>0x23 + wStartSector+wSectorSize</td>
</tr>
<tr>
<td></td>
<td>Deactivate Security Mode</td>
<td>0</td>
<td>5</td>
<td>0x24 + dwPassword</td>
</tr>
<tr>
<td></td>
<td>Leave DFU Mode</td>
<td>0</td>
<td>0</td>
<td>none</td>
</tr>
</tbody>
</table>

A DFU download example sequence (of a USB Slave Boot in Boot ROM) is as follows:
1. Set Mem Type: 21 01 00 00 00 00 02 00.
   Data: 21 01 (indicates Flash Mem); 21 00 (indicates SRAM Mem)
2. Get Status: a1 03 00 00 00 00 06 00.
3. Set Address Point: 21 01 00 00 00 00 05 00.
   Data: 22 00 00 00 00 (set address pointer 0x0 in Flash)
4. Get Status: a1 03 00 00 00 00 06 00.
5. Write Mem: 21 01 01 00 00 00 00 XX XX (XX XX: length of image file).
   Data: image data
6. Get Status: a1 03 00 00 00 00 06 00.
4.11 Fast Boot at Wake-up from PM3 Mode

1. Wake-up from PM3 low-power mode.
2. Read a 32-bit entry point address from 0x480C_0000 – 0x480C_0003 in AON 4K_MEM.
3. Jump to the entry address directly.

4.12 Additional Boot ROM Information

4.12.1 Boot ROM GPIOs

Table 56: Boot ROM GPIOs

<table>
<thead>
<tr>
<th>GPIO Name</th>
<th>Function</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_27   | CON[4]   | Select Boot Mode
           |           | See Section 1.5, Configuration Pins, on page 71. |
| GPIO_16   | CON[5]   | Select Boot Mode
           |           | See Section 1.5, Configuration Pins, on page 71. |
| GPIO_16   |          | Output a pulse after copying code to internal Flash through USB interface. It can be disabled through the bit bootCfg1.LEDEnable. See Table 52, Sub-Field in bootCfg1, on page 89. |
| GPIO_2    | UART0_TXD | UART0 Interface |
| GPIO_3    | UART0_RXD |               |
|           | GPT0_CH3  | GPT0 Interface (UART baud rate detection) |
| GPIO_28   | QSPI_SSn  | Used to Connect an External Flash |
| GPIO_29   | QSPI_CLK  |               |
| GPIO_30   | QSPI_D0   |               |
| GPIO_31   | QSPI_D1   |               |
| GPIO_32   | QSPI_D2   |               |
| GPIO_33   | QSPI_D3   |               |
4.12.2 Flash Requirements for Flash Boot Mode

An off-chip SPI/QSPI serial Flash can be used for Flash boot, which must meet the following conditions:
- SPI bus operation mode, Mode 0 (CPOL = 0, CPHA = 0) or Mode 3 (CPOL=1, CPHA=1)
- Supports clock frequency of 16 MHz or higher

Table 57 shows the commands required to support basic Flash boot function.

Table 57: Flash Boot Mode, Basic Functions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Byte 1 (code)</th>
<th>Byte 2</th>
<th>Byte 3</th>
<th>Byte 4</th>
<th>Byte 5</th>
<th>Byte 6</th>
<th>n-Bytes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Release from deep power-down</td>
<td>A8h</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
</tr>
<tr>
<td>Read data</td>
<td>03h</td>
<td>A23 to A16</td>
<td>A15 to A8</td>
<td>A7 to A0</td>
<td>(D7 to D0)</td>
<td>(next byte)</td>
<td>continuous</td>
</tr>
<tr>
<td>Write enable</td>
<td>06h</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
</tr>
<tr>
<td>Chip erase</td>
<td>C7h</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
</tr>
<tr>
<td>Read status register</td>
<td>05h</td>
<td>(S7 to S0)</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
</tr>
</tbody>
</table>
Table 58 shows additional instructions that may be used during boot.

### Table 58: Flash Boot Mode, Additional Functions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Byte 1 (code)</th>
<th>Byte 2</th>
<th>Byte 3</th>
<th>Byte 4</th>
<th>Byte 5</th>
<th>Byte 6</th>
<th>n-Bytes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Continuous Read Mode Reset¹</td>
<td>FFh</td>
<td>FFh</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td></td>
</tr>
<tr>
<td>Fast Read</td>
<td>0Bh</td>
<td>A23 to A16</td>
<td>A15 to A8</td>
<td>A7 to A0</td>
<td>dummy</td>
<td>(D7 to D0)</td>
<td>continuous</td>
</tr>
<tr>
<td>Fast Read Dual Output</td>
<td>3Bh</td>
<td>A23 to A16</td>
<td>A15 to A8</td>
<td>A7 to A0</td>
<td>dummy</td>
<td>(D7 to D0)²</td>
<td>continuous</td>
</tr>
<tr>
<td>Fast Read Quad Output</td>
<td>6Bh</td>
<td>A23 to A16</td>
<td>A15 to A8</td>
<td>A7 to A0</td>
<td>dummy</td>
<td>(D7 to D0)³</td>
<td>continuous</td>
</tr>
<tr>
<td>Write Enable for Volatile Status Register</td>
<td>50h</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td></td>
</tr>
<tr>
<td>Write Status Register</td>
<td>01h</td>
<td>S7 to S0</td>
<td>S15 to S8</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td></td>
</tr>
<tr>
<td>Write Status Register 2</td>
<td>35h</td>
<td>(S15 to S8)</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td></td>
</tr>
<tr>
<td>Page Program</td>
<td>02h</td>
<td>A23 to A16</td>
<td>A15 to A8</td>
<td>A7 to A0</td>
<td>D7 to D0</td>
<td>next byte</td>
<td>--</td>
</tr>
<tr>
<td>Quad Page Program</td>
<td>32h</td>
<td>A23 to A16</td>
<td>A15 to A8</td>
<td>A7 to A0</td>
<td>D7 to D0⁴</td>
<td>next byte</td>
<td>--</td>
</tr>
<tr>
<td>Sector Erase</td>
<td>20h</td>
<td>A23 to A16</td>
<td>A15 to A8</td>
<td>A7 to A0</td>
<td>--</td>
<td>--</td>
<td></td>
</tr>
</tbody>
</table>

1. This instruction is recommended when using the Dual or Quad "Continuous Read Mode" features.
2. Dual Output Data:
   - IO0 = (D6, D4, D2, D0)
   - IO1 = (D7, D5, D3, D1)
3. Quad Output Data:
   - IO0 = (D4, D0, ……)
   - IO1 = (D5, D1, ……)
   - IO2 = (D6, D2, ……)
   - IO3 = (D7, D3, ……)
4. Quad Page Program Input Data:
   - IO0 = D4, D0, ……
   - IO1 = D5, D1, ……
   - IO2 = D6, D2, ……
   - IO3 = D7, D3, ……
Table 59 shows the supported SPI Flash for basic Flash boot function (but not limited to these). However, if the complete boot function is needed, the Winbond W25 series is recommended.

Table 59: SPI Flash for Basic Flash Boot Function

<table>
<thead>
<tr>
<th>Company</th>
<th>Part Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>WINBOND</td>
<td>W25Q80BV</td>
</tr>
<tr>
<td>EON</td>
<td>EN25F80</td>
</tr>
<tr>
<td>ATMEL</td>
<td>AT25DF081</td>
</tr>
<tr>
<td>MXIC</td>
<td>MX25L8005</td>
</tr>
<tr>
<td>SPANSION</td>
<td>S25FL008A</td>
</tr>
<tr>
<td>ST</td>
<td>M25P80</td>
</tr>
<tr>
<td>AMIC</td>
<td>A25L080</td>
</tr>
<tr>
<td>GIGADEVICE</td>
<td>GD25Q80</td>
</tr>
</tbody>
</table>
4.12.3 Sample of Code Loading Through UART

This section provides a sample of code loading through UART. In this sample, security mode is enabled, and CRC check is enabled during data transfer.

1. Host: 55 // Detection packet
2. Device: 01 00 00 00 ac // Detection Acknowledgment packet
   // 01 00 00 00: the Boot ROM version number, 01 is the lowest byte
   // ac: the ACK field, it means Boot ROM is in security mode and the host is requested to send a password
3. Host: 5e 14 25 36 47 58 69 7a 8b 9c ad be cf 00 01 23 45 67 89 10 11 22 33 44 55 66 77 88 99 aa bb cc dd // Security packet
   // 5e: it indicates that this is a Security packet
   // 14 25 36 47 58 69 7a 8b 9c ad be cf 00 01 23 45 67 89 10 11 22 33 44 55 66 77 88 99 aa bb cc dd: 256 bits password, as same as AES Key, 14 is the lowest byte
   // ac: it means the password received from the host (0x58473625) is equal to bootInfo.mainPassword
5. Device: a5 10 00 ef ff // Header Request packet
   // a5: it means this is a Header Request packet
   // 10 00: the requested length. It is 0x0010
   // ef ff: the 1's complement of 10 00
6. Host: 53 // Header Request Acknowledgment packet
   // It means the host recognizes and processes the Header Request packet successfully
7. Host: 01 03 00 00 00 00 11 00 0c 00 00 00 e8 44 1b 80 // Data Header packet
   // 01: This is a Data Header packet, and CRC check is applied to this packet and the next Data packet
   // 03: the CRC mode is CRC-32-IEEE
   // 00 00: reserved
   // 00 01 11 00: The start address, where data in the next Data packet are placed, is 0x00110000
   // 0c 00 00 00: the length of the next Data packet is 0x0000000c
   // e8 44 1b 80: CRC signature for this packet
8. Device: a5 0c 00 f3 ff // Header Request packet
   // a5: it means this is a Header request packet
   // 0c 00: the requested length. It is 0x000c
   // f3 ff: the 1's complement of 0c 00
9. Host: 53 // Header Request Acknowledgment packet
   // It means the host recognizes and processes the Header Request packet successfully
10. Host: 00 04 00 20 7d 00 11 00 46 50 02 ff
    // Data packet
    // 00 04 00 20 7d 00 11 00: data which need to be stored to memory
    // 46 50 02 ff: CRC signature of this packet
11. Device: a5 10 00 ef ff // The function of Packet 11 - 58 is similar to Packet 5-10
    // Please refer to the comments of Packet 5-10
12. Host: 53
13. Host: 01 03 00 00 08 00 11 00 14 00 00 00 2d 20 53 c6
14. Device: a5 14 00 eb ff
15. Host: 53
16. Host: 07 48 00 68 50 f0 01 00 05 49 08 60 05 48 0f 21 d7 fb b5 98
17. Device: a5 10 00 ef ff
18. Host: 53
19. Host: 01 03 00 00 18 00 11 00 14 00 00 00 06 11 e8 ba
20. Device: a5 14 00 eb ff
21. Host: 53
22. Host: 01 60 05 48 0f 21 01 60 04 48 0f 21 01 60 f8 e7 8b ec 65 e5
23. Device: a5 10 00 ef ff
24. Host: 53
25. Host: 01 03 00 00 28 00 11 00 14 00 00 00 7b 42 25 3f
26. Device: a5 14 00 eb ff
27. Host: 53
28. Host: 04 00 0a 48 0c 00 06 46 18 00 06 46 24 00 06 46 b1 8c 15 0c
29. Device: a5 10 00 ef ff
30. Host: 53
31. Host: 01 03 00 00 38 00 11 00 14 00 00 00 50 73 9e 43
32. Device: a5 14 00 eb ff
33. Host: 53
34. Host: 00 f0 09 f8 00 28 01 d0 c0 46 c0 46 00 20 ff f7 38 73 1c 72
35. Device: a5 10 00 ef ff
36. Host: 53
37. Host: 01 03 00 00 48 00 11 00 14 00 00 00 c0 e2 ce ef
38. Device: a5 14 00 eb ff
39. Host: 53
40. Host: df ff 00 f0 02 f8 01 20 70 47 80 b5 00 f0 02 f8 3f 21 74 71
41. Device: a5 10 00 ef ff
42. Host: 53
43. Host: 01 03 00 00 58 00 11 00 14 00 00 00 eb d3 75 93
44. Device: a5 14 00 eb ff
45. Host: 53
46. Host: 00 bf 00 00 07 46 38 46 00 f0 02 f8 fb e7 00 00 58 c7 59 e6
47. Device: a5 10 00 ef ff
48. Host: 53
49. Host: 01 03 00 00 68 00 11 00 14 00 00 00 96 80 b8 16
50. Device: a5 14 00 eb ff
51. Host: 53
52. Host: 80 b5 c0 46 c0 46 02 4a 11 00 18 20 ab be fb e7 9c 9a 31 11
53. Device: a5 10 00 ef ff
54. Host: 53
55. Host: 01 03 00 00 78 00 11 00 14 00 00 00 bd b1 03 6a
56. Device: a5 14 00 eb ff
57. Host: 53
58. Host: 26 00 02 00 c0 46 c0 46 c0 46 c0 46 ff f7 d8 ff b3 de e5 8f
59. Device: a5 10 00 ef ff  // Header Request packet
   // a5: it means this is a Header request packet
   // 10 00: the requested length. It is 0x0010
   // ef ff: the 1's complement of 10 00
60. Host: 53  // Header Request Acknowledgment packet
   // It means the host recognizes and processes the Header Request packet successfully
61. Host: 04 03 00 00 7d 00 11 00 00 00 00 00 01 08 3b 65
   // Entry Address Header packet
   // 04: This is an Entry Address Header packet with CRC check
   // 03: CRC mode is CRC-32-IEEE
   // 00 00: reserved
   // 7d 00 11 00: entry address is 0x0011007d
   // 00 00 00 00: this field is always 0 for Entry Address Header Packet
   // 01 08 3b 65: CRC signature for this packet
62. Device: a5 00 00 ff ff  // Header Request packet
   // a5: it means this is a Header request packet
   // 00 00: the requested length is 0
   // ff ff: the 1's complement of 00 00
63. Host: 53  // Header Request Acknowledgment packet
   // It means the host recognizes and processes the Header Request packet successfully
5 Flash Controller

5.1 Overview

The 88MW320/322 Flash Controller provides a communication path between the Cortex-M4F CPU and the off-chip Flash memory. Main components of the controller include the Quad Serial interface, Flash Cache, and Flash Controller configuration registers.

5.2 Interface

The Flash Controller has an SPI interface (supports Quad-mode) that communicates with the Flash memory.

5.3 Cache

The Flash Cache is a 32 KB, 8-way set associative cache, which can cache data from a 16 MB address range. The cache is organized as 128 sets, with each set consisting of 8, 32-byte wide lines. The 32 KB is a SRAM type memory that holds CPU instructions and/or data. There is a small amount of Content Addressable Memory (CAM) memory that is used to hold information required to determine cache hit or miss.

The Flash Cache also has logic that compares the CAM information (tags) to the tag in the requested address to see if it resides in the set. In addition, the Flash Cache includes replacement logic. The Flash Cache uses a pseudo-LRU algorithm to determine which line within a set needs eviction, if needed. The pseudo least recently used algorithm will first select any cache line which is not valid, and if all 8 cache lines are valid it will select the cache line which it deems has been least recently used for eviction and replacement.

5.4 Functional Description

The Flash Controller provides a path for executing code (or data) residing in Flash memory. A read request or a code (or data) fetch by CM4 to Flash memory space will go through the cache if the FCCR.CACHE_MODE_EN is set to 1.

If a hit occurs, then the data is returned immediately. If a miss occurs, then the Flash Cache generates a read request for a 32-byte line to the serial interface; the interface reads 32 bytes of data from the Flash memory and returns it to the Flash Cache. The Flash Cache returns this data to CM4. The Flash Controller Configuration Register (FCCR) can be configured by software to set the FLASHC_PAD_EN to 1 before the CPU uses the Flash Controller. Software can also configure different types of Read commands supported on WinBond Flash memory prior to issuing reads to Flash memory space.

Figure 31, Flash Controller Block Diagram, on page 105 shows an overall block diagram.
5.4.1 Block Diagram

Figure 31: Flash Controller Block Diagram

5.4.2 Modes

5.4.2.1 Cache Bypass Mode
Cache bypass mode is the default mode of operation and requires that both FCCR.CACHE_MODE_EN and FCCR.SRAM_MODE_EN to be cleared to 0. In this mode, the fetched code from Flash memory bypasses the 32 KB cache.

5.4.2.2 Cache Mode
Cache mode is enabled when software sets FCCR.CACHE_MODE_EN to 1 and FCCR.SRAM_EN to 0. In this mode, the content fetched from the Flash memory will go through the 32 KB cache memory.

5.4.2.3 SRAM Mode
SRAM mode is enabled when FCCR.SRAM_MODE_EN is set to 1. The 32 KB data RAM can be utilized as SRAM in this mode. When FCCR.SRAM_MODE_EN is set to 1, also set FCCR.CACHE_MODE_EN to 0.
## 5.4.2.4 Configuration Override

The Flash Controller provides the capability to configure various different Command Semantics supported by Flash device vendors, specifically for Read. There are 2 ways of configuring and building the necessary Read Commands through the Flash Control Configuration register (FCCR) and Flash Controller Configuration Register 2 (FCCR).

When FCCR2.USE_CFG_OVRD = 0 (default), the user or software can configure FCCR.CMD_TYPE to achieve the necessary Read Command semantics for the target Flash device. In this case, the Flash Controller hardware configures the required Address clock cycles, Instruction Opcodes, and Dummy clock cycles required for a specific Read command type without software intervention.

When FCCR2.USE_CFG_OVRD = 1, software has the flexibility to configure the number of Address clock cycles, Dummy clock cycles, Instruction Opcodes, Read mode bit configuration, and clock cycles. When FCCR2.USE_CFG_OVRD = 1, all the contents and fields of FCCR2 are used by the Flash Controller to determine the command semantics. Software needs to ensure that complete configuration is provided.

## 5.4.3 Programming Notes

### 5.4.3.1 Switch From Flash Controller (memory mapped) to QSPI

Procedure to switch from Flash Controller (memory mapped) to QSPI when communicating with the Flash device.

The default Read Command type of Flash Controller is FCCR.CMD_TYPE=0x5, "Fast Read Dual I/O Continuous Read Mode". While operating the Flash Controller in this Read mode, the user must Exit the Continuous Read mode in order to switch to normal Read command.

To Exit Continuous Read Mode:
1. Set FCCR.CACHE_EN=0x0.
2. Set FCCR.CMD_TYPE=0xC.
3. Poll for FCSR.CONT_RD_MD_EXIT_DONE. Wait for this bit to become 1.
4. Write FCSR.CONT_RD_MD_EXIT_DONE=0x1 to clear.
5. Set FCCR.FLASH_PAD_EN=0x0. The QSPI interface can now be used to communicate with the Flash device.

### 5.4.3.2 Switch Back from QSPI to Flash Controller

Procedure to switch back from QSPI to Flash Controller when communicating with the Flash device.

1. Set FCCR.FLASH_PAD_EN=0x1.
2. Set FCCR.CMD_TYPE=0x5.
3. Set FCCR.CACHE_EN=0x1, if cache mode is desired.

The execution from Flash can now be resumed.
5.4.3.3 Retain State of Flash Cache in PM3

The cache inside the Flash Controller can retain state during PM3 for faster resume. Configuration is required.

The Flash Controller is reset when exiting PM3, during which the cache gets flushed and everything in the cache becomes invalid. To prevent this from happening, and to preserve the cache state:

1. PMU -> LOW_PWR_CTRL.CACHE_LINE_FLUSH = 0x0 (prevent/override cache flush).
2. Enter PM3.
3. Exit PM3 (reset happens).
4. Set FCCR.CACHE_LINE_FLUSH = 0x0.
5. PMU -> LOW_PWR_CTRL.CACHE_LINE_FLUSH = 0x1 (restore the default).

5.4.3.4 Cache Flush

The Flash Cache is flushed automatically upon POR and exiting from Low-Power Modes (PM3). However, software must ensure that FCCR.CACHE_LINE_FLUSH is set (1) when the Flash device content is modified through Erase or Program operations using the QSPI interface. Otherwise, outdated data might be present in the cache.

5.5 Register Description

See Section 24.4.2, Flash Controller Registers for a detailed description of the registers.
6 General Purpose Input Output (GPIO)

6.1 Overview

The 88MW320/322 GPIO unit provides as many as 50 GPIO pins. All ports are brought out of the device using alternate function multiplexing.

The GPIO function can be multiplexed on a multi-function I/O pin by selecting the GPIO alternate function in the pad configuration registers (PINMUX) and configuring the GPIO internal registers.

Note: Both the GPIO internal and PINMUX registers are accessed separately through the APB interface (different base addresses). See Section 2.4, Memory Map, on page 36 for base addressing.

For GPIO internal registers, see, Section 24.11, GPIO Address Block.
For PINMUX registers, see, Section 24.17, PINMUX Address Block.

6.2 I/O Configuration

Many of the 88MW320/322 package pins are multiplexed. They can be configured as general-purpose I/Os or an alternate function using the Multi-Function Pin Alternate-Function Select registers. Some functions can be configured to appear on 1 of several different pins using alternate function controls.

The I/O pad can support a 50 kΩ pull-up, 50 kΩ pull-down, or tri-state configuration. The default value of the I/O function is pull-up.

Note: See Section 6.2.2, I/O Padding Pin States, on page 123 for information regarding the I/O pins on each package.

6.2.1 PINMUX Alternate Functions

Each I/O or package pin has a dedicated register to control its functionality. The function number is specified from 0 to 7 by the least significant 3 bits of each register.

Function 0 is the GPIO function for all I/O pins, except:

- TDO/TCK/TMS/TDI/TRSTn (GPIO_6 to GPIO_10)
- WAKE_UP0/WAKE_UP1 (GPIO_22/23)
- OSC32K (GPIO_24)
- XTAL32K_IN/XTAL32K_OUT (GPIO_25/26)
- QSPI (GPIO_28 to GPIO_33)

After POR, PINMUX is Function 0 by default.

If Function 0 is a GPIO function, it has a 50 kΩ pull-up by default.

When Function 0 is not a GPIO function, the following pins also have a 50 kΩ pull-up, by default:

- GPIO_6 to GPIO_10
- GPIO_30 to GPIO_33

The following tables show the alternate functions for each GPIO pin.

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
</tbody>
</table>
### Table 60: GPIO_0 (Offset=0x00) (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>SSP0_CLK</td>
<td>I/O</td>
<td>SSP 0 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>UART0_CTSn</td>
<td>I</td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPT0_CH0</td>
<td>I/O</td>
<td>General Purpose Timer 0, Channel 0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_0</td>
<td>I/O</td>
<td>General Purpose I/O 0</td>
</tr>
</tbody>
</table>

### Table 61: GPIO_1 (Offset=0x04)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP0_FRM</td>
<td>I/O</td>
<td>SSP 0 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>UART0_RTSn</td>
<td>O</td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPT0_CH1</td>
<td>I/O</td>
<td>General Purpose Timer 0, Channel 1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_1</td>
<td>I/O</td>
<td>General Purpose I/O 1</td>
</tr>
</tbody>
</table>

### Table 62: GPIO_2 (Offset=0x08)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP0_TXD</td>
<td>O</td>
<td>SSP 0 TXD</td>
</tr>
<tr>
<td>2</td>
<td>UART0_TXD</td>
<td>O</td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td>1</td>
<td>GPT0_CH2</td>
<td>I/O</td>
<td>General Purpose Timer 0, Channel 2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_2</td>
<td>I/O</td>
<td>General Purpose I/O 2</td>
</tr>
</tbody>
</table>

### Table 63: GPIO_3 (Offset=0x0C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP0_RXD</td>
<td>I</td>
<td>SSP 0 RXD</td>
</tr>
<tr>
<td>2</td>
<td>UART0_RXD</td>
<td>I</td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td>1</td>
<td>GPT0_CH3</td>
<td>I/O</td>
<td>General Purpose Timer 0, Channel 3</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_3</td>
<td>I/O</td>
<td>General Purpose I/O 3</td>
</tr>
</tbody>
</table>
### Table 64: GPIO_4 (Offset=0x10)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>AUDIO_CLK</td>
<td>O</td>
<td>Audio Clock AUPLL Audio clock output provided by Audio PLL for external codec.</td>
</tr>
<tr>
<td>2</td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td>I²C 0 SDA</td>
</tr>
<tr>
<td>1</td>
<td>GPT0_CH4</td>
<td>I/O</td>
<td>General Purpose Timer 0, Channel 4</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_4</td>
<td>I/O</td>
<td>General Purpose I/O 4</td>
</tr>
</tbody>
</table>

### Table 65: GPIO_5 (Offset=0x14)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:3</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td>I²C 0 SCL</td>
</tr>
<tr>
<td>1</td>
<td>GPT0_CH5</td>
<td>I/O</td>
<td>General Purpose Timer 0, Channel 5</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_5</td>
<td>I/O</td>
<td>General Purpose I/O 5</td>
</tr>
</tbody>
</table>

### Table 66: GPIO_6 (Offset=0x18)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:3</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td>I²C 1 SDA</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_6</td>
<td>I/O</td>
<td>General Purpose I/O 6</td>
</tr>
<tr>
<td>0</td>
<td>TDO</td>
<td>O</td>
<td>JTAG Test Data</td>
</tr>
</tbody>
</table>

### Table 67: GPIO_7 (Offset=0x1C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:5</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>4</td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td>I²C 0 SDA</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_CLK</td>
<td>I/O</td>
<td>SSP 2 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>UART2_CTSn</td>
<td>I</td>
<td>UART 2 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_7</td>
<td>I/O</td>
<td>General Purpose I/O 7</td>
</tr>
<tr>
<td>0</td>
<td>TCK</td>
<td>I</td>
<td>JTAG Test Clock SWCLK in SWD Mode</td>
</tr>
</tbody>
</table>
### Table 68: GPIO_8 (Offset=0x20)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:5</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>4</td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td>I^2C 0 SCL</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_FRM</td>
<td>I/O</td>
<td>SSP 2 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>UART2_RTSn</td>
<td>O</td>
<td>UART 2 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_8</td>
<td>I/O</td>
<td>General Purpose I/O 8</td>
</tr>
<tr>
<td>0</td>
<td>TMS</td>
<td>I/O</td>
<td>JTAG Controller Select SWDIO in SWD Mode</td>
</tr>
</tbody>
</table>

### Table 69: GPIO_9 (Offset=0x24)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:5</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>4</td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td>I^2C 1 SDA</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_TXD</td>
<td>O</td>
<td>SSP 2 TXD</td>
</tr>
<tr>
<td>2</td>
<td>UART2_TXD</td>
<td>O</td>
<td>UART 2 TXD</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_9</td>
<td>I/O</td>
<td>General Purpose I/O 9</td>
</tr>
<tr>
<td>0</td>
<td>TDI</td>
<td>I</td>
<td>JTAG Controller Select</td>
</tr>
</tbody>
</table>

### Table 70: GPIO_10 (Offset=0x28)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:5</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>4</td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td>I^2C 1 SCL</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_RXD</td>
<td>I</td>
<td>SSP 2 RXD</td>
</tr>
<tr>
<td>2</td>
<td>UART2_RXD</td>
<td>I</td>
<td>UART 2 RXD</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_10</td>
<td>I/O</td>
<td>General Purpose I/O 10</td>
</tr>
<tr>
<td>0</td>
<td>TRSTn</td>
<td>I</td>
<td>JTAG Test Reset (active low)</td>
</tr>
</tbody>
</table>
### Table 71: GPIO_11 (Offset=0x2C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>UART1_CTSn</td>
<td>I</td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPT2_CH0</td>
<td>I/O</td>
<td>General Purpose Timer 2, Channel 0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_11</td>
<td>I/O</td>
<td>General Purpose I/O 11</td>
</tr>
</tbody>
</table>

### Table 72: GPIO_12 (Offset=0x30)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>UART1_RTSn</td>
<td>O</td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPT2_CH1</td>
<td>I/O</td>
<td>General Purpose Timer 2, Channel 1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_12</td>
<td>I/O</td>
<td>General Purpose I/O 12</td>
</tr>
</tbody>
</table>

### Table 73: GPIO_13 (Offset=0x34)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>2</td>
<td>UART1_TXD</td>
<td>O</td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td>1</td>
<td>GPT2_CH2</td>
<td>I/O</td>
<td>General Purpose Timer 2, Channel 2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_13</td>
<td>I/O</td>
<td>General Purpose I/O 13</td>
</tr>
</tbody>
</table>

### Table 74: GPIO_14 (Offset=0x38)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>2</td>
<td>UART1_RXD</td>
<td>I</td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td>1</td>
<td>GPT2_CH3</td>
<td>I/O</td>
<td>General Purpose Timer 2, Channel 3</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_14</td>
<td>I/O</td>
<td>General Purpose I/O 14</td>
</tr>
</tbody>
</table>
### Table 75: GPIO_15 (Offset=0x3C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:2</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>1</td>
<td>GPT2_CH4</td>
<td>I/O</td>
<td>General Purpose Timer 2, Channel 4</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_15</td>
<td>I/O</td>
<td>General Purpose I/O 15</td>
</tr>
</tbody>
</table>

### Table 76: GPIO_16 (Offset=0x40)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>AUDIO_CLK</td>
<td>O</td>
<td>Audio Clock AUPLL Audio clock output from Audio PLL for external codec.</td>
</tr>
<tr>
<td>2</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>1</td>
<td>CON[5]</td>
<td>I/O</td>
<td>Configuration Bit See Section 1.5, Configuration Pins, on page 71.</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_16</td>
<td>I/O</td>
<td>General Purpose I/O 16</td>
</tr>
</tbody>
</table>

### Table 77: GPIO_17 (Offset=0x44)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:3</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td>I^2^C 1 SCL</td>
</tr>
<tr>
<td>1</td>
<td>GPT3_CH0</td>
<td>I/O</td>
<td>General Purpose Timer 3, Channel 0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_17</td>
<td>I/O</td>
<td>General Purpose I/O 17</td>
</tr>
</tbody>
</table>

### Table 78: GPIO_18 (Offset=0x48)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td>I^2^C 1 SDA</td>
</tr>
<tr>
<td>1</td>
<td>GPT3_CH1</td>
<td>I/O</td>
<td>General Purpose Timer 3, Channel 1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_18</td>
<td>I/O</td>
<td>General Purpose I/O 18</td>
</tr>
</tbody>
</table>

### Table 79: GPIO_19 (Offset=0x4C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
</tbody>
</table>
Table 79: GPIO_19 (Offset=0x4C) (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td>I²C 1 SCL</td>
</tr>
<tr>
<td>1</td>
<td>GPT3_CH2</td>
<td>I/O</td>
<td>General Purpose Timer 3, Channel 2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_19</td>
<td>I/O</td>
<td>General Purpose I/O 19</td>
</tr>
</tbody>
</table>

Table 80: GPIO_20 (Offset=0x50)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>2</td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td>I²C 0 SDA</td>
</tr>
<tr>
<td>1</td>
<td>GPT3_CH3</td>
<td>I/O</td>
<td>General Purpose Timer 3, Channel 3</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_20</td>
<td>I/O</td>
<td>General Purpose I/O 20</td>
</tr>
</tbody>
</table>

Table 81: GPIO_21 (Offset=0x54)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>2</td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td>I²C 0 SCL</td>
</tr>
<tr>
<td>1</td>
<td>GPT3_CH4</td>
<td>I/O</td>
<td>General Purpose Timer 3, Channel 4</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_21</td>
<td>I/O</td>
<td>General Purpose I/O 21</td>
</tr>
</tbody>
</table>

Table 82: GPIO_22 (Offset=0x58)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:2</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_22</td>
<td>I/O</td>
<td>General Purpose I/O 22</td>
</tr>
<tr>
<td>0</td>
<td>WAKE_UP0</td>
<td>I</td>
<td>Wake-Up 0</td>
</tr>
</tbody>
</table>

Table 83: GPIO_23 (Offset=0x5C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>COMP_IN_P</td>
<td>I</td>
<td>LDO18 Comparator Input, Positive</td>
</tr>
</tbody>
</table>
### Table 83: GPIO_23 (Offset=0x5C) (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4:3</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>UART0_CTSn</td>
<td>I</td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_23</td>
<td>I/O</td>
<td>General Purpose I/O 23</td>
</tr>
<tr>
<td>0</td>
<td>WAKE_UP1</td>
<td>I</td>
<td>Wake-Up 1</td>
</tr>
</tbody>
</table>

### Table 84: GPIO_24 (Offset=0x60)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>COMP_IN_N</td>
<td>I</td>
<td>LDO18 Comparator Input, Negative</td>
</tr>
<tr>
<td>4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>GPT1_CH5</td>
<td>I/O</td>
<td>General Purpose Timer 1, Channel 5</td>
</tr>
<tr>
<td>2</td>
<td>UART0_RXD</td>
<td>I</td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_24</td>
<td>I/O</td>
<td>General Purpose I/O 24</td>
</tr>
<tr>
<td>0</td>
<td>OSC32K</td>
<td>O</td>
<td>32 kHz Output, Choose RC or Crystal</td>
</tr>
</tbody>
</table>

### Table 85: GPIO_25 (Offset=0x64)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>I2C1_SDA</td>
<td>I/O</td>
<td>I2C 1 SDA</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_25</td>
<td>I/O</td>
<td>General Purpose I/O 25</td>
</tr>
<tr>
<td>0</td>
<td>XTAL32K_IN</td>
<td>I</td>
<td>32.768 kHz Crystal Input</td>
</tr>
</tbody>
</table>

### Table 86: GPIO_26 (Offset=0x68)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>I2C1_SCL</td>
<td>I/O</td>
<td>I2C 1 SCL</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_26</td>
<td>I/O</td>
<td>General Purpose I/O 26</td>
</tr>
<tr>
<td>0</td>
<td>XTAL32K_OUT</td>
<td>O</td>
<td>32.768 kHz Crystal Output</td>
</tr>
</tbody>
</table>

### Table 87: GPIO_27 (Offset=0x6C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>USB_DRV_VBUS</td>
<td>O</td>
<td>Drive 5V on VBUS</td>
</tr>
</tbody>
</table>
### Table 87: GPIO_27 (Offset=0x6C) (Continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>UART0_TXD</td>
<td>O</td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td>1</td>
<td>CON[4]</td>
<td>I/O</td>
<td>Configuration Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>See Section 1.5, Configuration Pins, on page 71.</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_27</td>
<td>I/O</td>
<td>General Purpose I/O 27</td>
</tr>
</tbody>
</table>

### Table 88: GPIO_28 (Offset=0x70)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>GPT1_CH0</td>
<td>I/O</td>
<td>General Purpose Timer 1, Channel 0</td>
</tr>
<tr>
<td>4:3</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>I2C0_SDA</td>
<td>I/O</td>
<td>I²C 0 SDA</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_28</td>
<td>I/O</td>
<td>General Purpose I/O 28</td>
</tr>
<tr>
<td>0</td>
<td>QSPI_SSn</td>
<td>I/O</td>
<td>QSPI Chip Select (active low)</td>
</tr>
</tbody>
</table>

### Table 89: GPIO_29 (Offset=0x74)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>GPT1_CH1</td>
<td>I/O</td>
<td>General Purpose Timer 1, Channel 1</td>
</tr>
<tr>
<td>4:3</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>I2C0_SCL</td>
<td>I/O</td>
<td>I²C 0 SCL</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_29</td>
<td>I/O</td>
<td>General Purpose I/O 29</td>
</tr>
<tr>
<td>0</td>
<td>QSPI_CLK</td>
<td>O</td>
<td>QSPI Clock</td>
</tr>
</tbody>
</table>
### Table 90: GPIO_30 (Offset=0x78)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>GPT1_CH2</td>
<td>I/O</td>
<td>General Purpose Timer 1, Channel 2</td>
</tr>
<tr>
<td>4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP0_CLK</td>
<td>I/O</td>
<td>SSP 0 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>UART0_CTSn</td>
<td>I</td>
<td>UART 0 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_30</td>
<td>I/O</td>
<td>General Purpose I/O 30</td>
</tr>
<tr>
<td>0</td>
<td>QSPI_D0</td>
<td>I/O</td>
<td>QSPI Data 0</td>
</tr>
</tbody>
</table>

### Table 91: GPIO_31 (Offset=0x7C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>GPT1_CH3</td>
<td>I/O</td>
<td>General Purpose Timer 1, Channel 3</td>
</tr>
<tr>
<td>4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP0_FRM</td>
<td>I/O</td>
<td>SSP 0 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>UART0_RTSn</td>
<td>O</td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_31</td>
<td>I/O</td>
<td>General Purpose I/O 31</td>
</tr>
<tr>
<td>0</td>
<td>QSPI_D1</td>
<td>I/O</td>
<td>QSPI Data 1</td>
</tr>
</tbody>
</table>

### Table 92: GPIO_32 (Offset=0x80)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>GPT1_CH4</td>
<td>I/O</td>
<td>General Purpose Timer 1, Channel 4</td>
</tr>
<tr>
<td>4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP0_TXD</td>
<td>O</td>
<td>SSP 0 TXD</td>
</tr>
<tr>
<td>2</td>
<td>UART0_TXD</td>
<td>O</td>
<td>UART 0 TXD</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_32</td>
<td>I/O</td>
<td>General Purpose I/O 32</td>
</tr>
<tr>
<td>0</td>
<td>QSPI_D2</td>
<td>I/O</td>
<td>QSPI Data 2</td>
</tr>
<tr>
<td>Function</td>
<td>Name</td>
<td>I/O</td>
<td>Description</td>
</tr>
<tr>
<td>----------</td>
<td>-------</td>
<td>-----</td>
<td>------------------------------</td>
</tr>
<tr>
<td>7:6</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>5</td>
<td>GPT1_CH5</td>
<td>I/O</td>
<td>General Purpose Timer 1, Channel 5</td>
</tr>
<tr>
<td>4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP0_RXD</td>
<td>I</td>
<td>SSP 0 RXD</td>
</tr>
<tr>
<td>2</td>
<td>UART0_RXD</td>
<td>I</td>
<td>UART 0 RXD</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_33</td>
<td>I/O</td>
<td>General Purpose I/O 33</td>
</tr>
<tr>
<td>0</td>
<td>QSPI_D3</td>
<td>I/O</td>
<td>QSPI Data 3</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:2</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>1</td>
<td>GPT3_CH5</td>
<td>I/O</td>
<td>General Purpose Timer 3, Channel 5</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_34</td>
<td>I/O</td>
<td>General Purpose I/O 34</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>UART1_CTSn</td>
<td>I</td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPT0_CLKIN</td>
<td>I</td>
<td>General Purpose Timer 0, Clock Input</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_35</td>
<td>I/O</td>
<td>General Purpose I/O 35</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>UART1_RTSn</td>
<td>O</td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPT1_CLKIN</td>
<td>I</td>
<td>General Purpose Timer 1, Clock Input</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_36</td>
<td>I/O</td>
<td>General Purpose I/O 36</td>
</tr>
</tbody>
</table>
### Table 97: GPIO_37 (Offset=0x94)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:3</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>2</td>
<td>UART0_RTSn</td>
<td>O</td>
<td>UART 0 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>GPT2_CH5</td>
<td>I/O</td>
<td>General Purpose Timer 2, Channel 5</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_37</td>
<td>I/O</td>
<td>General Purpose I/O 37</td>
</tr>
</tbody>
</table>

### Table 98: GPIO_38 (Offset=0x98)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>2</td>
<td>UART1_TXD</td>
<td>O</td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td>1</td>
<td>GPT2_CLKIN</td>
<td>I</td>
<td>General Purpose Timer 2, Clock Input</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_38</td>
<td>I/O</td>
<td>General Purpose I/O 38</td>
</tr>
</tbody>
</table>

### Table 99: GPIO_39 (Offset=0x9C)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>2</td>
<td>UART1_RXD</td>
<td>I</td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td>1</td>
<td>GPT3_CLKIN</td>
<td>I</td>
<td>General Purpose Timer 3, Clock Input</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_39</td>
<td>I/O</td>
<td>General Purpose I/O 39</td>
</tr>
</tbody>
</table>

### Table 100: GPIO_40 (Offset=0xA0)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>ACOMP1_GPIO_OUT</td>
<td>O</td>
<td>ACOMP1 GPIO Output</td>
</tr>
<tr>
<td>2</td>
<td>ACOMP0_GPIO_OUT</td>
<td>O</td>
<td>ACOMP0 GPIO Output</td>
</tr>
<tr>
<td>1</td>
<td>ADC_DAC_TRIGGER0</td>
<td>I</td>
<td>ADC/DAC External Trigger 0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_40</td>
<td>I/O</td>
<td>General Purpose I/O 40</td>
</tr>
</tbody>
</table>
### Table 101: GPIO_41 (Offset=0xA4)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>ACOMP1_EDGE_PULSE</td>
<td>O</td>
<td>ACOMP Edge Pulse 1</td>
</tr>
<tr>
<td>2</td>
<td>ACOMP0_EDGE_PULSE</td>
<td>O</td>
<td>ACOMP Edge Pulse 0</td>
</tr>
<tr>
<td>1</td>
<td>ADC_DAC_TRIGGER1</td>
<td>I</td>
<td>ADC/DAC External Trigger 1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_41</td>
<td>I/O</td>
<td>General Purpose I/O 41</td>
</tr>
</tbody>
</table>

### Table 102: GPIO_42 (Offset=0xA8)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_CLK</td>
<td>I/O</td>
<td>SSP 1 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>UART1_CTSn</td>
<td>I</td>
<td>UART 1 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_0 / ACOMP0 / TS_INP / VOICE_P</td>
<td>I</td>
<td>ADC0 Channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Temperature sensor remote sensing positive input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Voice sensing positive input</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_42</td>
<td>I/O</td>
<td>General Purpose I/O 42</td>
</tr>
</tbody>
</table>

### Table 103: GPIO_43 (Offset=0xAC)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_FRM</td>
<td>I/O</td>
<td>SSP 1 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>UART1_RTSn</td>
<td>O</td>
<td>UART 1 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_1 / ACOMP1 / DACB / TS_INN / VOICE_N</td>
<td>I/O</td>
<td>ADC0 Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Temperature sensor remote sensing negative input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Voice sensing negative input</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_43</td>
<td>I/O</td>
<td>General Purpose I/O 43</td>
</tr>
</tbody>
</table>
### Table 104: GPIO_44 (Offset=0xB0)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>RF_CNTL1_P</td>
<td>O</td>
<td>WLAN Radio Control 1</td>
</tr>
<tr>
<td>6:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_TXD</td>
<td>O</td>
<td>SSP 1 TXD</td>
</tr>
<tr>
<td>2</td>
<td>UART1_TXD</td>
<td>O</td>
<td>UART 1 TXD</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_2 / ACOMP2 / DACA</td>
<td>I/O</td>
<td>ADC0 Channel 2&lt;br&gt;ACOMP0 Channel 2&lt;br&gt;ACOMP1 Channel 2&lt;br&gt;DAC Channel A output</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_44</td>
<td>I/O</td>
<td>General Purpose I/O 44</td>
</tr>
</tbody>
</table>

### Table 105: GPIO_45 (Offset=0xB4)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>RF_CNTL0_N</td>
<td>O</td>
<td>WLAN Radio Control 0</td>
</tr>
<tr>
<td>6:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP1_RXD</td>
<td>I</td>
<td>SSP 1 RXD</td>
</tr>
<tr>
<td>2</td>
<td>UART1_RXD</td>
<td>I</td>
<td>UART 1 RXD</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_3 / ACOMP3 / EXT_VREF</td>
<td>I</td>
<td>ADC0 Channel 3&lt;br&gt;ACOMP0 Channel 3&lt;br&gt;ACOMP1 Channel 3&lt;br&gt;ADC or DAC external voltage reference input</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_45</td>
<td>I/O</td>
<td>General Purpose I/O 45</td>
</tr>
</tbody>
</table>

### Table 106: GPIO_46 (Offset=0xB8)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_CLK</td>
<td>I/O</td>
<td>SSP 2 Serial Clock</td>
</tr>
<tr>
<td>2</td>
<td>UART2_CTSn</td>
<td>I</td>
<td>UART 2 CTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_4 / ACOMP4</td>
<td>I</td>
<td>ADC0 Channel 4&lt;br&gt;ACOMP0 Channel 4&lt;br&gt;ACOMP1 Channel 4</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_46</td>
<td>I/O</td>
<td>General Purpose I/O 46</td>
</tr>
</tbody>
</table>
### Table 107: GPIO_47 (Offset=0xBC)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_FRM</td>
<td>I/O</td>
<td>SSP 2 Frame Indicator</td>
</tr>
<tr>
<td>2</td>
<td>UART2_RTSn</td>
<td>O</td>
<td>UART 2 RTSn (active low)</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_5 / ACOMP5</td>
<td>I</td>
<td>ADC0 Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 5</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_47</td>
<td>I/O</td>
<td>General Purpose I/O 47</td>
</tr>
</tbody>
</table>

### Table 108: GPIO_48 (Offset=0xC0)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_TXD</td>
<td>O</td>
<td>SSP 2 TXD</td>
</tr>
<tr>
<td>2</td>
<td>UART2_TXD</td>
<td>O</td>
<td>UART 2 TXD</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_6 / ACOMP6</td>
<td>I</td>
<td>ADC0 Channel 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 6</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_48</td>
<td>I/O</td>
<td>General Purpose I/O 48</td>
</tr>
</tbody>
</table>

### Table 109: GPIO_49 (Offset=0xC4)

<table>
<thead>
<tr>
<th>Function</th>
<th>Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:4</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>SSP2_RXD</td>
<td>I</td>
<td>SSP 2 RXD</td>
</tr>
<tr>
<td>2</td>
<td>UART2_RXD</td>
<td>I</td>
<td>UART 2 RXD</td>
</tr>
<tr>
<td>1</td>
<td>ADC0_7 / ACOMP7</td>
<td>I</td>
<td>ADC0 Channel 7</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP0 Channel 7</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ACOMP1 Channel 7</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_49</td>
<td>I/O</td>
<td>General Purpose I/O 49</td>
</tr>
</tbody>
</table>
6.2.2 I/O Padding Pin States

The I/O padding can be configured to pull-up, pull-down, or tri-state mode. The I/O pins are configured to default mode when selecting 1 PINMUX alternate function. When an I/O pin is set to a GPIO function and the data transfer direction is input, users can reconfigure the I/O pin to pull-up, pull-down, or tri-state mode by setting bits[15:13] and bit[3] of the corresponding I/O PINMUX Configuration register. See Section 24.17.2, PINMUX Registers (GPIO).

Table 110, I/O Pin Mode Configuration shows the configuration.

Table 110: I/O Pin Mode Configuration

<table>
<thead>
<tr>
<th>Bit Field of I/O PINMUX Configuration Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>[15]  [14]  [13]  [3]</td>
<td></td>
</tr>
<tr>
<td>0 0 X X 1</td>
<td>Pull-up and pull-down from PINMUX alternate function</td>
</tr>
<tr>
<td>1 1 0 1</td>
<td>Pull-up enabled</td>
</tr>
<tr>
<td>1 0 1 1</td>
<td>Pull-down enabled</td>
</tr>
<tr>
<td>1 1 1 1</td>
<td>Not allowed</td>
</tr>
<tr>
<td>1 0 0 0</td>
<td>Tri-state</td>
</tr>
</tbody>
</table>

1. X = don’t care

Figure 32 shows the I/O padding structure.

Figure 32: I/O Padding Structure
6.3 Functional Description

6.3.1 Block Diagram

Figure 33 shows an overall block diagram.

Figure 33: General Purpose I/O Block Diagram

6.3.2 GPIO Ports

The GPIO pins are mapped to port groups:

- GPIO_PORT0 – 32 pins (correspond to GPIO[31:0])
- GPIO_PORT1 – 18 pins (correspond to GPIO[49:32])

Individual GPIO pins within a port are numbered from 0 to 31 according to their bit positions within the GPIO registers.
6.3.3 I/O Control

All the GPIO pins are inputs by default. The direction of the GPIO pins is configured by programming the GPIO Pin Direction Register (GPDR (0, 1) registers) or the GPIO Set Direction Register-GSDR and GPIO Clear Direction Register-GCDR (0, 1) registers through the APB interface. When the system is in low-power mode, the input enable to the GPIOs should be disabled by setting the di_en (bit[3]) bit of the corresponding GPIO Configuration register in the PINMUX.

When configured as an input, GPIO can read the data on the external I/O pads and also serve as an interrupt. Interrupts are generated when the GPIO Rising Edge detect enable -GRER (0, 1) or GPIO Falling edge detect enable-GFER (0, 1) registers are configured. Rising and falling edges are detected using APB Clock Synchronized GPIO inputs. The status of edge detection can be read through the GPIO edge detect status-GEDR (0, 1) registers. The edge detect status is used to generate a combined interrupt from the GPIO block. Specific GPIO interrupts can also be masked by programming the APMASK register.

When configured as an output, the GPSR and GPCR (0, 1) registers are programmed to define the GPIO output port status.

The value of each GPIO port can be read through the GPIO Pin Level register-GPLR (read only) when the GPIO is configured as an input or output. This register can be read at any time to confirm the port state for the input configuration.

6.3.4 GPIO Interrupt

The GPIOs can be programmed to accept external signals as interrupt sources on any bit of the signal. The type of interrupt is programmable with either a rising or falling edge.

When the GPIO is configured as an input, this register is updated with the current level of the GPIO input after 12 cycles of the 200 MHz clock in the system.

When the GPIO is configured as an output, it requires a few GPIO clock cycles for the value to be updated in the GPLR register. The number of cycles required for updating the value depends on the CORE and GPIO clock frequencies and is specified as follows:

- Core runs at 32M and GPIO runs at 32M: After writing to GPSR, correct GPLR value is reflected in 3 GPIO clock cycles
- Core runs at 200M and GPIO runs at 50M: After writing to GPSR, correct GPLR value is reflected in 5 GPIO clock cycles

When the GPIO is configured as an input, this register is updated with the current level of the GPIO input after 12 cycles of the 200 MHz clock in the system.

The interrupts can be masked by programming the APMASK register. The interrupt status can be read before masking (called raw status) and after masking. A single combined interrupt is generated as output from the GPIO. All individual edges detected (as recorded in the GEDR registers) have to be masked, to mask the interrupt output. If the pin direction register is reprogrammed to output, then any pending interrupts are not lost. However, no new interrupts are generated.

When an edge is detected on a port that matches the type of edge programmed in the GRER and/or GFER registers, the corresponding status bit is set in GEDR registers. GEDR register value is updated with the current edge-detect status value after 12 cycles of the 200 MHz clock in the system from the occurrence of the edge.
6.3.5 External Interrupts

The 88MW320/322 external interrupt sources are directly connected to the Cortex-M4F NVIC module, an external interrupt pin can be used simultaneously by a peripheral device. All external interrupts are active high.

See Section 2.5, External Interrupts, on page 41 for an external interrupt mapping table for peripheral interrupts and interrupts from the GPIO.

6.4 Register Description

There are a total of 42 registers in the GPIO register block. For each 32 bits forming a GPIO port, there is a set of 14 registers. For up to 50 GPIOs, 3 GPIO_ports are defined. There are 3 instances of each of the 14 registers.

See Section 24.11.2, GPIO Registers for a detailed description of the registers.
7 WLAN

7.1 Overview

The 88MW320/322 integrates a highly integrated, single-band (2.4 GHz) IEEE 802.11n 1x1 WLAN subsystem, specifically designed to support next generation, high throughput data rates.

The subsystem provides the combined functions of CPU, memory, Media/Medium Access Controller (MAC), Direct Sequence Spread Spectrum (DSSS) and Orthogonal Frequency Division Multiplexing (OFDM) baseband modulation, direct conversion WLAN RF radio, and encryption. For security, the 802.11i security standard is supported through several protocols.

7.2 Features

- 1x1 SISO, 2.4 GHz, HT20 operation
- Antenna diversity
- CMOS and low-swing sine wave input clock
- Low power with deep sleep and standby modes
- Pre-regulated supplies
- Integrated T/R switch, PA, and LNA
- Optional 802.11n features
- One Time Programmable (OTP) memory to eliminate need for external EEPROM

7.3 WLAN MAC

- Simultaneous peer-to-peer and Infrastructure Modes
- RTS/CTS for operation under DCF
- Hardware filtering of 32 multicast addresses
- On-chip Tx and Rx FIFO for maximum throughput
- Open System and Shared Key Authentication services
- A-MPDU Rx (de-aggregation) and Tx (aggregation)
- Reduced Inter-Frame Spacing (RIFS) receive
- Management information base counters
- Radio resource measurement counters
- Quality of service queues
- Block acknowledgment extension
- Multiple-BSSID and Multiple-Station operation
- Transmit rate adaptation
- Transmit power control
- Long and short preamble generation on a frame-by-frame basis for 802.11b frames
- Mobile hotspot
7.4 WLAN Baseband
- 802.11n 1x1 SISO (on-chip NXP RF radio)
- Backward compatibility with legacy 802.11g/b technology
- PHY data rates up to 72.2 Mbps
- 20 MHz bandwidth/channel
- Modulation and Coding Scheme (MCS)—MCS 0~7
- Radio resource measurement
- Optional 802.11n SISO features:
  - 1 spatial stream STBC reception and transmission
  - Short guard interval
  - RIFS on receive path for 802.11n packets
  - 802.11n greenfield Tx/Rx
- Power save features

7.5 WLAN Radio
The 88MW320/322 direct conversion WLAN RF radio integrates all the necessary functions for transmit and receive operation. See Section 22.6, Clock Specifications, on page 281 and Section 22.12, WLAN Radio Specifications, on page 298 for associated electrical specifications.
Features include:
- Integrated direct-conversion radio
- 20 MHz channel bandwidth
- Integrated T/R switch, PA, and LNA

7.5.1 WLAN Rx Path
- Direct conversion architecture eliminates need for external SAW filter
- On-chip gain selectable LNA with optimized noise figure and power consumption
- High dynamic range AGC function in receive mode

7.5.2 WLAN Tx Path
- Integrated power amplifier with power control
- Optimized Tx gain distribution for linearity and noise performance

7.5.3 WLAN Local Oscillator
- Fractional-N for multiple reference clock support
- Fine channel step
7.5.4 Channel Frequencies Supported

Table 111 shows the channel frequencies supported.

Table 111: Channel Frequencies Supported

<table>
<thead>
<tr>
<th>20 MHz Channels</th>
<th>Frequency (GHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Channel</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>2.412</td>
</tr>
<tr>
<td>2</td>
<td>2.417</td>
</tr>
<tr>
<td>3</td>
<td>2.422</td>
</tr>
<tr>
<td>4</td>
<td>2.427</td>
</tr>
<tr>
<td>5</td>
<td>2.432</td>
</tr>
<tr>
<td>6</td>
<td>2.437</td>
</tr>
<tr>
<td>7</td>
<td>2.442</td>
</tr>
<tr>
<td>8</td>
<td>2.447</td>
</tr>
<tr>
<td>9</td>
<td>2.452</td>
</tr>
<tr>
<td>10</td>
<td>2.457</td>
</tr>
<tr>
<td>11</td>
<td>2.462</td>
</tr>
<tr>
<td>12</td>
<td>2.467</td>
</tr>
<tr>
<td>13</td>
<td>2.472</td>
</tr>
</tbody>
</table>

7.6 WLAN Encryption

- WEP 64- and 128-bit encryption with hardware TKIP processing (WPA)
- AES-CCMP hardware implementation as part of 802.11i security standard (WPA2)
- Enhanced AES engine performance
- AES-Cipher-Based Message Authentication Code (CMAC) as part of the 802.11w security standard
- WLAN Authentication and Privacy Infrastructure (WAPI)
8  Direct Memory Access (DMA) Controller

8.1  Overview

The 88MW320/322 Direct Memory Access Controller (DMAC) is an AMBA High Speed Bus (AHB) system level controller used to transfer data between peripherals and memory as well as memory to memory without CPU action.

The data stream is maintained in 32 DMA channels. Each channel is required for each source/destination pair. The DMAC has 1 AHB master interface and 1 AHB slave interface. The master interface reads the data from a source peripheral and writes the data to a destination peripheral. There are 2 AHB transfers required for each DMA data transfer.

8.2  Features

- Compliance to the AMBA specification for easy integration
- Memory-to-memory, memory-to-peripheral, and peripheral-to-memory transfers
- Priority mechanism to process active channels
- 32 DMA logic channels (each channel can support a unidirectional transfer)
- 16x32 bits physical channel space to store the data
- 64 hardware handshake interfaces support for on-chip peripherals
- Programmable data-burst size (4, 8, and 16) and programmable peripheral device data widths (byte, half-word or word)
- Up to 8191 bytes of data transfer
- AHB slave DMA programming interface (program DMAC by writing to DMA control registers over AHB slave interface)
- Separate and combined DMA interrupt requests (generate an interrupt to the processor on a DMA error or when a DMA transfer has completed). Interrupt request signals include:
  - BLOCK signals when a block transfer has completed.
  - TFR signals when a transfer has completed.
  - BUSERR signals when a bus error has occurred.
  - ADDRERR signals when a peripheral address alignment error has occurred.
- Interrupt masking (mask each individual DMA interrupt request)
8.3 Basic Definitions

- **Source peripheral** – Device from which the DMAC reads data; the DMAC then stores the data in the channel FIFO.
- **Destination peripheral** – Device to which the DMAC writes the data from the FIFO (previously read from the source peripheral).
- **Memory** – Source or destination that is always "ready" for a DMA transfer and does not require a handshaking interface to interact with the DMAC.
- **Channel** – Read/Write data path between a source peripheral and a destination peripheral that occurs through the channel FIFO. If the source peripheral is not memory, then a source handshaking interface is asserted to the channel. If the destination peripheral is not a memory, then a destination handshaking interface is asserted to the channel. Source and destination handshaking interfaces can be assigned dynamically by programming the channel registers.
- **Master interface** – DMAC is a master on the AHB bus, reading data from source and writing it to the destination over the AHB bus.
- **Slave interface** – The AHB interface over which the DMAC is programmed.
- **Handshaking interface** – A set of signals that conform to a protocol and handshake between the DMAC and source or destination peripheral in order to control transferring a single or burst transaction between them. This interface is used to request, acknowledge, and control a DMAC transaction.
- **Flow controller** – Device that determines the length of a DMA block transfer and terminates it.
- **Block** – Block of DMAC data, the amount of which is the block length and is determined by the flow controller. For transaction, a block is either a burst or single transfers.
- **Single transaction** – Length of a single transaction is always 1 and is converted to a single AHB transfer.
- **Burst transaction** – Length of a burst transaction is programmed into the DMAC. The burst transaction is converted into a sequence of AHB burst transfers. The burst transaction length is under program control and normally bears some relationship to the FIFO size in the DMAC and in the source and destination peripheral.
# 8.4 Interface Signal Description

## 8.4.1 Internal Signals Diagram

Figure 34: DMAC Internal Signals

![DMAC Internal Signals Diagram]

## 8.4.2 Clock and Reset Interface

Table 112: Clock Unit Interface Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Type</th>
<th>Source</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>hclk</td>
<td>input</td>
<td>Clock generator</td>
<td>System (AHB) bus clock</td>
</tr>
<tr>
<td>hresetn</td>
<td>input</td>
<td>Reset controller</td>
<td>Power-on reset that resets the logic running off of hclk. Asynchronous assertion and de-assertion. Clocks are turned off during de-assertion.</td>
</tr>
</tbody>
</table>
8.4.3 Interface to Handshake Interface

Table 113: Handshake Interface Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Type</th>
<th>Source</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>dma_request[63:0]</td>
<td>input</td>
<td>DMA peripheral</td>
<td>Burst transaction request from peripheral</td>
</tr>
<tr>
<td>dma_single[63:0]</td>
<td>input</td>
<td>DMA peripheral</td>
<td>Single transaction request from peripheral</td>
</tr>
<tr>
<td>dma_last[63:0]</td>
<td>input</td>
<td>DMA peripheral</td>
<td>Last transaction in block indicator</td>
</tr>
<tr>
<td>dma_ack[63:0]</td>
<td>output</td>
<td>DMA peripheral</td>
<td>Transaction complete acknowledge signal</td>
</tr>
<tr>
<td>dma_finish[63:0]</td>
<td>output</td>
<td>DMA peripheral</td>
<td>DMA block complete signal</td>
</tr>
</tbody>
</table>

8.4.4 DMA Interrupt Request Interface

Table 114: DMA Interrupt Request Interface Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Type</th>
<th>Source</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>dma_intr_r</td>
<td>output</td>
<td>Interrupt controller</td>
<td>Logic OR of all individual channel interrupts</td>
</tr>
<tr>
<td>dint_r[31:0]</td>
<td>output</td>
<td>Interrupt controller</td>
<td>Logic OR of all types inner interrupts within each channel</td>
</tr>
</tbody>
</table>

8.4.5 AHB Slave Interface

Table 115: AHB Slave Interface Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Type</th>
<th>Source</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>slv_haddr[31:0]</td>
<td>input</td>
<td>AHB master</td>
<td>System address bus</td>
</tr>
<tr>
<td>slv_hburst[2:0]</td>
<td>input</td>
<td>AHB master</td>
<td>Burst type indicates if the transfer is a single or forms part of a burst.</td>
</tr>
<tr>
<td>slv_hmastlock</td>
<td>input</td>
<td>AHB master</td>
<td>When high, the current transfer is part of a locked sequence.</td>
</tr>
<tr>
<td>slv_hprot</td>
<td>input</td>
<td>AHB master</td>
<td>The protection control signals provide additional information about a bus access and primarily intended for use by any module that wants to implement some level of protection.</td>
</tr>
<tr>
<td>slv_hready</td>
<td>input</td>
<td>AHB master</td>
<td>When HIGH, indicates to the master and all slaves that the previous transfer is complete.</td>
</tr>
<tr>
<td>slv_hsel</td>
<td>input</td>
<td>Decoder</td>
<td>Current transfer is intended for the selected slave.</td>
</tr>
<tr>
<td>slv_hsize[2:0]</td>
<td>input</td>
<td>AHB master</td>
<td>Size of the transfer</td>
</tr>
<tr>
<td>slv_htrans[1:0]</td>
<td>input</td>
<td>AHB master</td>
<td>Transfer type of the current transfer</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This can be: IDLE, BUSY, NONSEQUENTIAL and SEQUENTIAL.</td>
</tr>
<tr>
<td>slv_hwdata[31:0]</td>
<td>input</td>
<td>AHB master</td>
<td>The write data bus transfer data from the master to the slave during write operations.</td>
</tr>
<tr>
<td>slv_hwrite</td>
<td>input</td>
<td>AHB master</td>
<td>Transfer direction</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>When HIGH this signal indicates a write transfer and when LOW a read transfer.</td>
</tr>
</tbody>
</table>
Table 115: AHB Slave Interface Signals (Continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Type</th>
<th>Source</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>slv_hrdata</td>
<td>output</td>
<td>AHB master</td>
<td>The read data bus transfers data from bus slaves to bus master during read operations.</td>
</tr>
<tr>
<td>slv_hreadyout</td>
<td>output</td>
<td>AHB master</td>
<td>When HIGH, a transfer has finished on the bus. This signal can be driven LOW to extend a transfer.</td>
</tr>
<tr>
<td>slv_hresp</td>
<td>output</td>
<td>AHB master</td>
<td>The transfer response provides additional information on the status of a transfer.</td>
</tr>
</tbody>
</table>

8.4.6 AHB Master Interface

Table 116: AHB Master Interface Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Type</th>
<th>Source</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>mas_haddr[31:0]</td>
<td>output</td>
<td>AHB slave</td>
<td>System address bus</td>
</tr>
<tr>
<td>mas_hburst[2:0]</td>
<td>output</td>
<td>AHB slave</td>
<td>Burst type indicates if the transfer is a single or forms part of a burst.</td>
</tr>
<tr>
<td>mas_hmastlock</td>
<td>output</td>
<td>AHB slave</td>
<td>When high, the current transfer is part of a locked sequence.</td>
</tr>
<tr>
<td>mas_hprot</td>
<td>output</td>
<td>AHB slave</td>
<td>The protection control signals provide additional information about a bus access and primarily intended for use by any module that wants to implement some level of protection.</td>
</tr>
<tr>
<td>mas_hsize[2:0]</td>
<td>output</td>
<td>AHB slave</td>
<td>Size of the transfer</td>
</tr>
<tr>
<td>mas_htrans[1:0]</td>
<td>output</td>
<td>AHB slave</td>
<td>Transfer type of the current transfer This can be: IDLE, BUSY, NONSEQUENTIAL and SEQUENTIAL.</td>
</tr>
<tr>
<td>mas_hwdata[31:0]</td>
<td>output</td>
<td>AHB slave</td>
<td>Write data bus transfer data from the master to the slave during write operations</td>
</tr>
<tr>
<td>mas_hwrite</td>
<td>output</td>
<td>AHB slave</td>
<td>Transfer direction When HIGH this signal indicates a write transfer and when LOW a read transfer.</td>
</tr>
<tr>
<td>mas_hrd data</td>
<td>input</td>
<td>AHB slave</td>
<td>The read data bus transfers data from bus slaves to bus master during read operations.</td>
</tr>
<tr>
<td>mas_hready</td>
<td>input</td>
<td>AHB slave</td>
<td>When HIGH, a transfer has finished on the bus. This signal can be driven LOW to extend a transfer.</td>
</tr>
<tr>
<td>mas_hresp</td>
<td>input</td>
<td>AHB slave</td>
<td>The transfer response provides additional information on the status of a transfer.</td>
</tr>
</tbody>
</table>
8.5 Functional Description

8.5.1 32 Channels and Priorities

8.5.1.1 DMA Channels

The DMAC uses 32 channels to manage the stream transfer. Each of the 32 DMA channels can be controlled by 4, 32-bit registers: SADRx, TADRx, CTRLAx, and CTRLBx.

Each channel is serviced in increments of that device burst size and delivered in the granularity of the device port width. The burst size and port width for each device are programmed in the channel registers and are based on the device FIFO depth and bandwidth requirements. When multiple channels are actively executing, each channel is serviced with a burst of data. After each burst of data, the DMA controller performs a context switch to another active channel. The DMAC performs context switches based on whether a channel is active, whether its device is currently requesting service, and the channel priority.

8.5.1.2 DMA Channel-Priority Scheme

The DMA channel-priority scheme helps to ensure that peripherals are serviced according to their bandwidth requirements. Assign a higher priority to peripherals with higher bandwidth requirements and a lower priority to peripherals with lower bandwidth requirements. This assignment ensures that higher-bandwidth peripherals are services more often than lower-bandwidth peripherals.

The DMA channels are divided internally into 4 sets of 8 channels each. The channels in each set use a round-robin priority. Set 0 has the highest priority, and Set 3 has the lowest. Program the modules that have the most severe latency requirements into Set 0. See Table 117.

When all 32 channels are running concurrently, Set 0 is serviced 4 out of every 8 consecutive channel-servicing instances, Set 1 is serviced twice, and Set 2 and 3 are each serviced once.

For example, if all the channels request data transfers, the sets are prioritized in the following order: Set 0, Set 1, Set 0, Set 2, Set 0, Set 1, Set 0, Set 3. After 8 channel-servicing instances, the pattern repeats. The channels in each set are given a round-robin priority.

Table 117 shows the channel priority.

<table>
<thead>
<tr>
<th>Set</th>
<th>Channels</th>
<th>Priority</th>
<th>Number of Times Served</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0, 1, 2, 3, 16, 17, 18, 19</td>
<td>Highest</td>
<td>4/8</td>
</tr>
<tr>
<td>1</td>
<td>4, 5, 6, 7, 20, 21, 22, 23</td>
<td>Higher than 2 and 3, lower than 0</td>
<td>2/8</td>
</tr>
<tr>
<td>2</td>
<td>8, 9, 10, 11, 24, 25, 26, 27</td>
<td>Higher than 3, lower than 0 and 1</td>
<td>1/8</td>
</tr>
<tr>
<td>3</td>
<td>12, 13, 14, 15, 28, 29, 30, 31</td>
<td>Lowest</td>
<td>1/8</td>
</tr>
</tbody>
</table>
8.5.2 Enable/Stop Channel

8.5.2.1 Enable a Channel
Program CHL_ENx = 1'b1 to enable a channel. Programming DMA_CHL_ENx = 1'b0 is not recommended.

CHL_ENx will be cleared after the channel has finished all expected transfers. To stop a channel which has not finished all transfers, see Section 8.5.2.2, Stop a Running Channel.

A channel cannot be enabled to initiate a transfer if the channel interrupt is raised. It can only be enabled again after programming the corresponding interrupt (clear it by writing 1).

8.5.2.2 Stop a Running Channel
To stop a channel that has not finished all transfers, program CHL_STOPx = 1'b1. Channelx will stop immediately if the channel is not on service, and stop after the current transfer finished if the channel is on service. Poll the corresponding CHL_ENx to check whether the stop operation is successful since the operation may not be immediate.

After CHL_ENx is in a disabled state, CHL_STOPx is automatically cleared by hardware.

Programming CHL_STOPx = 1'b0 has no effect on the channel, which is already in a disabled state.

8.5.3 Transfer Type and Flow Controller
The DMAC transfer types include:
- Memory-to-Memory
- Memory-to-Peripheral
- Peripheral-to-Memory

The transfer type is programmed in the channel CTRLAx register based on the different source and target device type.

The DMAC is always assigned as the flow controller. The block size is known before the channel is enabled and should be programmed into the CTRLAx.LEN field. Peripherals may not be used as a flow controller.

8.5.4 Hardware Handshaking Interface
Handshaking interfaces are used at the transaction level to control the flow of single or burst transactions. Hardware handshaking is supported and accomplished using a dedicated handshaking interface.

Generally, the DMAC tries to transfer the data using burst transactions and, where possible, fill or empty the channel FIFO in single burst. In the latter case, the peripheral asserts a single status flag to indicate to the DMAC that there is enough data or space to complete a single transaction from or to the source/destination peripheral.

Figure 35 shows the hardware handshaking interface between a peripheral (whether a destination or source) and the DMAC when the DMAC is the flow controller.
There are some cases where a DMA block transfer cannot complete using only burst transactions. Typically this occurs when the block size is not a multiple of the burst transaction length. In these cases, the block transfer uses burst transactions up to the point where the amount of data left to complete the block is less than the amount of data in a burst transaction. At this point, the DMAC samples the "single" status flag and completes the block transfer using single transactions.

The single transaction region is the time interval where the DMAC uses single transactions to complete the block transfer. Burst transactions are exclusively used outside this region.

Table 118 shows the hardware handshaking signals.

### Table 118: Hardware Handshaking Interface Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
</table>
| dma_ack      | output  | DMAC acknowledge signal to peripheral  
The dma_ack signal is asserted after the data phase of the last AHB transfer in the current transaction -single or -burst- to the peripheral that has completed. For a single transaction, dma_ack remains asserted until the peripheral de-asserts dma-single; dma_ack is de-asserted 1 hclk cycle later. For a burst transaction, dma_ack remains asserted until the peripheral de-asserts dma_req; dma_ack is de-asserted 1 hclk cycle later. |
| dma_finish   | output  | DMAC asserts dma_finish to signal block completion  
This has the same timing as dma_ack and forms a handshaking loop with dma_req is the last transaction in the block was a burst transaction, or with dma_single if the last transaction in the block was a single transaction. |
| dma_last     | input   | Since the peripheral is not the flow controller, dma_last is not sampled by the DMAC and this signal is ignored. |
| dma_req      | input   | Burst transaction request form peripheral  
The DMAC always interprets the dma_req signal as a burst transaction request, regardless of the level of the dma_single. This is a level-sensitive signal; once asserted by the peripheral, dma_req must remain asserted until the DMAC asserts dma_ack. Upon receiving the dma_ack signals from the DMAC to indicate the burst transaction is complete, the peripheral should de-asserted the burst request signal dma_req. Once dma_req is de-asserted by the peripheral, the DMAC de-asserts dma_ack. This signal is sampled by DMAC only outside the single transaction region. |
Figure 36 shows the timing diagram of a burst transaction where the peripheral clock (per_clk) is half of the hclk frequency. In this example, the peripheral is outside the single transaction region, and the DMAC does not sample dma_single.

**Figure 36: Burst Transaction – hclk=2*per_clk**

The handshaking loop is as follows:
- dma_req asserted by peripheral
- dma_ack asserted by DMAC
- dma_req de-asserted by peripheral
- dma_ack de-asserted by DMAC
Figure 37 shows 2 back-to-back burst transactions at the end of a block transaction where the hclk frequency is twice the pclk frequency. The peripheral is an APB peripheral. The second burst transaction terminates the block, and dma_finish is asserted to indicate block completion.

Figure 37: Back-to-Back Burst Transaction – hclk=2*per_clk

When designing the hardware handshaking interface, note that:

- Once asserted, the dma_req must remain asserted until the corresponding dma_ack signal is received, even if the condition that generates dma_req in the peripheral is False.
- The dma_req signal should be de-asserted when dma_ack is asserted, even if the condition that generates dma_req in the peripheral is true.
Figure 38 shows a single transaction that occurs in the single transaction region.

Figure 38: Single Transaction – hclk=2*per_clk

The handshaking loop is as follows:
- dma_single asserted by peripheral
- dma_ack asserted by DMAC
- dma_single de-asserted by peripheral
- dma_ack de-asserted by DMAC
Figure 39 shows a burst transaction, followed by 2 back-to-back single transactions, where the hclk frequency is twice the per_clk frequency.

Figure 39: Burst Followed by Back-to-Back Single Transactions

After the first burst transaction, the peripheral enters the single transaction region and the DMAC starts sampling dma_single. DMAC samples that dma_single is asserted and performs single transactions. The second single transaction terminates the block transfer; dma_finish is asserted to indicate block completion.
8.5.5 Interrupt Management

There are 4 types of interrupt source:
- **BLOCKINT** – Block Transfer Complete Interrupt
  This interrupt is generated on DMA block transfer completion to the destination peripheral.
- **TFRINT** – DMA Transfer Complete Interrupt
  This interrupt is generated on DMA transfer completion to destination peripheral.
- **BUSERROR** – AHB Bus Error Interrupt
  This interrupt is generated when an error response is received from AHB slave.
- **ADDRERRINT** – Address Configuration Error Interrupt
  This interrupt is generated when the on-chip peripheral address is not aligned to width.

There are several groups of interrupt-related registers:
- **MASK_BLOCKINT, MASK_TFRINT, MASK_BUSERRINT, MASK_ADDRERRINT**
- **STATUS_BLOCKINT, STATUS_TFRINT, STATUS_BUSERRINT, STATUS_ADDRERRINT**
- **STATUS_CHLINT**

When a channel has been enabled to generated interrupts:
- Interrupt events are stored in the STATUS registers
- Contents of the STATUS registers are masked with the contents of MASK registers
- Masked interrupts are stored in the STATUS_CHLINT register
- Contents of STATUS_CHLINT are used to drive dma_int_r and dint_r
- Writing to the appropriate bit in STATUS registers clears an interrupt in STATUS registers
- Each mask and status interrupt register has a bit allocated per channel

8.5.6 Transfer Operation Example

Transfers are set up by programming registers for that channel. As shown in Figure 26, a single block is made up of numerous transactions -single and burst - which are in turn composed of AHB transfers. A peripheral requests a transaction through the handshaking interface to the DMAC.

The following examples show the effect of different settings on a DMA block transfer.
- Memory-to-Peripheral (assumed that peripheral 0 and channel 0 are used)
  - Polling the DMA_CHANNEL[0].CHL_EN.CHLEN status, if channel0 in disable status, then it can initiate a new transfer, otherwise, channel0 is serving another transfer and can't use it now.
  - Program DMA_CHANNEL[0].CTRLB.PERNUM = 6'b00_0000.
  - Program DMA_CHANNEL[0].CTRLA fields:
    - DMA_CHANNEL[0].CTRLA.INCSRCADDR = 1'b1
    - DMA_CHANNEL[0].CTRLA.INCTRGRADDR = 1'b0
    - DMA_CHANNEL[0].CTRLA.TRAN_TYPE = 2'b01
    - DMA_CHANNEL[0].CTRLA.TRAN_SIZE = 2'bxx
    - DMA_CHANNEL[0].CTRLA.WIDTH = 2'bxx
    - DMA_CHANNEL[0].CTRLA.LEN = 13bx_xxxx_xxxx_xxxx
  - Program SADR0 and TADR0 respectively to the memory and peripheral addresses. The peripheral address should be aligned to DMA_CHANNEL[0].CTRLA.WIDTH, otherwise, ADDRERRINT[0] will occur and the transfer will be stopped if it is not been masked.
  - Program the MASK registers to decide which type of interrupt should be visible to CPU.
8.6 Register Description

See Section 24.2.2, DMAC Registers for a detailed description of the registers.
9  Real Time Clock (RTC)

9.1  Overview
The 88MW320/322 Real Time Clock (RTC) registers are controlled through the APB bus. The RTC is optimized for a counter in the Always ON (AON) domain.

9.2  Features
- Selectable clock source
- Programmable clock divider
- 32-bit Up counter with a programmable upper overflow boundary
- Interrupt is generated on the counter clock when it reaches the upper boundary

9.3  Functional Description

9.3.1  Block Diagram
Figure 40 shows an overall block diagram.

Figure 40: RTC Block Diagram

9.3.2  Counter Clock
The clock source of the RTC comes from the PMU. It can be set to XTAL32K or RC32K through RTC_INT_SEL bits in PERI_CLK_SRC register of PMU module. To avoid any potential issues, stopping the counter is required before changing the clock source. Reset the counter after changing the clock source.

The RTC can divide the clock simultaneously. CLK_DIV stores the clock division factor. The clock division formula is:

\[
\text{counter\_clock\_divide} = \frac{\text{counter\_clock}}{2^{\text{CLK\_DIV}}}
\]

For example, if a timer clock divider register is set to 2, then the timer gets 1 tick every 4 clock ticks. The bit width of a clock divider register is 4, which makes the maximum value of CLK_DIV as 15 and the maximum division ratio as 32768:1.
9.3.3 Counting Mode

The RTC counter works in a counting-up mode. UPP_VAL defines the upper boundary of the counter; default value is 0xFFFFFFFF, the maximum counter value. The lower boundary is always 0.

The RTC counter value increments until reaching the upper boundary defined by UPP_VAL (event counter-reach-upper). In the next tick, the counter resets to 0 and begins counting up again. Upon a counter reset (write 1 to CNT_RESET), the counter resets to 0. A full cycle from 0 to UPP_VAL consists of UPP_VAL+1 counter ticks. Figure 41 shows the timing.

*Figure 41: Count-up Mode Timing*

![Count-up Mode Timing Diagram]

9.3.4 Counter Update Mode

The counter value can be read from the APB bus through the register CNT_VAL. The update mode of CNT_VAL can be configured using CNT_UP_MOD.

Table 119 shows the configuration.

<table>
<thead>
<tr>
<th>CNT_UPDT_MOD</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Auto-update</td>
</tr>
<tr>
<td></td>
<td>CNT_VAL is updated on every counter clock tick</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Update off</td>
</tr>
</tbody>
</table>

Table 119: Counter Update Mode

9.3.5 Interrupt

When the counter reaches the UPP_VAL, the CNT_UPP_INT bit in the INT_RAW register is set to 1. Interrupt status bits are always enabled to be set in the INT_RAW register. The interrupt status bit can be cleared by writing 1 to the corresponding bit in the INT_RAW register. Each interrupt status has a corresponding mask in the INT_MSK register. If the corresponding mask is set to 1, the interrupt status does not assert the interrupt. By default, all bits are masked. The INT register is the masked result of INT_RAW register. The interrupt is asserted if any of the bits in INT register is 1.
9.4 Programming Notes

9.4.1 Initialization

1. Before using the RTC, poll the STS_RESETN bit to be set.
2. Program various parameters
   a) Select clock source with RTC_INT_SEL bit in PERI_CLK_SRC register of PMU module.
   b) Set counter upper value in UPP_VAL.
   c) If the counter value needs to be read out, program CNT_UPDT_MOD to 0x2. Otherwise, leave it at 0x0
3. Write 1 to CNT_RESET to reset the counter. Poll CNT_RST_DONE bit to be set to determine when the counter finishes resetting. Do not access any other registers until CNT_RST_DONE is 1.
4. Write 1 to CNT_START to start the counter. Poll CNT_RUN bit to be set to determine when the counter begins to count.

9.4.2 UPP_VAL

The value written to UPP_VAL is not valid immediately. It is not effective until the counter overflows. To make the value valid immediately, write 1 to CNT_RESET.

9.5 Register Description

10 Watchdog Timer (WDT)

10.1 Overview
The 88MW320/322 Watchdog Timer (WDT) regains control in case of system failure (due to a software error) to increase application reliability. The WDT can generate a reset or an interrupt when the counter reaches a given timeout value.

10.2 Features
- WDT module gets clock from APB clock
- 32-bit down counter with the minimal timeout value of 65536
- Configurable reset or interrupt generation with the given timeout value
- Supports 8 types of reset pulse length

10.3 Functional Description

10.3.1 Counter Operation
The watchdog counter descends from a preset (timeout) value to 0. The timeout value is obtained by the formula of $2^{16+\text{WDT.TORR.TOP} .\text{INIT}}$ or $2^{16+\text{WDT.TORR.TOP}}$. The register bit WDT.TORR.TOP.INIT is only used to initialize timeout period for the first counter restarts, which should be written after reset and before the WDT is enabled. The register bit WDT.TORR.TOP is used to select the timeout period from which the WDT count restarts. Depending on the output response mode selected, when the counter reaches 0, either a system reset or an interrupt occurs. The output response mode is set using the WDT.CR.RMOD register bit. WDT.CR.RMOD = 0 generates a system reset and WDT.CR.RMOD = 1 first generates an interrupt. If it is not cleared before a second timeout occurs then, a system reset is generated.

Users can restart the counter to its initial value (timeout value) by writing to the restart register WDT.CRR[7:0] at any time. The process of restarting the watchdog counter is sometimes referred to as "kicking the dog." As a safety feature to prevent accidental restarts, the value 0x76 must be written to the current counter value register (WDT.CRR).

10.3.2 Interrupt
The WDT can be programmed to generate an interrupt (and then a system reset) when a timeout occurs. When WDT.CR.RMOD is programmed to 1, the WDT generates an interrupt. If it is not cleared by the time a second timeout occurs, then it generates a system reset. If a restart occurs at the same time the watchdog counter reaches 0, an interrupt is not generated.

Figure 42 shows the timing diagram of the interrupt being generated and cleared. The interrupt is cleared by reading the WDT.EOI register in which no kicks required. The interrupt can also be cleared by a "kick" (watchdog counter restart).
10.3.3 System Reset

When bit WDT.CR.RMOD is programmed to 0, the WDT generates a system reset when a timeout occurs. Figure 43 shows the timing diagram of the WDT system reset.

10.3.4 Reset Pulse Length

The reset pulse length is the number of pclk cycles for which a system reset is asserted. When a system reset is generated, it remains asserted for the number of cycles specified by the reset pulse length or until the system is reset (by the Reset Controller). A counter restart has no effect on the system reset once it has been asserted. The reset pulse length is set by programmed the WDT.CR.RPL register field. The register bits can be programmed to 8 types of pulse length. The reset pulse is selected by balancing reset reliability and reset latency. A longer reset pulse provides a more reliable reset but may result in longer reset latency.
10.4 Initialization Sequence

When the counter reaches 0, depending on the output response mode selected, either system reset or an interrupt occurs.

The following sequence of operations must be followed to start the watchdog timer.
1. Configure the WDT in Generate Reset mode by setting WDT.CR.RMOD to 0.
2. Configure timeout value.
3. Set WDT.CR.WDT.EN to 1'b1.

The following sequence of operations must be followed to start the watchdog timer to generate an interrupt.
1. Configure WDT in Generate Interrupt mode by setting WDT.CR.RMOD to 1.
2. Configure timeout value.
3. Set WDT.CR.WDT.EN to 1'b1.

10.5 Register Description

See Section 24.18.2, WDT Registers for a detailed description of the registers.
11 General Purpose Timers (GPT)

11.1 Overview
The 88MW320/322 includes 4, 32-bit GPTs. Registers are controlled through the APB bus.

11.2 Features
Each GPT is a multi-purpose counter that supports the following:
- Selectable clock source
- Programmable clock divider and pre-scaler
- 32-bit up counter
- 6 independent channels with multiple modes
- Input capture for external inputs
- Edge-aligned and Center-aligned Pulse Width Modulation (PWM)
- "1-shot" mode to trigger a 1-time output change and interrupt
- Auto-trigger ADC/DAC module for PWM mode
- DMA transfer for input capture
- Interrupt generation on counter and channel events

11.3 Interface Signal Description
Table 120 shows the interface signals.

Table 120: GPT Interface Signals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPTx.CHx</td>
<td>I/O</td>
<td>Timer Number and Channel Number</td>
</tr>
<tr>
<td>GPTx.CLKIN</td>
<td>I</td>
<td>Clock</td>
</tr>
</tbody>
</table>
11.4 Functional Description

Each timer supports as many as 6 channels. Each channel shares the same clock source but has a separate set of registers for configuration. In this way, each channel can serve different applications independently. The register prefix CHx means that register is for the Channel x.

11.4.1 Block Diagram

Figure 44 shows an overall block diagram.

Figure 44: GPT Block Diagram
11.4.2 Counter

11.4.2.1 Counter Clock

Counter Clock Source
The clock source of the timer can be selected with CLK_SRC in CLK_CNTL register in the GPT. There are 2 choices available:
- Clock 0 (default) from PMU
- Clock 1 from the GPIO

Clock 0 can be chosen from multiple sources. Details regarding the sources of Clock 0 are in the PMU and Clocking registers description. When using Clock 1, the corresponding GPIO function must be programmed to the appropriate value, and the pad must be connected to a clean external clock. To avoid any potential issues, stopping the counter is necessary before changing the clock source. Reset the counter after changing the clock source.

Figure 45 shows the clock source selection.

Figure 45: Clock Source Selection

Clock Pre-Scaling and Division
The GPT can divide and pre-scale the clock simultaneously. The combination of the divider and pre-scalar allows for many possible integer ratios within the range. CLK_PRE can linearly pre-scale the counter clock using the formula:
\[
\text{counter\_clock\_prescale} = \frac{\text{counter\_clock}}{\text{CLK\_PRE} + 1}
\]
Each pre-scaler has 8 bits, allowing a scaling factor from 1 to 256.

After the clock pre-scaling, the resulting clock can be further divided down. CLK_DIV stores the clock division factor. The clock division formula is:
\[
\text{counter\_clock\_divide} = \frac{\text{counter\_clock\_prescale}}{2^{\text{CLK\_DIV}}}
\]
For example, if a timer clock divider register is set to 2, then the timer gets 1 tick every 4 clock ticks. The bit width of a clock divider register is 4, which makes the maximum value of CLK_DIV as 15 and the maximum division ratio as 32768:1.
11.4.2.2 Counting Mode

The GPT always counts up. UPP_VAL defines the upper boundary of the counter. The main counter counts from 0 to UPP_VAL, overflows to 0 and continues counting. A full cycle from 0 to UPP_VAL consists of UPP_VAL+1 counter ticks. The CNT_UPP_STS status bit is set upon an overflow. Upon a count reset (write 1 to CNT_RESET), the counter resets to 0.

The value written to UPP_VAL is not valid immediately. It is not effective until the counter overflows. To make the value valid immediately, write 1 to CNT_RESET.

Figure 46 show the count-up mode timing.

11.4.2.3 Counter Update Mode

The counter can be read from the APB bus through the register CNT_VAL. Updates to CNT_VAL are determined by CNT_UPDT_MOD. Table 121 shows the configuration.

Table 121: Counter Update Mode Configuration

<table>
<thead>
<tr>
<th>CNT_UPDT_MOD</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>Update Off&lt;br&gt;If CNT_VAL does not need to be read, CNT_UPDT_MOD can be set to off to save power.</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Auto-update Fast&lt;br&gt;Used when counter clock is at least 5 times slower than the APB clock. CNT_VAL is updated on every counter clock tick.</td>
</tr>
<tr>
<td>0</td>
<td>Auto-update Normal&lt;br&gt;Can be used for any clock relationship between the counter clock and the APB clock. Only every 3-4 counter ticks are updated to CNT_VAL.</td>
</tr>
</tbody>
</table>
11.4.3 Interrupts

Table 122 shows the type of events that can generate interrupts.

<table>
<thead>
<tr>
<th>Event</th>
<th>Availability</th>
</tr>
</thead>
<tbody>
<tr>
<td>Channel status</td>
<td>Yes</td>
</tr>
<tr>
<td>Channel error status</td>
<td>Yes</td>
</tr>
<tr>
<td>Reach UPP_VAL</td>
<td>Yes</td>
</tr>
<tr>
<td>DMA overflow</td>
<td>Yes</td>
</tr>
</tbody>
</table>

Registers used to control the interrupts include STS, INT, and INT_MSK. They all have corresponding bits in the same location. The status bits are in the STS register. Various events in the timer set the status bits automatically. The status bit can be cleared by writing 1 to the corresponding bit in STS.

Each status bit has a corresponding mask in INT_MSK register. If the mask bit is set to 1, the status bit is masked and does not generate an interrupt. If the mask bit is 0, then the status bit can generate an interrupt. By default, all bits are masked.

The INT register is the masked result of the STS register. If the mask bit is 1, then the corresponding bit in the INT register is 0. If the mask bit is 0, then the corresponding bit in the INT register is the same value as that in STS register.

The interrupt is asserted if any of the bits in INT register is 1.

11.4.4 Channel Operation Modes

11.4.4.1 Counter Match Register 0 and 1 (CMR0 and CMR1)

CMR0 and CMR1 are a pair of multipurpose registers for each channel. In input-capture mode, CMR0 is used to store the captured values. In all other modes, CMR0 and CMR1 are used to determine counter parameters.

The flow of updating the values of CMR0 and CMR1 is as follows:
1. Write new values to CMR0 and CMR1.
2. Write 1 to Chx_CMR_UPDT in the USER_REQ register.
3. Check the value of Chx_ERR_STS, if it is 0, it means CMR0 and CMR1 are updated successfully; if it is 1, clear Chx_ERR_STS, and repeat Steps 2-3.

11.4.4.2 No Function Mode

Set Chx_IO to 0 to configure the channel to no function. The channel does nothing and does not set the status bit. Set unused channels to this mode to save power and avoid unpredictable behaviors.
11.4.4.3 Input Capture Mode

Set CHx_IO to 1 to configure the channel to input-capture mode.

In input-capture mode, the channel waits for 1 of 2 trigger events to occur:

- An external trigger can come from a GPIO. The timer samples the edge transition using a fast sampling clock.
- Write to CHx_USER_ITRIG (x = 1, 2, 3, 4, or 5) to generate a software trigger.

CMR0 is the capture register.

The external trigger event can be a rising or falling edge. An external trigger event is considered valid after being filtered with the settings programmed in the IC_CNTL and CHx_CNTL registers. Space external triggers sufficiently apart relative to the sampling parameters to allow sufficient time to read out the value before the next capture. Small glitches can be filtered using the input capture registers, but in general the triggers should be clean.

Each valid trigger event sets the channel status bit CHx_STS.

A valid trigger event can be generated manually by writing 1 to CHx_USER_ITRIG. This Write bypasses any sampling filters in IC_CNTL register. In this mode, during the tick where a trigger event occurs, the counter value is copied to the capture register.

Figure 47 shows the input capture mode timing.

Figure 47: Input Capture Timing

DMA

In input-capture mode, CHx_CMR0 is shared as a capture register. If the captured value is required to be stored in memory by DMA, the general-purpose timer provides hardware handshake signals to automate this process. The DMA signals follow the protocol of the DMA Controller.

To enable the DMA function:
1. Set DMAz_EN (z=0,1) in the DMA_CNTL_EN register to 0.
2. Select GPT channel x as the source by programming DMAz_CH = x.
3. Program CHx_CNTL to set channel x to input capture.
4. Set DMAz_EN to 1 to enable the DMA channel.

On the DMA Controller:
1. Write to the DMA_HS register in system control module to set DMA handshake mapping.
2. Set SAR to the address of the capture register (CHx_CMR0).
3. Set DAR to the memory address.
4. In the CTL register:
   a) Write to SRC_TR_WIDTH and DST_TR_WIDTH to set the transfer width to 32 bits.
b) Write to SRC_MSIZE and DEST_MSIZE to set the burst transfer length to 1 item.
c) Write to TT_FC to set the transfer type to peripheral-to-memory.
d) Write to BLOCK_TS to configure the transfer length.
e) Set SINC to maintain source address.
f) Set DINC to make destination address increase.

5. In CFG register, set HS_SEL_SRC and HS_SEL_DST to select hardware handshaking; set SRC_PER and DST_PER to assign hardware handshaking interfaces.

11.4.4.4 1-Shot Pulse Mode

Set CH_IO to 4 to configure the channel to 1-shot pulse mode. See Table 123 and Figure 48.

Table 123: 1-Shot Pulse Control Registers

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Positive Polarity</td>
<td>Positive pulse</td>
</tr>
<tr>
<td>(POL = 0)</td>
<td></td>
</tr>
<tr>
<td>Negative Polarity</td>
<td>Negative pulse</td>
</tr>
<tr>
<td>(POL = 1)</td>
<td></td>
</tr>
<tr>
<td>Duty Cycle</td>
<td>CMR0</td>
</tr>
<tr>
<td>Period</td>
<td>CMR0 + CMR1</td>
</tr>
</tbody>
</table>

- Generates a single pulse
- Setting CMR1 to 0 results in an instant pulse generation
- Setting CMR0 to 0 results in no pulse, but the status bit remains set at the end of period

Write 1 to CHx_RST to generate 1 pulse:
1. After the channel reset, the 1 state resets to POL.
2. Wait CMR1 cycles, then change output state to the reverse value of POL.
3. Wait CMR0 cycles, then change output state to POL and set the channel status bit.

Figure 48: 1-Shot Pulse

![Figure 48: 1-Shot Pulse](image-url)
11.4.4.5 1-Shot Edge Mode
Set CH_IO to 5 to configure the channel to 1-shot edge mode. This mode generates a single edge transition. Setting CMR1 to 0 results in an instant edge transition. See Figure 49.

Write 1 to CHx_RST to generate 1 edge transition:
1. Channel reset.
2. Wait CMR1 cycles, then invert the current output state and set the channel status bit.

Figure 49: 1-Shot Edge Timing

11.4.4.6 Pulse Width Modulation (PWM) Edge-Aligned Mode
Set CH_IO to 6 to configure the channel to PWM edge-aligned mode. See Table 124 and Figure 50, PWM Edge-Aligned, on page 158.

Table 124: PWM Edge-Aligned Control Registers

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Positive Polarity (POL = 0)</td>
<td>High -&gt; Low</td>
</tr>
<tr>
<td>Negative Polarity (POL = 1)</td>
<td>Low -&gt; High</td>
</tr>
<tr>
<td>Duty Cycle</td>
<td>CMR0</td>
</tr>
<tr>
<td>Period</td>
<td>CMR0 + CMR1</td>
</tr>
</tbody>
</table>

PWM edge-aligned is a periodic square waveform aligned to the starting edge of the period. To adjust the duty cycle, subtract a number from either CMR0 or CMR1 and add it to the other, thereby keeping the period the same.

Setting CMR0 to 0 results in a 0% duty cycle, and setting CMR1 to 0 results in a 100% duty cycle. Setting both CMR0 and CMR1 to 0 pauses the PWM. The output remains at the previous state and no additional interrupts are generated. To restart the PWM, set at least 1 CMR0 or CMR1 to a non-0 value, then write 1 to CHx_CMR_UPDT.

The behavior of the PWM Edge-Aligned mode is as follows:
1. Change CH_IO to 6.
2. Channel reset – Output state is first reset to POL.
3. On the next counter tick, output state changes to the reverse value of POL.
4. Wait CMR0 cycles, then set the output state to POL.
5. Wait CMR1 cycles, then set the output state to the reverse value of POL and set the channel status bit.
6. Repeat 4-5.
Figure 50: PWM Edge-Aligned
11.4.4.7 Pulse Width Modulation (PWM) Center-Aligned Mode

Set CH_IO to 7 to configure the channel to PWM center-aligned mode. See Table 125 and Figure 51, PWM Center-Aligned, on page 160.

Table 125: PWM Center-Aligned Control Registers

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Positive Polarity (POL = 0)</td>
<td>Low -&gt; High -&gt; High -&gt; Low</td>
</tr>
<tr>
<td>Negative Polarity (POL = 1)</td>
<td>High -&gt; Low -&gt; Low -&gt; High</td>
</tr>
<tr>
<td>Duty Cycle</td>
<td>2 x CMR0</td>
</tr>
<tr>
<td>Period</td>
<td>2 x CMR0 + 2 x CMR1</td>
</tr>
</tbody>
</table>

PWM center-aligned is a periodic square waveform aligned to the center of the period. To adjust the duty cycle, subtract a number from either CMR0 or CMR1 and add it to the other, thereby keeping the period the same.

Setting CMR0 to 0 results in a 0% duty cycle, and setting CMR1 to 0 results in a 100% duty cycle. Setting both CMR0 and CMR1 to 0 pauses the PWM. The output remains at the previous state and no additional interrupts are generated. To restart the PWM, set at least 1 CMR0 or CMR1 to a non-0 value.

The behavior of the PWM Center-Aligned mode is as follows (see Figure 51, PWM Center-Aligned, on page 160):

1. Change CH_IO to 7.
2. Write 1 to CHx_RST – Output state is first reset to POL.
3. Wait CMR1 cycles, then set the output state to the reverse value of POL.
4. Wait 2x CMR0 cycles, then set the output state to POL.
5. Wait CMR1 cycles, then set the channel status bit.
6. Repeat steps 3, 4, and 5.
Figure 51: PWM Center-Aligned

Positive PWM signal (polarity bit = 0)

Negative PWM signal (polarity bit = 1)

CMR0: Counter Match Register 0
CMR1: Counter Match Register 1
11.4.5 ADC Trigger

The ADC trigger is available only in GPT0 and GPT1.

The ADC trigger is a hardware handshake signal that periodically signals the Analog-Digital Converter (ADC) to begin a data conversion. The ADC trigger source can be selected from the 6 GPT channels using TRIG_CHSEL bits in the TCR register. The selected GPT channel must be in a PWM mode for the ADC trigger to assert. The ADC trigger can be delayed from the end of the PWM period by programming TRIG_DLY bits in the TDR register. When TRIG_EN equals 1, the ADC trigger is enabled. See Figure 52.

- TRIG_DLY has a 4-cycle resolution which allows the delay to cover the maximum period for the PWM Center-Aligned mode
- Effect of ADC delay must be shorter than PWM period
- PWM period must be longer than ADC conversion time

Figure 52: ADC Trigger for PWM Edge-Aligned and Center-Aligned
11.4.6 DAC Trigger
The DAC trigger—available only in GPT2 and GPT3—is a hardware handshake that signals the DAC to begin a conversion. The DAC trigger source can be selected from the 6 GPT channels using TRIG_CHSEL bit in the TCR register. The selected GPT channel must be in a PWM mode for the DAC trigger to assert. The DAC trigger can be delayed from the end of PWM period by programming TRIG_DLY bits in the TDR register. The DAC trigger is enabled when TRIG_EN = 1. See Figure 53.

- TRIG_DLY has a 4-cycle resolution which allows the delay to cover the maximum period for the PWM Center-Aligned mode
- TRIG_DLY delay time must be shorter than the PWM period
- PWM period must be longer than the DAC conversion time

Figure 53: DAC Trigger for PWM Edge-Aligned and Center-Aligned
11.5 Programming Notes

11.5.1 Initialization

1. Before using the GPT, poll STS_RESETN bit to be set.
2. Program various parameters:
   a) Select clock source with CLK_SRC. If CLK_SRC is set to 0, corresponding registers in PMU module should be configured for further clock source selection.
   b) Select clock prescalar and divider values in CLK_PRE & CLK_DIV.
   c) Set counter upper value in UPP_VAL.
   d) If the counter value needs to be read out, program CNT_UPDT_MOD. Otherwise, leave it at 0x0.
   e) Set CH_IO to select channel mode and configure related parameters for the channels to be used.
3. Write 1 to CNT_RESET to reset the counter. Poll CNT_RST_DONE for a 1 to determine when the counter finishes resetting. Do not access any other registers until CNT_RST_DONE is 1.
4. Write 1 to CNT_START to start the counter. Poll CNT_RUN for a 1 to determine when the counter begins to count.
5. If GPT channels are used, write 1 to CHx_RST to enable the corresponding channel.

11.5.2 UPP_VAL

The value written to UPP_VAL is not valid immediately. It is not effective until the counter overflows. To make the value valid immediately, write 1 to CNT_RESET.

11.5.3 User Request Register

The User Request Register (USER_REQ) performs various operations on each channel. Operations are not pipelined and must be synchronized to the proper clock domain, so operations in the USER_REQ register must not be performed in quick succession. The definition of quick succession in this case is 5 counter clock cycles.

For example, if a Write is to perform a channel reset, wait at least 5 counter clock cycles before performing the next channel reset. When the counter-clock frequency is close to the APB clock frequency, the quick succession delay can be easily waited out with just a few extra register accesses. When the counter clock frequency is much slower than the APB clock, then the safest way is to read CNT_VAL and wait 5 counter clock cycles to pass.

11.6 Register Description

12 Advanced Encryption Standard (AES)

12.1 Overview
The 88MW320/322 AES engine provides fast and energy efficient hardware encryption and decryption service for the device.

12.2 Features
- Supports as many as 6 block cipher modes: ECB, CBC, CTR, CCM*, MMO, and Bypass
- Supports 128-, 192-, and 256-bit keys
- Efficient CPU/DMA access support
- Interrupt on finished AES operation, input FIFO full and output FIFO empty
- Error indication for each block cipher mode
- Separate 4*32-bit input and output FIFO
12.3 Functional Description

The AES module implements ECB, CBC, CTR, CCM*, MMO, and Bypass block cipher modes by efficient hardware.

12.3.1 AES Operational Flow

*Figure 54* shows the AES operational flow.

*Figure 54: AES Operational Flow*
12.3.2 AES Configuration

Ensure correct configuration before starting the AES engine by following these steps:

1. Set AES engine to encrypt or decrypt by clearing/setting AES.CTRL1.DECRYPT
2. Configure AES block cipher mode by setting AES.CTRL1.MODE, 0 for ECB mode, 1 for CBC mode, 2 for CTR mode, 5 for CCM* mode, 6 for MMO mode and 7 for BYPASS mode
3. Configure AES key size. AES engine supports 3 types of key size: 128-, 192-, and 256-bit. Configure AES key size parameter by setting AES.CTRL1.KEY_SIZE
4. Fill the key according to key size. AES engine contains 8, 32-bit key registers defined as AES.KEY0, AES.KEY1, AES.KEY2, AES.KEY3, AES.KEY4, AES.KEY5, AES.KEY6 and AES.KEY7. When key size is set to 128-bit, then AES.KEY7/6/5/4 is used. When key size is set to 192-bit, then AES.KEY7/6/5/4/3/2 is used. When key size is set to 256-bit, then AES.KEY7/6/5/4/3/2/1/0 is used. However, MMO does not support 192- and 256-bit key size, and key size is ignored in Bypass mode.
5. For all modes except CCM* mode, set input data size by setting AES.MSTR_LEN. For CCM* mode, set associate data size by setting AES.ASTR_LEN, set message data size by setting AES.MSTR_LEN.
6. If AES block cipher mode is CTR mode, set CTR mode’s counter modular by setting AES.CTRL1.CTR_MODE.
7. For CCM* encryption or MMO mode, If MIC/HASH is needed, set AES.CTRL1.OUT_MIC bit to 1 to append MIC/HASH at the end of output stream. If only MIC/HASH is needed, we can block the encrypted data into output FIFO (set AES.CTRL1.OUT_MSG bit to 1), and get MIC/HASH from AES.OV3/2/1/0.
8. For CCM* mode, set AES.CTRL1.OUT_HDR bit to 1 to output B0 at the beginning of the output stream, if necessary.
9. Fill with initial value according to AES block cipher mode. AES engine contains 4, 32-bit initial vector registers: AES.IV0, AES.IV1, AES.IV2, AES.IV3.
   • For ECB/MMO/BYPASS mode, there are no initial vectors that need to be configured.
   • For CTR mode,
     - Set AES.IV0= initial counter, AES.IV1= Nonce[31:0], AES.IV2= Nonce[63:32], AES.IV3= Nonce[95:64].

Note: For Bypass mode, the AES engine ignores input data; it passes it along unchanged to the output.

12.3.3 Data Access Method

The AES module contains separate 4*32-bit input and output FIFO. The input and output FIFO can be accessed by DMA or CPU.

When setting AES.CTRL1.IO_SRC bit to 1 and AES.CTRL1.DMA_EN bit to 1, the input and output FIFO are accessed by DMA. There are 2 channels required: 1 for input data and the other for output data. Before starting AES engine, the DMA controller must be configured, the transfer size is the input data length and output data length. The AES operation finishes as the DMA operation finishes.

When setting AES.CTRL1.IO_SRC bit to 0 and AES.CTRL1.DMA_EN bit to 0, the input and output FIFO are accessed by CPU. Then it writes data into AES.STR_IN if the input FIFO is not full; read data from AES.STR_OUT if output FIFO is not empty. The AES operation finishes as the transfer data size reaches input and output data size.
12.3.4 Starting the AES Engine
Clear AES input and output FIFO and reset AES core before starting the AES engine. The AES input and output FIFO can be cleared by setting the AES.CTRL1.IF_CLR bit and AES.CTRL1.OF_CLR bit to 1. The AES core can be reset by setting and then clearing AES.CTRL2.CORE_RESET.

12.3.5 Interrupt Request
There are 3 interrupts for the AES engine: input FIFO full interrupt, output FIFO empty interrupt, and AES operation done interrupt. Each interrupt can be masked or cleared by setting AES.IMR/AES.IC registers.

12.3.6 Partial Code Support
The AES engine can automatically pad the input data when the input data length is not a multiple of 128 bits. The AES module supports the following padding scheme for different AES block cipher modes. Table 126 shows the scheme.

**Table 126: Padding Scheme**

<table>
<thead>
<tr>
<th>Mode</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM*</td>
<td>Automatically padding 0 for both A string and M string</td>
</tr>
<tr>
<td>MMO</td>
<td>Automatically padding “100…00”+2 bytes length information</td>
</tr>
<tr>
<td>CBC</td>
<td>Cipher stealing is performed to partial codeword</td>
</tr>
<tr>
<td>CTR</td>
<td>Partial code word don’t affect the operation</td>
</tr>
<tr>
<td>ECB</td>
<td>Check partial case, assert error when partial cases detected</td>
</tr>
</tbody>
</table>

12.3.7 Error Status Check
Register AES.STATUS.STATUS records the error status for the AES engine when the AES operation has finished. Table 127 shows the error status for different AES block cipher modes.

**Table 127: Error Status for Different AES Block Cipher Modes**

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>ECB</td>
<td>n/a</td>
<td>Data is not multiple of 16 bytes</td>
<td>Input data size less than 16 bytes</td>
</tr>
<tr>
<td>CBC</td>
<td>n/a</td>
<td>n/a</td>
<td>n/a</td>
</tr>
<tr>
<td>CTR</td>
<td>n/a</td>
<td>n/a</td>
<td>n/a</td>
</tr>
<tr>
<td>CCM*</td>
<td>MIC mismatch during decryption</td>
<td>n/a</td>
<td>n/a</td>
</tr>
<tr>
<td>MMO</td>
<td>n/a</td>
<td>Data is more than 2^{13}-1 bytes</td>
<td>n/a</td>
</tr>
<tr>
<td>Bypass</td>
<td>n/a</td>
<td>n/a</td>
<td>n/a</td>
</tr>
</tbody>
</table>
12.3.8 Output Vector

The output vector provides some useful information, such as the last cipher block in CBC mode, last counter in CTR mode, MIC value in CCM* mode and HASH value in MMO mode. Register AES.OV3/2/1/0 records useful information for different AES block cipher modes.

Table 128 shows the recorded information in AES output vector for different AES block cipher mode.

Table 128: AES Output Vector

<table>
<thead>
<tr>
<th>Block Cipher Mode</th>
<th>Output Vector</th>
</tr>
</thead>
<tbody>
<tr>
<td>ECB</td>
<td>n/a</td>
</tr>
</tbody>
</table>
| CBC               | Last Cipher Block  
AES.OV0 = cipher[31:0]  
AES.OV1 = cipher[63:32]  
AES.OV2 = cipher[95:64]  
AES.OV3 = cipher[127:96] |
| CTR               | Last Counter  
AES.OV0 = counter[31:0]  
AES.OV1 = counter[63:32]  
AES.OV2 = counter[95:64]  
AES.OV3 = counter[127:96] |
| CCM*              | Encryption: MIC value  
If MIC is less than 32 byte, always MSB byte is used.  
Example: 8 byte MIC:  
AES.OV2 = MIC[31:0]  
AES.OV3 = MIC[63:32] |
| MMO               | HASH Value  
AES.OV0 = HASH[31:0]  
AES.OV1 = HASH[63:32]  
AES.OV2 = HASH[95:64]  
AES.OV3 = HASH[127:96] |
| Bypass            | n/a         |
12.3.9 AES Operation Pseudo Code

```
AES_Config_Type aesConfig

aesConfig.mode <- AES_MODE_CBC
aesConfig.encDecSel <- AES_MODE_ENCRYPTION
aesConfig.keySize <- keysize
aesConfig.mStrLen <- length

for i=1 to keysize do
    aesConfig.key[i] = key[i]

for i=1 to 4 do
    aesConfig.initVect[i] = vector[i]

while j < length or k < length do
    if AES input fifo not full do
        feed the data plain_text[j]
        j++

    if AES output fifo not empty do
        read the encryption data
        k++
```

12.4 References for AES Standard

[1] www.nist.gov/aes (AES development, historical site)

12.5 Register Description

See Section 24.5, AES Address Block for a detailed description of the registers.
13 **Cyclic Redundancy Check (CRC)**

13.1 **Overview**

A Cyclic Redundancy Check (CRC) or polynomial code checksum is a hash function designed to detect data integrity. The 88MW320/322 CRC unit calculates a short, fixed-length binary sequence, known as the CRC code. For each block of data, CRC code and original data are sent or stored together. When a block of data is used, the same CRC calculation is processed. If the new CRC does not match the one pre-calculated earlier in the block of data, then the block contains a data error and the device may take corrective action, such as resending or requesting the block again. Otherwise the data is assumed to be error free (though, with some small probability, it may contain undetected errors; this is the fundamental nature of error-checking).

13.2 **Features**

A standard AHB slave interface is used to configure the module, receive the bit stream, and output the CRC result.

- Supports 32-bit parallel bit stream input, and supports up to 32-bit CRC output
- Supports up to $2^{32}$ (4294967296) byte length to calculate CRC
- Supports the following CRC standards
  - CRC-16-CCITT, the polynomial is $x^{16}+x^{12}+x^5+1$
  - CRC-16-IBM, the polynomial is $x^{16}+x^{15}+x^2+1$
  - CRC-16-T10-DIF, the polynomial is $x^{16}+x^{15}+x^{11}+x^9+x^8+x^7+x^5+x^4+x^2+x+1$
  - CRC-32-IEEE 802.3, the polynomial is $x^{32}+x^{26}+x^{23}+x^{22}+x^{16}+x^{12}+x^{11}+x^{10}+x^8+x^7+x^5+x^4+x^2+x+1$
  - CRC-16-DNP, the polynomial is $x^{16}+x^{13}+x^{12}+x^{11}+x^{10}+x^8+x^6+x^5+x^2+1$

13.3 **CRC Operation Flow**

1. Disable CRC (CRC.CTRL.ENABLE to 0).
2. Disable the interrupt (set CRC.IMR.MASK to 1).
3. Clear all the interrupts (set CRC_ICR.CLEAR to 1).
4. Configure the stream length (set register CRC STREAM_LEN_M1).
5. Configure CRC mode (set bit CRC.CTRL.MODE).
6. Enable the interrupt (set CRC.IMR.MASK to 0).
7. Enable CRC (set CRC.CTRL.ENABLE to 1).
8. Write stream in and waiting for interrupt to occur. (If interrupt occurred, go to 9)
9. Get CRC calculation result (Read register CRC.RESULT).
10. Complete CRC operation.

**Note:** The CRC input stream registers accepts a word (32-bit) at a time. If the input data is not 4 bytes aligned, pad 0’s at the start of the data stream. For example, if the data stream consists of 5 bytes starting from the lower address: 0xA1, 0xA2, 0xA3, 0xA4, 0xA5.
Write the following words to the stream input register:
- 0xA1000000
- 0xA5A4A3A2

The CRC result bit order is:
- 16-bit CRC: $x_0$~$x_{15}$  [msb->lsb]
- 32-bit CRCt: $x_0$~$x_{31}$  [msb->lsb]

13.4 **Register Description**

See [Section 24.6.2, CRC Registers](#) for a detailed description of the registers.
14 Universal Asynchronous Receiver Transmitter (UART)

14.1 Overview
The 88MW320/322 Universal Asynchronous Receive Transmitter (UART) supports 16550A and 16750 functions. It also includes a slow infrared Transmit encoder and Receive decoder that conforms to the Infrared Data Association (IrDA) Serial Infrared (SIR) specification.

14.2 Features
- Compliance to the AMBA specification (Rev 2.0)
- Programmable use of UART or IrDA SIR input/output
- Separate 64x8 transmit and 64x11 receive FIFO memory buffers to reduce CPU interrupts
- Supports 8-bit or 32-bit peripheral bus
- Programmable FIFO disabling for 1-byte depth
- Programmable baud rate generator
- Ability to add or delete standard asynchronous communication bits (start, stop, and parity) in the serial data
- Independently controlled transmit, receive, line status, and data-set interrupts
- Supports modern control functions: CTS and RTS
- Auto-flow capability control data I/O without generating interrupt
  - RTS (output) controlled by the UART Receive FIFO
  - CTS (input) from modern control UART transmitter
- Programmable serial interface
  - 5 to 8-bit characters
  - Even, odd, or no parity detection
  - 1 or 2 stop-bit generation
  - Baud-rate generation up to F(uart)/16 bps
  - False start-bit filter
- Line break generation and detection
- Internal diagnostic capabilities that include:
  - Loopback control for communications link fault isolation
  - Break, parity, and framing-error simulation
- Separate DMA requests for Transmit and Receive data services
14.3  Interface Signal Description

14.3.1  External Interface

Table 129 shows the interface signals from the UART to the I/O pins of the device.

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Source/Destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>UART_TXD</td>
<td>O</td>
<td>PAD</td>
<td>UART Transmit serial data</td>
</tr>
<tr>
<td>UART_RXD</td>
<td>I</td>
<td>PAD</td>
<td>UART Receive serial data</td>
</tr>
<tr>
<td>UART_CTSn</td>
<td>I</td>
<td>PAD</td>
<td>UART Clear To Send modem status (active low)</td>
</tr>
<tr>
<td>UART_RTSn</td>
<td>O</td>
<td>PAD</td>
<td>UART Request To Send modem status (active low)</td>
</tr>
</tbody>
</table>

14.3.2  Internal Interface

Table 130 shows the interface signals.

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Source/Destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>rst_uart_n</td>
<td>I</td>
<td>Reset controller</td>
<td>UART reset signal to clk_uart clock domain (active low)</td>
</tr>
<tr>
<td>clk_uart</td>
<td>I</td>
<td>Clock generator</td>
<td>UART reference clock</td>
</tr>
<tr>
<td>uart_int</td>
<td>O</td>
<td>Interrupt controller</td>
<td>UART interrupt (active high), a single combined interrupt generated as an OR function of all interrupts</td>
</tr>
<tr>
<td>dma_tx_ack</td>
<td>I</td>
<td>DMA controller</td>
<td>UART transmit DMA acknowledge signal (active high)</td>
</tr>
<tr>
<td>dma_tx_finish</td>
<td>I</td>
<td>DMA controller</td>
<td>UART transmit DMA finish signal (active high)</td>
</tr>
<tr>
<td>dma_tx_single</td>
<td>O</td>
<td>DMA controller</td>
<td>UART transmit DMA signal request (active high)</td>
</tr>
<tr>
<td>dma_tx_request</td>
<td>O</td>
<td>DMA controller</td>
<td>UART transmit DMA burst request (active high)</td>
</tr>
<tr>
<td>dma_rx_ack</td>
<td>I</td>
<td>DMA controller</td>
<td>UART receive DMA acknowledge signal (active high)</td>
</tr>
<tr>
<td>dma_rx_finish</td>
<td>I</td>
<td>DMA controller</td>
<td>UART receive DMA finish signal (active high)</td>
</tr>
<tr>
<td>dma_rx_single</td>
<td>O</td>
<td>DMA controller</td>
<td>UART receive DMA signal request (active high)</td>
</tr>
<tr>
<td>dma_rx_request</td>
<td>O</td>
<td>DMA controller</td>
<td>UART receive DMA burst request (active high)</td>
</tr>
</tbody>
</table>
14.3.3 AMBA APB Interface

Table 131 shows the interface signals.

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Source/Destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>clk_apb</td>
<td>I</td>
<td>Clock generator</td>
<td>APB clock, used to time all bus transfers</td>
</tr>
<tr>
<td>rst_sys_n</td>
<td>I</td>
<td>Reset controller</td>
<td>Bus reset (active low)</td>
</tr>
<tr>
<td>penable</td>
<td>I</td>
<td>APB</td>
<td>APB enable PENABLE is asserted high for 1 cycle of clk_apb to enable a bus transfer</td>
</tr>
<tr>
<td>pwrite</td>
<td>I</td>
<td>APB</td>
<td>APB transfer direction signal Indicates a write access when high, read access when low.</td>
</tr>
<tr>
<td>psel</td>
<td>I</td>
<td>APB</td>
<td>UART and SIR select signal from decoder When set high, indicates the slave device is selected by the AMBA APB bridge, and that a data transfer is required.</td>
</tr>
<tr>
<td>paddr[3:0]</td>
<td>I</td>
<td>APB</td>
<td>Subset of AMBA APB address bus</td>
</tr>
<tr>
<td>pwdata[31:0]</td>
<td>I</td>
<td>APB</td>
<td>Subset of unidirectional AMBA APB write data bus</td>
</tr>
<tr>
<td>prdata[31:0]</td>
<td>O</td>
<td>APB</td>
<td>Subset of unidirectional AMBA APB read data bus</td>
</tr>
</tbody>
</table>
14.4 Function Description

14.4.1 Block Diagram

Figure 55 shows an overall block diagram.

Figure 55: UART Block Diagram
14.4.2 UART Operation

14.4.2.1 Data Format

Serial communication between the UART and a selected device is asynchronous. Therefore, additional bits (start and stop) are added to the serial data to indicate the beginning and end. Utilizing these bits allows 2 devices to be synchronized. This structure of serial data—accompanied by start and stop bits—is referred to as a character.

Figure 56 shows the data format.

An additional parity bit can be added to the serial character. This bit appears after the last data bit and before the stop bit(s) in the character structure in order to provide the UART with the ability to perform simple error checking on the receive data.

The UART Line Control Register (UART_LCR) is used to control the serial character characteristics. The individual bits of the data word are sent after start bit, starting with the Least Significant bit (LSb). These are followed by the optional parity bit, followed by stop bit(s), which can be 1 or 2.

- Data bits – This field can have 5 to 8 bits, which is depend on the programmed value in LCR.WLS10.
- Parity and sticky bit – 3 bits in LSR register determine the existence or value of parity value. Table 132 shows a true table for the Sticky Parity (STKYP), Even Parity Select (EPS), and Parity Enable (PEN) bits of the LSR.

Table 132: Parity Truth Table

<table>
<thead>
<tr>
<th>PEN</th>
<th>EPS</th>
<th>STKYP</th>
<th>Parity Bit (transmitted or checked)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>x</td>
<td>x</td>
<td>Not transmitted or checked</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Even parity</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Odd parity</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>--</td>
<td>0</td>
</tr>
</tbody>
</table>

- Stop bits – 1 or 2 stop bits can be programmed in LSR.STB. It specifies the number of stop bits transmitted and received in each character. When receiving, the receiver checks only the first stop bit.
Set break – If LSR.SB is set to 1, a low-level is continually output on the TXD output after completing transmission of current character. Acts only on the TXD pin and has no effect on the transmit logic.

To the receiver, when a break (LSR.BI) is detected, a break interrupt (LSR.BI) is raised. A break interrupt is cleared when the CPU reads the LSR register or receiver detects a high (idle value). In FIFO mode, only 1 character equal to 0x00 is loaded into the FIFO regardless of the length of the break condition. In non-FIFO mode, 1 character equal to 0x00 is stored in RBR register. Receiver can resume when the receive sequence exit form break condition.

### 14.4.2.2 NRZ Coding

The UART can use NRZ coding to represent individual bit values. To enable NRZ coding, set the <NRZ Coding Enable> field in the Interrupt Enable Register. A bit value of 1 is represented by a line transition, and 0 is represented by no line transition.

Figure 57 shows the data byte 0b0100_1011 in NRZ coding. The LSb in the byte is transmitted first.

**Figure 57: Example NRZ Bit Encoding – 0b0100_1011**

*Note:* The NRZ cannot be used in infrared mode. NRZ encoding/decoding is only applied to the data bits. Start, parity, and stop bits are not involved.
14.4.2.3 Baud Rate Divider

The UART contains a programmable baud-rate generator that can take a fixed input clock and divide it down to generate the preferred baud rate. The baud rate is calculated by taking an example 14.7456 MHz fixed-input clock and dividing it by the Divisor Latch registers.

The baud-rate generator output frequency is 16 times the baud rate. There are 2, 8-bit Divisor Latch Registers that store the divisor in a 16-bit binary format.

The baud rate of the data shifted into or out of a UART is given by the formula:

\[
\text{BaudRate} = \frac{(14.857 \text{ MHz})}{(16 \times \text{Divisor})}
\]

The divisor reset value is 0x0002. 0 is a meaningless value and is forbidden. Changing the baud rate is not permitted while actively transmitting or receiving data.

<table>
<thead>
<tr>
<th>Required Baud Rate</th>
<th>Divisor</th>
<th>Actual Baud Rate @ 14.857 MHz</th>
</tr>
</thead>
<tbody>
<tr>
<td>9600</td>
<td>96</td>
<td>9673</td>
</tr>
<tr>
<td>19200</td>
<td>48</td>
<td>19345</td>
</tr>
<tr>
<td>38400</td>
<td>24</td>
<td>38690</td>
</tr>
<tr>
<td>57600</td>
<td>16</td>
<td>58036</td>
</tr>
<tr>
<td>115200</td>
<td>8</td>
<td>116071</td>
</tr>
<tr>
<td>230400</td>
<td>4</td>
<td>232143</td>
</tr>
<tr>
<td>460800</td>
<td>2</td>
<td>464286</td>
</tr>
<tr>
<td>921600</td>
<td>1</td>
<td>928571</td>
</tr>
</tbody>
</table>

14.4.3 IrDA 1.0 SIR Operation

The SIR interface is used to support 2-way wireless communication that uses infrared transmission. The SIR interface provides a Transmit encoder and Receive decoder to support a physical link that conforms to the IrDA SIR specification.

The SIR interface does not contain the actual the actual IR LED driver or the receive amplifier. The I/O pins attached to the SIR interface (UART_RXD/UART_TXD) have only digital CMOS-level signals. SIR supports 2-way communication, but full-duplex communication is not possible because reflections from the transmit LED enter the receiver. Half-duplex is functional, and the receiver works when both transmitter and receiver SIR mode are enabled.

SIR supports frequencies up to 115.2 Kbps. The baud divisor must be 8 or more because the input clock is 14.7456 MHz.

The SIR modulation technique works with 7- or 8-bits characters with an optional parity bit. The data is preceded by 0-value start bit and ends with 1 or 2 stop bits. The role of the SIR ENDEC is to provide a digital encoded output and decoded input to the UART.

Modes of operation include:
- Normal mode
- Low-power mode
14.4.3.1 Normal Mode

In normal mode, the encoding scheme sends a pulse 3/16 of a bit wide in the middle of every 0-value bit, and sends no pulses for bits with a value of 1. These levels control the driver of an infrared transmitter, sending a pulse of light for each 0. On the reception side, the incoming light pulses energize the photo transistor base of the receiver, pulling its output LOW. The drives the RXD signal LOW. The pulse for each 0-value bit must occur, even for consecutive bits with no edge between them. Figure 58 shows an example.

Figure 58: IR Transmit and Receive Example

<table>
<thead>
<tr>
<th>UART Transmit Shift Value</th>
<th>Start Bit</th>
<th>1</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>1</th>
<th>0</th>
<th>1</th>
<th>0</th>
<th>Stop Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>IR Encoder Output (TXD Pin Value)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RXD Pin Value</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IR Decoder Output</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>UART Receive Shift Value</td>
<td>Start Bit</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Stop Bit</td>
</tr>
</tbody>
</table>

The last line is the same as the first, but it is shifted half a bit period. When the <Transmit Pulse Width Select> is clear, each 0 bit has a pulse width of 3/16 of a bit time.
14.4.3.2 **Low-Power Mode**

It is strongly recommended to set the <Transmit Pulse Width Select> field in the Infrared Selection Register for the transmit-pulse width. The shorter infrared pulse generated when the <Transmit Pulse Width Select> field is set reduces the LED power consumption. At 2400 bps when the UART frequency is 14.7456 MHz, the LED is normally on 78 us for each 0-bit transmitted. When the <Transmit Pulse Width Select> field is set, the LED is on for only 1.6 us.

Figure 59 shows an example.

Figure 59: XMODE Example

In generalization, we use $F_{UART}$ to denote the UART functional frequency, in order to make IR correct functionality, divider equal or bigger than 8 is required. When $N$ is denoted as the divider, then the pulse width under IrDA can be shown as follows:

$$\frac{1}{F_{UART}} \times \frac{3}{16}$$

When $N = 8$, the pulse width will get minimal width. In IrDA normal mode, pulse width is calculated with the actual divider. In IrDA low-power mode, pulse width is calculated with divider 8 regardless of the actual divider.

<Transmit Pulse Width Select>=1 toggles only the transmit-pulse width. It does not affect the receive-pulse width, which is always take the received sequence as generated in low-power mode.

To prevent transmitter LED reflection feedback to the receiver, disable the IR receive decoder when the IR Transmit encoder transmits data, and disable the IR Transmit encoder when the IR Receive decoder receives data. UART_SCR.RCVEIR and UART_SCR.XMITIR must not be set at the same time.
14.4.4 Clock Support

The frequency selected for the UART functional clock must accommodate the required range of band rates:

- \( \text{Fuart (min)} \geq 16 \times \text{baud\_rate (max)} \)
- \( \text{Fuart (max)} \leq 16 \times 65535 \times \text{baud\_rate (min)} \)

For example, for a range of baud rates from 110 baud to 460800 baud the UART clock frequency must be between 7.3728 MHz to 115.34 MHz.

There is also a constraint on the ratio of clock frequencies for PCLK to UART clock. The frequency of the UART clock and the frequency of PCLK must at least meet the following constraints:

\[ \frac{\text{Fuart}}{\text{PCLK}} > \frac{1}{14} \]

14.4.5 Reset

The UART is disabled on reset. To enable the UART, software must program the <UART Unit Enable> field in the Interrupt Enable Register. When the UART is enabled, the receiver waits for a frame start bit and the transmitter send data if it is available in the Transmit Holding Register. Transmit data can be written to the Transmit Holding Register before the UART unit is enabled. In FIFO mode, data is transmitted from the FIFO to the pin.

When UART unit is disabled, the transmitter or receiver finishes the current byte and stops transmitting or receiving more data. Data in the FIFO is not cleared and transmission resumes when the UART is enabled.

14.4.6 FIFO Operation

When FIFO_MODE is enabled, data written to the Transmit Holding Register by either the CPU or DMA is automatically transferred to the transmit FIFO. When reading the Receive Buffer Register by either CPU or DMA, the data in the Receive FIFO is transferred automatically from the FIFO data register.

UART has a Transmit FIFO and Receive FIFO, with each FIFO holding 64 characters of data. The FIFOs are filled or emptied by CPU or DMA transactions. The data is accessed through the TXFIFO and RXFIFO. The Processor accesses are normally triggered by an interrupt caused by an UART Interrupt Identification Register (UART_IIR). The data writes to the TXFIFO are either 8bits or 32bits wide. The processor always reads 32bits from RXFIFO, with 0 inserted in the MSb, down to the programmed data size.

The TXFIFO and RXFIFO are each accessed as 1, 32-bit location by the CPU. For data transmission, the UART port transmits the data from the TXFIFO to the external peripheral through the UART.txd interface. Data received from the external peripheral through the UART.rxd interface is converted to parallel bytes and written into the RXFIFO.

The TXFIFO and RXFIFO are differentiated by whether the access is Read or a Write transfer. Reads from the Receive Buffer Register automatically target the RXFIFO. Writes to the Transmit Holding Register automatically target the TXFIFO. From the memory-map perspective, the TXFIFO and the RXFIFO are at the same physical address.
14.4.6.1 Transmit FIFO

The transmit FIFO is an 8-bit wide, 64-location deep, FIFO memory buffer. Data written across the APB interface is stored in the FIFO until read out by the transmit logic.

TXFIFO can be accessed by both Processor and DMA bursts, setting TIL causes transmitter interrupts and DMA requests to occur when the transmitter FIFO is empty. Clearing TIL causes transmitter interrupts and DMA requests to occur when the transmitter FIFO is half empty. The trigger level must be bigger or equal to the DMA burst length programmed in the DMA registers.

The transmit FIFO can be disabled to act like a 1-byte holding register.

14.4.6.2 Receive FIFO

The receive FIFO is an 11-bit wide, 64 location deep, FIFO memory buffer. Received data and corresponding error bits are stored in the receive FIFO by the receive logic until read out across the APB interface.

When the number of bytes in the RXFIFO equals the interrupts trigger level programmed into this field and the receive-data-available interrupt is enabled (with Interrupt Enable Register), an interrupt is generated and appropriate bits are set in the Interrupt Identification Register. The receive DMA request is generated as well when trigger level is reached. The trigger level must be bigger or equal to the DMA burst size programmed in the DMA registers.

The receive FIFO can be disabled to act like a 1-byte holding register.

14.4.6.3 32-Bit Peripheral Bus

UART supports an 8- (default) and 32-bit peripheral bus. If a 32-bit bus is preferred, the bytes are written in Little Endian format (7:0) with byte 3 (the most recent byte) starting at bit[31], byte 2 starting at bit[23], and so on.

- 8-bit mode – only the least significant byte contains valid data on the peripheral bus. The upper 24 bits are ignored.
- 32-bit mode – UART can only read or write partial words of 1, 2, 3 or 4 continuous bytes from the peripheral bus. In this mode, UART always transmit or receive byte 0 first, and then byte 1 and so on. The Receive FIFO and Transmit FIFO must be enabled when in 32-bit mode.

14.4.7 DMA Support

The UART provides an interface to connect to a DMA controller. The DMA operation of the UART is controlled using the DMA Control Register. There are 2 types of request UART can signal to DMA: burst transfer request and single transfer request.

The burst transfer and single transfer request signals are not mutually exclusive, they can both be asserted at the same time. When there is more than the watermark level in the RXFIFO, the burst transfer request and the single transfer request are asserted. When the amount of data left in the RXFIFO is less than the watermark level, the single request only is asserted. This is useful for situation where the number of characters left to be received in the stream is less than a burst.

If you disable the FIFO mode in the UART then it operates in non-FIFO mode and only the DMA single transfer mode can operate, because only 1 character can be transferred to, or from the FIFOs at any time.

When the UART is in FIFO mode, data transfers can be made by either single or burst transfers depending on the programmed watermark level and the amount of data in the FIFO. Table 3.3 and Table 3.4 list the trigger level for the transmit and receive FIFOs.

Table 134 shows trigger levels for the transmit FIFO.
Table 134: DMA Trigger Points for Transmit FIFO

<table>
<thead>
<tr>
<th>Transmitter Trigger Level (TTL)</th>
<th>Transmit (number of empty locations)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>32</td>
</tr>
<tr>
<td>1</td>
<td>64</td>
</tr>
</tbody>
</table>

Table 134 shows trigger levels for the receive FIFO.

Table 135: DMA Trigger Points for Receive FIFO

<table>
<thead>
<tr>
<th>Transmitter Trigger Level (TTL)</th>
<th>Transmit (number of empty locations)</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>1</td>
</tr>
<tr>
<td>01</td>
<td>8</td>
</tr>
<tr>
<td>10</td>
<td>16</td>
</tr>
<tr>
<td>11</td>
<td>32</td>
</tr>
</tbody>
</table>

To prevent overflow of the TXFIFO or underflow of the RXFIFO when using the DMA, be careful when setting the FIFO trigger threshold levels by setting the DMA burst size and data width. TXFIFO overflow and RXFIFO underflow will cause data missing. The DMA burst size must be smaller or equal the trigger threshold.

Assume that DMAC is in another clock domain (hclk) different from UART clock domain (per_clk).

Figure 60 shows the timing diagram of a burst transaction where the UART clock, per_clk is half of the hclk frequency. In this example, the UART is outside the single transaction region, and therefore DMAC does not sample dma_single.

Figure 60: Burst Transaction – hclk=2*per_clk
When designing the hardware handshaking interface:

- Once asserted, the `dma_req` must remain asserted until the corresponding `dma_ack` signal is received, even if the condition that generates `dma_req` in the peripheral is False.
- The `dma_req` signal should be de-asserted when `dma_ack` is asserted, even if the condition that generates `dma_req` in the peripheral is True.

**Figure 61** shows a single transaction that occurs in the single transaction region. The handshaking loop is as follows:

- `dma_single` asserted by peripheral
- `dma_ack` asserted by DMAC
- `dma_single` de-asserted by peripheral
- `dma_ack` de-asserted by DMAC

**Figure 61: Signal Transaction – hclk=2*per_clk**
Figure 62 shows a burst transaction, followed by 2 back-to-back single transactions, where the hclk frequency is twice the per_clk frequency.

Figure 62: Burst Followed by Back-to-Back Single Transactions

After the first burst transaction, the UART enters the single transaction region and the DMAC starts sampling dma_single. DMAC samples that dma_single is asserted and performs single transactions. The second single transaction terminates the block transfer; dma_finish is asserted to indicate block completion.

14.4.8 UART Modem Operation

The UART supports the Data Terminal Equipment (DTE) mode of operation. Table 136 shows the signals.

Table 136: Modem I/O Signals in DTE Mode

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Source/Destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>UART_CTSn</td>
<td>I</td>
<td>PAD</td>
<td>UART Clear To Send modem status (active low)</td>
</tr>
<tr>
<td>UART_RTSn</td>
<td>O</td>
<td>PAD</td>
<td>UART Request To Send modem status (active low)</td>
</tr>
</tbody>
</table>
14.4.9 UART Hardware Flow Control

The hardware flow control feature is fully selectable, and enables you to control the serial data flow by using the uart_cts_n input and uart_rts_n output signals.

Figure 63: Hardware Flow Control

Auto-flow mode can be used in 2 ways: full auto-flow, automating both CTSn and RTSn; and half auto-flow, automating only CTSn. Table 137 shows the bits to enable RTS and CTS flow control both simultaneously and independently.

Table 137: Control Bits to Enable Hardware Flow Control

<table>
<thead>
<tr>
<th>UART_MCR Register Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>AFE</td>
<td>RTS</td>
</tr>
<tr>
<td>0</td>
<td>x</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

14.4.9.1 RTS Flow Control

The RTS flow control is linked to the programmable receive FIFO watermark levels. When RTS flow control is enabled, the uart_rts_n is asserted until the receive FIFO is filled up to the watermark level. When the receive FIFO watermark level is reached, the uart_rts_n signal is deasserted, indicating that there is no more room to receive any more data. The transmission of data is expected to cease after the current character has been transmitted.

The uart_rts_n signal is reasserted when data has been read out of the receive FIFO so that it is filled to less than the watermark level. If RTS flow control is disabled and the UART is still enabled, then data is still enabled, then data is received until the receive FIFO is full, or no more data is transmitted to it.
14.4.9.2 CTS Flow Control

If CTS flow control is enabled, then the transmitter checks the uart_cts_n signal before transmitting the next byte. If the uart_cts_n signal is asserted, it transmits the byte otherwise transmission does not occur.

The data continues to be transmitted while uart_cts_n is asserted, and the transmit FIFO is not empty. If the transmit FIFO is empty and the uart_cts_n signal is asserted no data is transmitted.

If the uart_cts_n signal is deasserted and CTS flow control is enabled, then the current character transmission is completed before stopping. If CTS flow control is disabled and the UART is enabled, then the data continues to be transmitted until the transmit FIFO is empty.

When auto-flow control is enabled in IrDA mode, since IrDA can’t work in full-duplex mode, transmitter won’t work when Both RTS and CTS flow control enabled.

14.4.10 Auto Baud Rate Detection

UART supports auto-baud-rate detection. When enabled, the UART counts the number of clock cycle within the start-bit pulse (a special sequencer with the LSb ‘1’ is required). This number is then written into the Auto-Baud Counter Register and is used to calculate the baud rate. When the Auto-Baud Count Register is written, an auto-baud-lock interrupt is generated (if enabled), and the UART automatically programs the Divisor Latch Registers with the appropriate baud rate if ABR.ABUP is ‘1’. If preferred, the user can read the Auto-Baud Count Register and use this information to program the Divisor Latch Registers with a baud rate calculated by CPU, in this condition, ABR.ABUP need to ‘0’. After the baud rate has been programmed, the user verifies that the predetermined characters are being received correctly.

Software can use either of 2 methods for auto-baud calculation: table-based and formula-based.

- Formula method – any baud rate can be programmed by the UART. This method works well for higher baud rates, but it could fail below 28.8 Kbps if the remote transmitter’s actual baud rate differs by more than 1 percent of its target.
- Table method – is more immune to such errors, because the table rejects uncommon baud rates and rounds to the common 1s. The table method allows any baud rate defined by the formula in (1) above 28.8 Kbps. Below 28.8 Kbps, the only baud rates that can be programmed by the UART are 19200, 14400, 9600, 4800, 1200, and 300 baud.

When the baud rate is detected, the auto-baud circuitry disables itself by clearing the <ABE> field in the Auto-Baud Count Register. To re-enable auto-baud detection, set the <ABE> field again.

Changing the baud rate is not permitted when actively transmitting or receiving data. Auto-baud-rate detection is not supported in IrDA mode.
14.4.11 Interrupts
There are 7 maskable interrupts generated in the UART. These interrupts are combined to produce 1 interrupt output that is the OR of the individual outputs:

- Receive timeout interrupt
- Modem state change interrupt, that can be caused by delta clear to send
- Receive line status interrupt, that can be caused by:
  - Overrun error
  - Parity error
  - Framing error
  - Break interrupt
- Receive FIFO error interrupt
- Transmit data request interrupt
- Receive data available interrupt
- Auto-baud-lock interrupt

UART_INT, this is an OR function of the 7 individual masked interrupt

Enable or disable individual interrupts by changing the mask bit in the Interrupt Enable Register (UART_IER) and Auto-Baud Control Register (UART_ABR). Setting the appropriate mask bit HIGH enables the interrupt.

The status of the individual interrupt sources can be read either from the Interrupt Identification Register (UART_IIR), Line Status Register (UART_LSR) and Modem Status Register (UART_MSR).

14.4.11.1 Receive Timeout Interrupt
The receive timeout interrupt is asserted when the trailing bytes are programmed to remove by the processor (UART_FCR.TRAIL) and receive FIFO is not empty, and no more data is received during a 32-bit period. The receive timeout interrupt is cleared either when the FIFO becomes empty through reading all the data (or by reading the holding register).

14.4.11.2 Modem State Change Interrupt
The modem status interrupt is asserted if any of the modem status signals change. It is cleared by writing a 0 to corresponding bit(s) in the Modem Control Register, depending on the modem status signals that generated the interrupt.

14.4.11.3 Receive Line Status Interrupt
The receive line status interrupt is asserted when an error occurs in the reception of data by the UART. The interrupt can be caused by a number of different error conditions:

- Overrun
- Framing
- Parity
- Break

Determine the cause of the interrupt by reading the Interrupt Identification Register (UART_IIR) and Line Status Register (UART_LSR).

14.4.11.4 Receive FIFO Error Interrupt
The receive FIFO error interrupt is asserted when an error occurs in the Receive FIFO, this can be either an invalid data received from pin RXD or try to read data from an error address in the FIFO.
14.4.11.5 Transmit Data Request Interrupt
The transmit interrupt changes state when any of the following events occurs:

- If the FIFO mode is enabled and the transmit FIFO is equal to or lower than the programmed trigger level then the transmit interrupt is asserted HIGH. The transmit interrupt is cleared by writing data to the transmit FIFO until it becomes greater than the trigger level.
- If the FIFO mode is disabled (have a depth of 1 location), and there is no data present in the transmitter single location, the transmit interrupt is asserted HIGH. It is cleared by performing a single write to the transmit FIFO.

14.4.11.6 Receive Data Available Interrupt
The receive interrupt changes state when any of the following events occurs:

- If the FIFO mode is enabled and the receive FIFO reaches the programmed trigger level. When this happens, the receive interrupt is asserted HIGH. The receive interrupt is cleared by reading data from the receive FIFO until it becomes less than the trigger level.
- If the FIFO mode is disabled (have a depth of 1 location) and data is received thereby filling the location, the receive interrupt is asserted HIGH. The receive interrupt is cleared by performing a single read of the receive FIFO.

14.4.11.7 Auto Baud Lock Interrupt
The Auto-Baud-Lock interrupt changes state when Divisor Latch Register programmed by auto-baud circuitry in Auto-baud-rate detect mode.

14.4.11.8 UART_INT
The masked interrupts are also combined into a single output; that is an OR function of the individual masked sources. Connect this output to a system interrupt controller.

The combined UART interrupt is asserted if any of the individual interrupts are asserted and enabled and enabled.

UART_INT is masked by OUT2 Signal Control (UART_MCR.OUT2) which connects the UART interrupt, only when either OUT2 or loopback mode enable is set 1, the UART_INT can be asserted.

14.5 Register Description
See Section 24.10.2, UART Registers for a detailed description of the registers.
15 Inter-Integrated Circuit (I\textsuperscript{2}C)

15.1 Overview

The 88MW320/322 I\textsuperscript{2}C bus interface complies with the common I\textsuperscript{2}C protocol and can operate in standard mode (with data rates up to 100 Kbps), fast mode (with data rates up to 400 Kbps) and high-speed mode (with data rates up to 2 Mbps). Additionally, high-speed mode devices and fast mode devices are downward compatible. It also supports DMA capability.

The device supports 2, I\textsuperscript{2}C interfaces, I2C0 and I2C1, both of which are identical in function.

15.2 Features

- 2 I\textsuperscript{2}C serial interfaces consisting of a serial data line (SDA) and serial clock (SCL)
- 3 speeds include:
  - Standard mode (up to 100 Kbps)
  - Fast mode (up to 400 Kbps)
  - High-speed mode (2 Mbps)
- Clock synchronization
- Master or Slave I\textsuperscript{2}C operation, multi-master, multi-slave operation, and arbitration support
- 7- or 10-bit addressing and General Call
- 7- or 10-bit combined format transfers
- Bulk transmit mode in slave
- 16 * 32 bits deep transmit and receive buffers, respectively
- Interrupt operation
- DMA function support

15.3 Interface Signal Description

Table 138 shows the interface signals.

Table 138: I\textsuperscript{2}C Interface Signals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDA</td>
<td>I/O</td>
<td>Data signal line (Serial Data)</td>
</tr>
<tr>
<td>SCL</td>
<td>I/O</td>
<td>Clock signal line (Serial Clock)</td>
</tr>
</tbody>
</table>
15.4 Functional Description

15.4.1 Block Diagram

The I²C consists of an APB slave interface, an I²C interface, and FIFO logic to maintain coherency between the interfaces.

Figure 64 shows a simplified block diagram.

Figure 64: I²C Block Diagram
15.4.2 \(\text{i}^2\text{C} \text{ Bus Terminology}

Table 139 shows bus terminology.

<table>
<thead>
<tr>
<th>(\text{i}^2\text{C} \text{ Device} )</th>
<th>Description</th>
</tr>
</thead>
</table>
| Transmitter                     | Sends Data Over \(\text{i}^2\text{C} \) Bus  
Transmitter can either be a device that initiates the data transmission to the bus (a master-transmitter) or responds to a request from the master to send data to the bus (a slave-transmitter). |
| Receiver                        | Receives Data Over \(\text{i}^2\text{C} \) Bus  
A receiver can either be a device that receives data on its own request (a master-receiver) or in response to a request from the master (a slave-receiver). |
| Master                          | Component that initiates a transfer (START command), generated the clock (SCL) signal and terminates the transfer (STOP command). A master can be either a transmitter or a receiver. |
| Slave                           | Device addressed by the master. A slave can be either a receiver or transmitter (see Figure 65, Master/Slave and Transmitter/Receiver Relationship, on page 192). |
| Multi-master                    | Ability for more than 1 master to co-exist on the bus at the same time without collision or data loss. |
| Arbitration                     | Predefined procedure that authorizes only 1 master at a time to take control of the bus. Refer to “Multiple Master Arbitration” for more information. |
| Synchronization                 | Predefined procedure that synchronizes the clock signals provided by 2 or more masters. For more information about this feature, refer to “Clock Synchronization.” |

**Bus Transfer Terminology**

The following terms are specific to data transfers that occur to/from the \(\text{i}^2\text{C} \) bus.

| START (RESTART) | Data transfer begins with a START or RESTART condition. The level of the SDA data line changes from high to low, while the SCL clock line remains high. When this occurs, the bus becomes busy.  
**NOTE:** START and RESTART conditions are functionally identical. |
| STOP            | Data transfer is terminated by a STOP condition that occurs when the level on the SDA data line passes from the low state to the high state, while the SCL clock line remains high. When the data transfer has been terminated, the bus is free or idle once again. The bus stays busy if a RESTART is generated instead of a STOP condition. |

Figure 65: Master/Slave and Transmitter/Receiver Relationship

![Master/Slave and Transmitter/Receiver Relationship](image-url)
15.4.3 I²C Behavior

The I²C can be controlled by software to be either:
- I²C master only, communicating with other I²C slaves
- I²C slave only, communicating with 1 or more I²C master

The master is responsible for generating the clock and controlling the transfer of data. The slave is responsible for either transmitting or receiving data to/from the master. The acknowledgment of data is sent by the device that is receiving data, which can be either a master or a slave. The I²C protocol also allows multiple masters to reside on the I²C bus and uses an arbitration procedure to determine bus ownership.

Each slave has a unique address that is determined by the system designer. When a master wants to communicate with a slave, the master transmits a START/RESTART condition that is then followed by the slave’s address and a control bit (R/W) to determine if the master wants to transmit data or receive data from the slave. The slave then sends an acknowledge (ACK) pulse after the address.

If the master (master-transmitter) is writing to the slave (slave-receiver), the receiver gets 1 byte of data. This transaction continues until the master terminates the transmission with a STOP condition. If the master is reading from a slave (master-receiver), the slave transmits (slave-transmitter) a byte of data to the master, and the master then acknowledges the transaction with the ACK pulse. This transaction continues until the master terminates the transmission by not acknowledging (Negative Acknowledgment (NACK)) the transaction after the last byte is received, and then the master issues a STOP condition or addresses another slave after issuing a RESTART condition.

Figure 66 shows the data transfer.

Figure 66: Data Transfer on the I²C Bus

The I²C is a synchronous serial interface. The SDA line is a bidirectional signal and changes only while the SCL line is low, except for STOP, START, and RESTART conditions. The output drivers are open-drain or open-collector to perform wire-AND functions on the bus. The maximum number of devices on the bus is limited by only the maximum capacitance specification of 400 pF. Data is transmitted in byte packages.

Note: Placing data into the FIFO generates a START, and emptying the FIFO generates a STOP. For more information, see Section 15.4.3.1, START and STOP Generation, on page 194.
15.4.3.1 START and STOP Generation

When operating as an I²C master, placing data into the Transmit FIFO causes the I²C to generate a START condition on the I²C bus. Allowing the Transmit FIFO to empty causes the I²C to generate a STOP condition on the I²C bus.

When operating as a slave, the I²C does not generate START and STOP conditions, as per the protocol. However, if a read request is made to the I²C, it holds the SCL line low until read data has been supplied to it. This action stalls the I²C bus until read data is provided to the slave I²C, or the I²C slave is disabled by writing a 0 to ENABLE in register I2C.ENABLE.

15.4.3.2 Combined Formats

The I²C supports mixed read and write combined format transactions in both 7-bit and 10-bit addressing modes.

The I²C does not support mixed address and mixed address format—that is, a 7-bit address transaction followed by a 10-bit address transaction or vice versa—combined format transactions.

To initiate combined format transfers, set the register CON.RESTART_EN to 1. With this value set and operating as a master, when the I²C completes a I²C transfer, it checks the Transmit FIFO and executes the next transfer. If the direction of this transfer differs from the previous transfer, the combined format is used to issue the transfer. If the Transmit FIFO is empty when the current I²C transfer completes, a STOP is issued and the next transfer is issued following a START condition.
15.4.4 I²C Protocols

15.4.4.1 START and STOP Conditions

When the bus is idle, both the SCL and SDA signals are pulled high through external pullup resistors on the bus. When the master wants to start a transmission on the bus, the master issues a START condition. This is defined to be a high-to-low transition of the SDA signal while SCL is 1. When the master must terminate the transmission, it issues a STOP condition, which is defined to be a low-to-high transition of the SDA line while SCL is 1.

When data is being transmitted on the bus, the SDA line must be stable when SCL is 1. Figure 67 shows the timing of the START and STOP conditions.

Figure 67: START and STOP Condition

Note: The signal transitions for the START/STOP conditions reflect those observed at the output signals of the Master driving the I²C bus. Use caution when observing the SDA/SCL signals at the input signals of the Slave(s), because unequal line delays may result in an incorrect SDA/SCL timing relationship.

15.4.4.2 Addressing Slave Protocol

There are 2 address formats: the 7-bit and 10-bit address formats.

15.4.4.2.1 7-Bit Address Format

During the 7-bit address format, the first 7 bits (bits[7:1]) of the first byte set the slave address and the Least Significant bit (LSb) (bit[0]) is the R/W bit (as shown in Figure 68). When bit 0 (R/W) is set to 0, the master writes to the slave. When bit 0 (R/W) is set to 1, the master reads from the slave.

Figure 68 shows the 7-bit address format.

Figure 68: 7-Bit Address Format

Note: The signal transitions for the START/STOP conditions reflect those observed at the output signals of the Master driving the I²C bus. Use caution when observing the SDA/SCL signals at the input signals of the Slave(s), because unequal line delays may result in an incorrect SDA/SCL timing relationship.
15.4.4.2.2 10-Bit Address Format

During 10-bit addressing, 2 bytes are transferred to set the 10-bit address. The transfer of the first byte contains the following bit definition. The first 5 bits (bits[7:3]) notify the slaves that this is a 10-bit transfer followed by the next 2 bits (bits[2:1]), which set the slaves address bits 9:8, and the LSb (bit 0) is the /W bit. The second byte transferred sets bits 7:0 of the slave address.

Figure 69 shows the 10-bit address format.

Figure 69: 10-Bit Address Format

15.4.4.3 Transmitting and Receiving Protocol

The master can initiate data transmission and reception to/from the bus, acting as either a master-transmitter or master-receiver. A slave responds to requests from the master to either transmit data or receive data to/from the bus, acting as either a slave-transmitter or slave-receiver, respectively.

15.4.4.3.1 Master-Transmitter and Slave-Receiver

All data is transmitted in byte format, with no limit on the number of bytes transferred per data transfer. After the master sends the address and R/W bit or the master transmits a byte of data to the slave, the slave-receiver must respond with the acknowledge signal (ACK). When a slave-receiver does not respond with an ACK pulse, the master aborts the transfer by issuing a STOP condition. The slave must leave the SDA line high so that the master can abort the transfer.

Figure 70: Master-Transmitter Protocol
15.4.4.3.2 Master-Receiver and Slave-Transmitter

If the master is receiving data as shown in Figure 71, then the master responds to the slave-transmitter with an acknowledge pulse after a byte of data has been received, except for the last byte. This method is how the master-receiver notifies the slave-transmitter that this is the last byte. The slave-transmitter relinquishes the SDA line after detecting the Negative Acknowledgment (NACK) so that the master can issue a STOP condition.

When a master refuses to relinquish the bus with a STOP condition, the master can issue a RESTART condition. This is identical to a START condition except it occurs after the ACK pulse. Operating in master mode, the I\textsuperscript{2}C can then communicate with the same slave using a transfer of a different direction. For a description of the combined format transactions that the I\textsuperscript{2}C supports, refer to “Combined Formats.”

**Figure 71: Master-Receive Protocol**

<table>
<thead>
<tr>
<th>S</th>
<th>Slave Address</th>
<th>RW</th>
<th>A</th>
<th>DATA</th>
<th>A</th>
<th>DATA</th>
<th>A</th>
<th>P</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Slave Address First 7 Bits</td>
<td>RW</td>
<td>A</td>
<td>Second Byte</td>
<td>A</td>
<td>Sr</td>
<td>Slave Address First 7 Bits</td>
<td>RW</td>
</tr>
<tr>
<td></td>
<td>‘1’ (read)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>‘11110xxx’</td>
<td></td>
</tr>
</tbody>
</table>

From Master to Slave

A = Acknowledge(SDA low)

R = RESTART condition

From Slave to Master

\(\bar{A}\) = Acknowledge(SDA high)

P = STOP condition

S = START condition

15.4.5 Multiple Master Arbitration

The I\textsuperscript{2}C bus protocol allows multiple masters to reside on the same bus. If there are 2 masters on the same I\textsuperscript{2}C bus, there is an arbitration procedure if both try to take control of the bus at the same time by generating a START condition at the same time. Once a master (for example, a microcontroller) has control of the bus, no other master can take control until the first master sends a STOP condition and places the bus in an idle state.

Arbitration occurs on the SDA line, while the SCL line is 1. The master, which transmits a 1 while the other mastertransmits 0, loses arbitration and turns off its data output stage. The master that lost arbitration can continue to generate clocks until the end of the byte transfer. If both masters are addressing the same slave device, the arbitration could go into the data phase.

The I\textsuperscript{2}C stops generating SCL when it has detected it has lost arbitration to another master.

**Figure 72** shows the timing of when 2 masters are arbitrating on the bus.
Arbitration is not allowed between the following conditions:
- RESTART condition and a data bit
- STOP condition and a data bit
- RESTART condition and a STOP condition

Slaves are not involved in the arbitration process.

### 15.4.6 Clock Synchronization

When 2 or more masters try to transfer information on the bus at the same time, they must arbitrate and synchronize the SCL clock. All masters generate their own clock to transfer messages. Data is valid only during the high period of SCL clock. Clock synchronization is performed using the wired-AND connection to the SCL signal. When the master transitions the SCL clock to 0, the master starts counting the low time of the SCL clock and transitions the SCL clock signal to 1 at the beginning of the next clock period. However, if another master is holding the SCL line to 0, then the master goes into a HIGH wait state until the SCL clock line transitions to 1.

All masters then count off their high time. The master with the shortest high time transitions the SCL line to 0. The masters then counts out their low time. The count with the longest low time forces the other master into a HIGH wait state. Therefore, a synchronized SCL clock is generated. Optionally, slaves may hold the SCL line low to slow down the timing on the I2C bus.

### Figure 72: Multiple Master Arbitration

![Multiple Master Arbitration Diagram]

Arbitration is not allowed between the following conditions:
- RESTART condition and a data bit
- STOP condition and a data bit
- RESTART condition and a STOP condition

Slaves are not involved in the arbitration process.

### Figure 73: Multi-Master Clock Synchronization

![Multi-Master Clock Synchronization Diagram]
15.4.7 Operation Modes

This section provides information on operation modes.

**Note:** The I\(^2\)C should only be set to operate as an I\(^2\)C Master, or I\(^2\)C Slave, but not both simultaneously. This is achieved by ensuring that Bit[6] (SLAVE_DISABLE) and Bit[0] (MASTER_MODE) of the IIC_CON register are never set to 0 and 1, respectively.

15.4.7.1 Slave Mode Operation

**Initial Configuration**

To use the I\(^2\)C as a slave, perform the following steps:

1. Disable the I\(^2\)C by writing a 0 to Bit 0 of the I2C_ENABLE register.
2. Write to the I2C_SAR register (bits 9:0) to set the slave address. This is the address to which the I\(^2\)C responds.
3. Write to the IIC_CON register to specify which type of addressing is supported (7-bit or 10-bit by setting Bit 3). Enable the I\(^2\)C in slave-only mode by writing a 0 into bit 6 (SLAVE_DISABLE) and a 0 to Bit 0 (MASTER_MODE).

**Note:** Slaves and masters do not have to be programmed with the same type of addressing 7- or 10-bit address. For instance, a slave can be programmed with 7-bit addressing and a master with 10-bit addressing, and vice versa.

4. Enable the TWSI by writing a 1 to Bit 0 of the IIC_ENABLE register.

**Slave-Transmitter Operation for a Single Byte**

When another I\(^2\)C master device on the bus addresses the I\(^2\)C and requests data, the I\(^2\)C acts as a slave-transmitter and the following steps occur:

1. The other I\(^2\)C master device initiates an I\(^2\)C transfer with an address that matches the slave address in the I2C_SAR register of the I2C.
2. The I\(^2\)C acknowledges the sent address and recognizes the direction of the transfer to indicate that it is acting as a slave-transmitter.
3. The I\(^2\)C asserts the RD_REQ interrupt (Bit 5 of the I2C_RAW_INTR_STAT register) and holds the SCL line low. It is in a wait state until software responds. If the RD_REQ interrupt has been masked, due to I2C_INTR_MASK [5] register (M_RD_REQ bit field) being set to 0, then NXP recommends that a hardware and/or software timing routine be used to instruct the CPU to perform periodic reads of the I2C_RAW_INTR_STAT register.
   a) Reads that indicate I2C_RAW_INTR_STAT [5] (R_RD_REQ bit field) being set to 1 must be treated as the equivalent of the RD_REQ interrupt being asserted.
   b) Software must then act to satisfy the I\(^2\)C transfer.
   c) The timing interval used should be in the order of 10 times the fastest SCL clock period the I\(^2\)C can handle. For example, for 400 Kbps, the timing interval is 25 \(\mu\)s.

**Note:** The value of 10 is recommended here because this is approximately the amount of time required for a single byte of data transferred on the I\(^2\)C bus.

4. If there is any data remaining in the TX FIFO before receiving the read request, then the I\(^2\)C asserts a TX_ABRT interrupt (Bit 6 of the I2C_RAW_INTR_STAT register) to flush the old data from the TX FIFO.

**Note:** Because the I\(^2\)C TX FIFO is forced into a flushed/reset state whenever a TX_ABRT event occurs, software must release the I\(^2\)C from this state by reading the I2C_CLR_TX_ABRT register before attempting to write into the TX FIFO. See register I2C_RAW_INTR_STAT for more details.
If the TX_ABRT interrupt has been masked, due to of I2C_INTR_MASK [6] register (M_TX_ABRT bit field) being set to 0, it is recommended that re-using the timing routine (described in the previous step), or a similar one be used to read the I2C_RAW_INTR_STAT register.

a) Reads that indicate Bit 6 (R_TX_ABRT) being set to 1 must be treated as the equivalent of the TX_ABRT interrupt being asserted.
b) There is no further action required from software.
c) The timing interval used should be similar to that described in the previous step for the I2C_RAW_INTR_STAT [5] register.

5. Software writes to the IIC_DATA_CMD register with the data to be written (by writing a 0 in Bit 8).

6. Software must clear the RD_REQ and TX_ABRT interrupts (bits 5 and 6, respectively) of the I2C_RAW_INTR_STAT register before proceeding. If the RD_REQ and/or TX_ABRT interrupts have been masked, then clearing of the I2C_RAW_INTR_STAT register will have already been performed when either the R_RD_REQ or R_TX_ABRT bit has been read as 1.

7. The I2C releases the SCL and transmits the byte.

8. The master may hold the I2C bus by issuing a RESTART condition or release the bus by issuing a STOP condition.

Slave-Receiver Operation for a Single Byte

When another I2C master device on the bus addresses the I2C and is sending data, the I2C acts as a slave-receiver and the following steps occur:

1. The other I2C master device initiates a I2C transfer with an address that matches the I2C slave address in the I2C_SAR register.
2. The I2C acknowledges the sent address and recognizes the direction of the transfer to indicate that the I2C is acting as a slave-receiver.
3. I2C receives the transmitted byte and places it in the receive buffer.

Note: If the RX FIFO is completely filled with data when a byte is pushed, then an overflow occurs and the I2C continues with subsequent I2C transfers. Because a NACK is not generated, software must recognize the overflow when indicated by the I2C (by the R_RX_OVER bit in the IIC_INTR_STAT register) and take appropriate actions to recover from lost data. Therefore, there is a real-time constraint on software to service the RX FIFO before the latter overflow as there is no way to reapply pressure to the remote transmitting master. Users must select a deep enough RX FIFO depth to satisfy the interrupt service interval of their system.

4. I2C asserts the RX_FULL interrupt (I2C_RAW_INTR_STAT [2] register). If the RX_FULL interrupt has been masked, due to setting I2C_INTR_MASK [2] register to 0 or setting I2C_TX TL to a value larger than 0, then NXP recommends that a timing routine (see Slave-Transmitter Operation for a Single Byte, on page 199) be implemented for periodic reads of the I2C_STATUS register. Reads of the I2C_STATUS register, with Bit 3 (RFNE) set at 1, must then be treated by software as the equivalent of the RX_FULL interrupt being asserted.

5. Software may read the byte from the IIC_DATA_CMD register (bits 7:0).

6. The other master device may hold the I2C bus by issuing a RESTART condition or release the bus by issuing a STOP condition.
Slave-Transfer Operation for Bulk Transfers

In the standard I²C protocol, all transactions are single byte transactions and the programmer responds to a remote master read request by writing 1 byte into the slave TX FIFO. When a slave (slave-transmitter) is issued with a read request (RD_REQ) from the remote master (master-receiver), at a minimum there should be at least 1 entry placed into the slave-transmitter TX FIFO. I²C is designed to handle more data in the TX FIFO so that subsequent read requests can take that data without raising an interrupt to get more data. Ultimately, this eliminates the possibility of significant latencies being incurred between raising the interrupt for data each time had there been a restriction of having only 1 entry placed in the TX FIFO.

This mode only occurs when I²C is acting as a slave-transmitter. If the remote master acknowledges the data sent by the slave-transmitter and there is no data in the slave TX FIFO, the I²C holds the I²C SCL line low while it raises the read request interrupt (RD_REQ) and waits for data to be written into the TX FIFO before it can be sent to the remote master.

If the RD_REQ interrupt is masked, due to Bit 5 (M_RD_REQ) of the I2C_INTR_STAT register being set to 0, then it is recommended that a timing routine be used to activate periodic reads of the I2C_RAW_INTR_STAT register. Reads of I2C_RAW_INTRSTAT that return Bit 5 (R_RD_REQ) set to 1 must be treated as the equivalent of the RD_REQ interrupt referred to in this section. This timing routine is similar to that described in Slave-Transmitter Operation for a Single Byte, on page 199.

The RD_REQ interrupt is raised upon a read request, and like interrupts, must be cleared when exiting the interrupt service handling routine (ISR). The ISR allows users to either write 1 byte or more than 1 byte into the TX FIFO. During the transmission of these bytes to the master, if the master acknowledges the last byte, then the slave must raise the RD_REQ again because the master is requesting for more data.

If the programmer knows in advance that the remote master is requesting a packet of \( n \) bytes, then when another master addresses I²C and requests data, the TX FIFO could be written with \( n \) number bytes and the remote master receives it as a continuous stream of data. For example, the I²C slave continues to send data to the remote master as long as the remote master is acknowledging the data sent and there is data available in the TX FIFO. There is no need to hold the SCL line low or to issue RD_REQ again.

If the remote master is to receive \( n \) bytes from the I²C but the programmer wrote a number of bytes larger than \( n \) to the TX FIFO, then when the slave finishes sending the requested \( n \) bytes, it clears the TX FIFO and ignores any excess bytes.

The I²C generates a transmit abort (TX_ABRT) event to indicate the clearing of the TX FIFO in this example. At the time an ACK/NACK is expected, if a NACK is received, then the remote master has all the data it wants. At this time, a flag is raised within the slave state machine to clear the leftover data in the TX FIFO. This flag is transferred to the processor bus clock domain where the FIFO exists and the contents of the TX FIFO are cleared at that time.
15.4.7.2 Master Mode Operation

Initial Configuration

Perform the following steps to use the I²C as a master:

1. Disable the I²C by writing 0 to the I2C_ENABLE register.
2. Write to the I2C_CON register to set the maximum speed mode supported for slave operation (bits 2:1) and to specify whether the I²C starts its transfers in 7/10 bit addressing mode when the device is a slave (Bit 3).
3. Write to the I2C_TAR register the address of the I²C device to be addressed. It also indicates whether a General Call or a START BYTE command is going to be performed by I²C. The required speed of the I²C master-initiated transfers, either 7-bit or 10-bit addressing, is controlled by the BIT Offset address10_MASTER bit field (bit 12).
4. Enable the I²C by writing a 1 in the I2C_ENABLE register.
5. Now write the transfer direction and data to be sent to the I2C_DATA_CMD register. If the I2C_DATA_CMD register is written before the I²C is enabled, the data and commands are lost as the buffers are kept cleared when I²C is not enabled.

Note: For multiple I²C transfers, perform additional writes to the TX FIFO such that the TX FIFO does not become empty during the I²C transaction. If the TX FIFO is completely emptied at any stage, then further writes to the TX FIFO result in an independent I²C transaction.

Dynamic TAR or BIT Offset address10_MASTER Update

The I²C supports dynamic updating of the TAR (bits 9:0) and BIT Offset address10_MASTER (Bit 12) bit fields of the IIC_TAR register. Users can dynamically write to the I2C_TAR register provided all of the following conditions are met:

- I²C is not enabled (I2C_ENABLE [0] =0); OR I²C is enabled (I2C_ENABLE [0] =1)
- I²C is NOT engaged in any Master (tx, rx) operation (I2C_STATUS [5] =0)
- I²C is enabled to operate in Master Mode (I2C_CON [0] =1)
- No entries in the TX FIFO (I2C_STATUS [2] =1)

Master Transmit and Master Receive

The TWSI supports switching back and forth between reading and writing dynamically. To transmit data, write the data to be written to the lower byte of the I²C Rx/Tx Data Buffer and Command Register (I2C_DATA_CMD). The CMD bit [8] should be written to 0 for I²C write operations. Subsequently, a read command may be issued by writing "don’t cares" to the lower byte of the I2C_DATA_CMD register, and a 1 should be written to the CMD bit. The I²C master continues to initiate transfers as long as there are commands present in the transmit FIFO. If the transmit FIFO becomes empty, the I²C inserts a STOP condition after completing the current transfers.
15.4.8 I2C.CLK Frequency Configuration

When the I²C is configured as a master, the *CNT registers must be set before any I²C bus transaction can occur to ensure proper I/O timing.

The *CNT registers are:
- I2C.SS_SCL_HCNT
- I2C.SS_SCL_LCNT
- I2C.FS_SCL_HCNT
- I2C.FS_SCL_LCNT

15.4.8.1 Calculating High and Low Counts

This section shows how to calculate SCL high and low counts for each speed mode in the I²C. In this TWSI module ic_clk is 16 MHz. The equation to calculate the proper number of ic_clk signals required for setting the proper SCL clocks high and low times is as follows:

$$IIC_{xCNT} = \text{(ROUNDUP ( MIN_SCL_{xxxtime} * OSCFREQ, 0 ) )}$$

ROUNDUP is an explicit Excel function call that is used to convert a real number to its equivalent integer number.

MIN_SCL_HIGHtime = Minimum High Period

- MIN_SCL_HIGHtime = 4000 ns for 100 Kbps
- 600 ns for 400 Kbps
- 60 ns for 3.4 Mbs, bus loading = 100 pF
- 160 ns for 3.4 Mbs, bus loading = 400 pF

MIN_SCL_LOWtime = Minimum Low Period

- MIN_SCL_LOWtime = 4700 ns for 100 Kbps
- 1300 ns for 400 Kbps
- 120 ns for 2.4 Mbps, bus loading = 100 pF
- 320 ns for 2.4 Mbps, bus loading = 400 pF

OSCFREQ = ic_clk Clock Frequency (Hz)

For example:

OSCFREQ = 100 MHz

I2C mode = fast, 40 Kbps

MIN_SCL_HIGHtime = 600 ns.

MIN_SCL_LOWtime = 1300 ns.

$$IIC_{xCNT} = \text{(ROUNDUP(MIN_SCL_HIGHLOWtime*OSCFREQ,0))}$$

$$IIC_{HCNT} = \text{(ROUNDUP(600 ns * 100 MHz,0))}$$

IIC_HCNTSCL PERIOD = 60

$$IIC_{LCNT} = \text{(ROUNDUP(1300 ns * 100 MHz,0))}$$

IIC_LCNTSCL PERIOD = 130

Actual MIN_SCL_HIGHtime = 60*(1/100 MHz) = 600 ns
Actual MIN_SCL_LOWtime = 130*(1/100 MHz) = 1300 ns
15.4.9 DMA Controller Interface

The \( \text{I}^2\text{C} \) has a built-in DMA capability to request and control transfers. To enable the DMA Controller interface on the \( \text{I}^2\text{C} \), write the DMA Control Register (DMAC.I2C_DMA_CR). Writing a 1 into the TDMAE bit field of DMAC.I2C_DMA_CR register enables the \( \text{I}^2\text{C} \) transmit handshaking interface. Writing a 1 into the RDMAE bit field of the DMAC.I2C_DMA_CR register enables the \( \text{I}^2\text{C} \) receive handshaking interface.

See Section 8, Direct Memory Access (DMA) Controller, on page 130 for more information.

15.5 Register Description

See Section 24.7.2, I2C Registers for a detailed description of the registers.
16 Synchronous Serial Protocol (SSP)

16.1 Overview
An SSP port is a synchronous serial controller that can be connected to a variety of external Analog-to-Digital converters (ADC), audio and telecommunication codecs, and many other devices that use serial protocols for data transfer.

The 88MW320/322 supports three SSP interfaces: SSP0, SSP1, and SSP2. The SSP ports are configurable to operate in Master mode (the attached peripheral functions as a slave) or Slave mode (the attached peripheral functions as a master).

The SSP ports support serial bit rates up to 25 Mbps. Serial data sample size can be set to 8, 16, 18, or 32 bits in length. A FIFO is provided for Transmit data, and a second independent FIFO is provided for Receive data. Both FIFOs are 16 x 32 bits wide or both are 32 x 16 bits wide. The FIFOs can be loaded or emptied by the Cortex-M4F or by DMA burst transfers.

16.2 Features
- Directly supports Texas Instruments* (TI) Synchronous Serial Protocol (SSP), and Motorola* Serial Peripheral Interface (SPI)
- I2S protocol is supported by programming the PSP
  - I2S Philips standard
  - Most Significant bit (MSb)-justified standard (left justified)
  - Master or Slave mode operation
  - Data transfer up to 25 Mbps
  - Programmable data frame size: 8, 16, 18, or 32 bits
  - Separate FIFO for transmit and receive with 16 x 32 or 32 x 16 bit length
  - Receive-without-Transmit operation
  - Network mode with as many as 8 time slots for Programmable Serial Protocol (PSP) formats
- Independent transmit/receive in any, all, or none of the time slots
- Supports DMA transfer
16.3 Interface Signal Description

Table 140 shows the interface signals.

Table 140: SSP Interface Signals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
</table>
| SSPx_RXD    | I    | Synchronous Serial Protocol Receive Data
|             |      | Serial data in. Sample length is selected by the <Extended Data Size Select> and <Data Size Select> fields in the SSP Control Register 0, |
| SSPx_TXD    | O    | Synchronous Serial Protocol Transmit Data
|             |      | Serial data out. Sample length is selected by the <Extended Data Size Select> and <Data Size Select> fields in the SSP Control Register 0, |
| SSPx_CLK    | I/O  | Synchronous Serial Protocol Serial Clock
|             |      | Controls the timing of a serial transfer. SSPx_CLK can be generated internally (master mode) or taken from an external source (slave mode) |
| SSPx_FRM    | I/O  | Synchronous Serial Protocol Serial Frame Indicator
|             |      | Indicates the beginning and the end of a serialized data sample. The SSPx_FRM can be generated internally (master mode) or taken from an external source (slave mode). |

1. See Section 22.11.1, SSP Timing and Specifications, on page 294 for electrical specifications.

16.4 Functional Description

Serial data is transferred between the Cortex-M4F Processor and an external peripheral through FIFOs in the SSPx port. Data transfers between an SSPx port and memory are initiated by the core or by DMA bursts. Separate data paths for transmitting and receiving permit simultaneous transaction in both directions, depending on the protocols chosen. The core and DMA bursts transaction can transfer data between:
- Memory to the FIFO Data Register for the TXFIFO
- FIFO Data Register to memory for the RXFIFO

Data written to the FIFO Data Register by either the core or DMA is automatically transferred to the Transmit FIFO. When reading the FIFO Data Register by either the core or DMA, the data in the Receive FIFO is transferred automatically from the FIFO data register.

16.4.1 FIFO Operation

There are 2 separate and independent FIFOs available for transmitting (TXFIFO to peripheral) and receiving (RXFIFO from peripheral) serial data. The FIFOs are filled or emptied by the Cortex-M4F core or DMA bursts. The data is accessed through the TXFIFO and RXFIFO. The Cortex-M4F accesses are normally triggered by an interrupt caused by an SSP Status Register event (see the Appendix in this manual) and must always be 32 bits wide. The Cortex-M4F writes to the TXFIFO are 32-bits wide, but bits beyond the programmed FIFO data size are ignored. The Cortex-M4F Reads from the RXFIFO are also 32 bits wide with 0’s inserted in the MSb’s, down to the programmed data size.

The TXFIFO and RXFIFO can also be accessed by DMA bursts, which must be 8, 16, or 32 bytes in length, and must transfer 1 FIFO entry per access. When the SSP_SSCR0[EDSS] bit is set, the SSPx port must be configured as a 32-bit peripheral. The DMA burst transaction width must be programmed to at least the same data size programmed into this SSP_SSCR0[EDSS] and SSP_SSCR0[DSS] fields.
The TXFIFO and RXFIFO are each accessed as 1, 32-bit location by the Cortex-M4F core. For data transmission, the SSPx port transmits the data from the TXFIFO to the external peripheral through the SSPx_TXD interface. Data received from the external peripheral through the SSPx_RXD interface is converted to parallel words and written into the RXFIFO.

An interrupt or DMA service request is generated if a programmable FIFO trigger threshold exceeded which signals the Cortex-M4F or DMA to empty the RXFIFO or refill the TXFIFO.

The TXFIFO and RXFIFO are differentiated by whether the access is a Read or a Write transfer. Reads from the Data Register automatically target the RXFIFO. Writes to the FIFO Data Register automatically target the TXFIFO. From a memory-map perspective, the TXFIFO and the RXFIFO are at the same address. Each FIFO is 16 rows deep x 32 bits wide for a total of 16 data samples. Each sample can be 8, 16, 18, or 32 bits in length.

### 16.4.1.1 Parallel Data Formats for FIFO Storage

Data in the FIFOs is either stored with 1, 32-bit value per data sample (in non-packed or data size greater than 16 bits) or in a 16-bit value in packed mode when the data is 8 or 16 bits. Within each 32- or 16-bit field, the stored data sample is right-justified, with the LSb of the word in Bit 0. In the Receive FIFO, unused bits are packed as 0's above the MSb. In the Transmit FIFO, unused “don’t-care” bits are above the MSb. For example, DMA accesses do not have to write to the unused bit locations. Logic in the SSP automatically formats data in the Transmit FIFO so that the sample is properly transmitted on SSPx_TXD in the selected frame format.

### 16.4.1.2 FIFO Operation in Packed Mode

When the TXFIFO and RXFIFO are operating in packed mode, each FIFO is 32 rows deep x 16-bits wide for a total of 32 data samples. For packed mode, each sample can be 8 or 16 bits in length. When the data is serialized and transmitted, Bits 15 to 0 are transmitted first, followed by Bits 31 to 16. When the TXFIFO and RXFIFO are operating in packed mode, they may best be thought of as a single entry of 32 bits holding 2, 8- or 16-bit samples. Thus, the Cortex-M4F Processor or the DMA should write and read 32 bits of data at a time where each Write or Read transfers 2 samples. The entire FIFO width (32 bits) must be read/written in this mode. The SSP FIFO thresholds align in 32-bit data size.

### 16.4.2 Using Programmed I/O Data Transfers

FIFO filling and emptying can be performed by the Cortex-M4F Processor in response to an interrupt from the FIFO logic. Each FIFO has a programmable FIFO trigger threshold that triggers an interrupt. When the number of entries in the RXFIFO exceeds the RXFIFO Trigger Threshold (SSP_SSCR1[RFT]) field in the SSP Control Register 1, an interrupt is generated (if enabled) that signals Cortex-M4F Processor to empty the RXFIFO. When the number of entries in the TXFIFO is less than or equal to the TXFIFO Trigger Threshold (SSP_SSCR1[TFT]) field in the SSP Control Register 1 plus 1, an interrupt is generated (if enabled) that signals the Cortex-M4F Processor to refill the TXFIFO.

The SSP Status Register can be polled to determine how many samples are in a FIFO and whether the FIFO is full or empty. Software is responsible for ensuring that the proper RXFIFO Trigger Threshold and TXFIFO Trigger Threshold values are chosen to prevent Receive FIFO Overrun and Transmit FIFO Underrun (in the SSP Status Register) error conditions.
16.4.3 **Using DMA Data Transfers**

The DMA controller can also be programmed to transfer data to and from the FIFOs. The SSP Serial Port uses the following handshaking signals to interface with the DMA controller:

- `dma_tx_req`
- `dma_tx_single`
- `dma_tx_ack`
- `dma_rx_req`
- `dma_rx_single`
- `dma_rx_ack`

As a block flow control device, the DMA Controller is programmed by the processor with the number of data items (block size) to be transmitted or received by the SSP. The block will be broken into a number of transactions, each initiated by a request from the SSP. The DMA Controller must also be programmed with the number of data items to be transferred for each DMA request, which is named burst size. When the block size is a multiple of the burst size, the DMA block transfer consists of a series of burst transactions. When the block size programmed into the DMA Controller is not a multiple of the burst size, a series of burst transactions followed by single transactions are needed to complete the block transfer.

16.4.3.1 **Transmit and Receive FIFO Trigger Threshold**

During SSP serial transfers, transmit FIFO requests are generated whenever the number of entries in the transmit FIFO is less than or equal to the transmit FIFO trigger threshold, which can be configured in TXFIFO threshold (SSCR1[TFT]) field. The DMA responds by writing a burst of data to the transmit FIFO buffer. The configuration of DMA burst size and SSCR1[TFT] should be correctly set to prevent the underflow and overflow of Transmit FIFO.

Programming DMA burst size to a value greater than the transmit FIFO threshold that triggers the DMA request may cause overflow when there is not enough space in the SSP transmit FIFO to service the destination burst request. Therefore, the DMA burst size should not be greater than the trigger threshold. The optimal operation is setting the DMA burst size the same as the transmit FIFO trigger threshold (SSCR1[TFT] value +1).

When the DMA burst size is equal to the empty space in the Transmit FIFO, the difference of transmit FIFO threshold will also lead to different situation. If the trigger threshold is low, the number of burst transactions of the DMA is lower than the high trigger threshold situation, which means has a better bus utilization. However, the probability of the FIFO underflow is high because the DMA may not have had enough time to service the DMA request before the transmit FIFO becomes empty. Software should choose a trigger threshold to balance the number of transactions per block and the probability of an underflow.

During SSP serial transfers, Receive FIFO requests are generated whenever the number of entries in the Receive FIFO is above the Receive FIFO trigger threshold, which can be configured in RXFIFO threshold (SSCR1[RFT]) field. The DMA responds by reading a burst of data from the Receive FIFO buffer. The configuration of DMA burst size and SSCR1[RFT] should be correctly to prevent the underflow and overflow of Transmit FIFO.

Programming DMA burst size to a value greater than the Receive FIFO threshold that triggers the DMA request may cause underflow when there is not enough data in the SSP Receive FIFO to service the destination burst request. Therefore, the DMA burst size should not be greater than the trigger threshold. The optimal operation is setting the DMA burst size the same as the Receive FIFO trigger threshold (SSCR1[RFT] value +1). Similar to choosing the transmit FIFO threshold, software should also choose a Receive FIFO trigger threshold to balance the number of transactions per block and the probability of an Receive FIFO overflow.
When not using packed mode, the SSP stores 1 data sample per FIFO location where each FIFO has 16 locations. When using packed mode, the SSP stores 2 data samples per FIFO location where each FIFO has 16 locations.

### 16.4.3.2 Handshaking Interface Details

The request signals for source and destination (dma_tx_req and dma_rx_req) are activated when their corresponding FIFOs reach the trigger levels discussed prior. The DMA uses rising-edge detection of the dma_tx_req/dma_rx_req signal to identify a request on the channel from SSP. Upon reception of the dma_tx_ack/dma_rx_ack signal from the DMA to indicate the burst transaction is complete, the SSP de-asserts the burst request signals. Then, the dma_tx_ack/dma_rx_ack will be de-asserted by the DMA. When the SSP samples that dma_tx_ack/dma_rx_ack is de-asserted, it can re-assert the dma_tx_req/dma_rx_req if their corresponding FIFOs exceed their trigger levels (back-to-back burst transaction). Otherwise, the DMA request remains de-asserted.

*Figure 74* shows a timing diagram of a burst transaction where pclk = hclk.

*Figure 75* shows 2 back-to-back burst transactions where the hclk frequency is twice the pclk frequency.

---

**Figure 74: Burst Transaction, hclk = pclk**

![Timing Diagram](image1)

**Figure 75: Burst Transaction, hclk = 2*pclk**

![Timing Diagram](image2)
The handshaking loop is as follows:
- dma_tx_req/dma_rx_req asserted by SSP
- dma_tx_ack/dma_rx_ack asserted by DMAC
- dma_tx_req/dma_rx_req de-asserted by SSP
- dma_tx_ack/dma_rx_ack de-asserted by DMAC
- dma_tx_req/dma_rx_req re-asserted by SSP, if back-to-back transaction is required

The burst transaction request signals (dma_tx_req and dma_rx_req) are generated in the SSP off pclk and sampled in the DMA by hclk. The acknowledge signals (dma_tx_ack and dma_rx_ack) are generated in the DMA off hclk and sampled in the SSP of pclk. The handshaking mechanism between the DMA and the SSP supports quasi-synchronous clocks. That is, hclk and pclk must be phase-aligned, and the hclk frequency must be a multiple of the pclk frequency.

The dma_tx_single signal is asserted when there is at least 1 free entry in the transmit FIFO and is cleared when the transmit FIFO is full or the dma_tx_ack signal is active. The dma_tx_single signal will be re-asserted when the dma_tx_ack signal is removed if the condition for setting still holds true.

The dma_rx_single signal is asserted when there is at least 1 valid data entry in the receive FIFO and is cleared when the receive FIFO is empty or the dma_rx_ack signal is active. The dma_rx_single signal will be re-asserted when the dma_rx_ack signal is removed if the condition for setting still holds true.

These signals are needed by the DMA only for the case that the block size programmed in the DMA is not a multiple of the burst size. For example, for a Block size of 15 and burst size of 4:

The first 12 data items are transferred as already described using 3 burst transactions. When the last 3 data frames enter the receive FIFO, the dma_rx_req signal is not activated because the FIFO level is below the trigger level 4. The DMA samples dma_rx_single and completes the DMA block transfer using 3 single transactions. The block transfer is made up of 3 burst transactions followed by 3 single transactions.

The handshaking loop is as follows:
- dma_tx_single/dma_rx_single asserted by SSP
- dma_tx_ack/dma_rx_ack asserted by DMAC
- dma_tx_single/dma_rx_single de-asserted by SSP
- dma_tx_ack/dma_rx_ack de-asserted by DMAC

Figure 76 shows a burst transaction, followed by 3 back-to-back single transactions, where the hclk frequency is twice the pclk frequency.

**Figure 76: Burst Transaction, +3 Back-to-Back Singles **C hclk = 2*pclk
The single transaction request signals (dma_tx_single and dma_rx_single) are generated in the SSP on the pclk edge and sampled in DMA on hclk. The acknowledge signals (dma_tx_ack and dma_rx_ack) are generated in the DMA on the hclk edge hclk and sampled in the SSP on pclk. The handshaking mechanism between the DMA and the SSP supports quasi-synchronous clocks. That is, hclk and pclk must be phase-aligned, and the hclk frequency must be a multiple of pclk frequency.

16.4.4 SSP Interrupts

The SSP can generate 5 interrupts, each enabled individually by configuring their Interrupt Mask. See Table 141.

Table 141: SSP Interrupts

<table>
<thead>
<tr>
<th>Interrupt</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit Count Error interrupt (SSSR[BCE])</td>
<td>In slave mode, if the real sample size mismatch to the configuration of SSCR0[EDSS] and SSCR0[DSS], and when the SSCR1[EBCEI] (Enable Bit Count Error interrupt) is set, this interrupt is generated. Only support SSP and PSP formats.</td>
</tr>
<tr>
<td>Transmit FIFO Underrun</td>
<td>This interrupt is generated when a read operation occurs to the empty TXFIFO when the SSCR0[TIM] (Transmit FIFO Underrun Interrupt Mask) is set to 0 (enabled).</td>
</tr>
<tr>
<td>Receive FIFO Overrun</td>
<td>This interrupt is generated when a write operation occurs to the full RXFIFO when the SSCR0[RIM] (Receive FIFO Overrun Interrupt Mask) is set to 0 (enabled).</td>
</tr>
<tr>
<td>Transmit FIFO Service Request</td>
<td>This interrupt is generated when the number of entries in the transmit FIFO reaches or is below the transmit FIFO threshold (configured in SSCR1[TFT]) and if the SSCR1[TIE] (Transmit FIFO Interrupt Enable) is set to 1 (enabled).</td>
</tr>
<tr>
<td>Receive FIFO Service Request</td>
<td>This interrupt is generated when the number of entries in the receive FIFO exceeds the receive FIFO threshold (configured in SSCR1[RFT]) and if the SSCR1[RIE] (Receive FIFO Interrupt Enable) is set to 1 (enabled).</td>
</tr>
</tbody>
</table>

The SSP also has the read-write Interrupt test registers for testing purposes, which can assert interrupts directly by writing the register bits. For details, see Section 24.9.2, SSP Registers.

16.4.5 Data Formats

This section describes the types of formats used to transfer serial data between the Cortex-M4F core and external peripherals.

16.4.5.1 Serial Data Formats for Transfer to/from Peripherals

There are 4 interface signals for each SSPx port transfer data between the Cortex-M4F core and external peripherals. Although serial-data formats exist, each has the same basic structure, and in all cases, the interface signals used are:

- **SSPx_CLK** – Bit rate at which serial data is driven onto and sampled from the port
- **SSPx_FRM** – Boundaries of a basic data "unit", comprised of multiple serial bits
- **SSPx_TXD** – Serial datapath for transmitted data from the SSPx port to the peripheral
- **SSPx_RXD** – Serial datapath for received data from peripheral to the SSPx port
A data frame can contain 8, 16, 18, or 32 bits (see SSP_SSCR0[EDSS] and SSP_SSCR0[DSS] fields in the Section 24.9, SSP Address Block). Serial data is transmitted with the MSb first. The formats directly supported are the Motorola SPI and Texas Instruments SSP. The I²S protocol is supported by programming the PSP format.

The SSPx_FRM function and use varies between each format:

- **SPI format** – SSPx_FRM functions as a chip select to enable the external device (target of the transfer) and is held active-low during the data transfer. During continuous transfers, the SSPx_FRM signal can be either held low or pulsed depending upon the value of the Motorola* SPI SSPx_CLK phase setting, SSP_SSCR1[SPH], field in the SSP Control Register 1. Master and Slave modes are supported. SPI is a full-duplex format.

- **SSP format** – SSPx_FRM is pulsed high for 1 (serial) data period at the start of each frame. Master and Slave modes are supported. SSP is a full-duplex format.

- **PSP format (I²S)** – SSPx_FRM is programmable in direction, delay, polarity, and width. Master and Slave modes are supported. PSP can be programmed to be either full- or half-duplex format.

The SSPx_CLK function and use varies between each format:

- **SPI format** – Programmers choose which edge of SSPx_CLK to use for switching Transmit data and for sampling Receive data. In addition, moving the phase of SSPx_CLK can be user-initiated, shifting its active state 1/2 cycle earlier or later at the start and end of a frame. Master and Slave modes are supported, and in both, the SSPx_CLK only toggles during active transfers (does not run continuously).

- **SSP format** – Data sources switch Transmit data on the rising edge of SSPx_CLK and sample Receive data on the falling edge. Master and Slave modes are supported. When driven by the SSPx port, the SSPx_CLK only toggles during active transfers (not continuously) unless the SSP_SSCR1[SCFR], SSP_SSCR1[ECRA], or SSP_SSCR1[ECRB] functions are used.

When the SSPx_CLK is driven by another device, it is allowed to be either continuous or only driven during transfers.

- **PSP format (I²S)** – Programmers choose which edge of SSPx_CLK to use for switching Transmit data and for sampling Receive data. In addition, programmers can control the Idle state for SSPx_CLK and the number of active clocks that precede and follow the data transmission. Master and Slave modes are supported. When driven by the SSPx port, the SSPx_CLK toggles only during active transfers, not continuously, unless the SSP_SSCR1[SCFR], SSP_SSCR1[ECRA], or SSP_SSCR1[ECRB] functions are used. When the SSPx_CLK is driven by another device, it is allowed to be either continuous or driven only during transfers, but certain restrictions on PSP parameters apply (see Programmable Serial Protocol (PSP) Format).

Normally, if the serial clock (SSPx_CLK) is driven by the SSPx port, it toggles only while an active data transfer is underway. However, there are several conditions that may cause the clock to run continuously. If the Receive-without-Transmit mode is enabled by setting the Receive Without Transmit SSP_SSCR1[RWOT], field and the frame format is not Microwire then the SSPx_CLK toggles regardless of whether Transmit data exists within the Transmit FIFO. The SSPx_CLK also toggles continuously if the SSPx port is in Network mode, or if the SSP_SSCR1[ECRA] or SSP_SSCR1[ECRB] bits are enabled. At other times, SSPx_CLK is held in an inactive or idle state, as defined by the specified protocol under which it operates.
16.4.5.2 TI-SSP Format Details

When outgoing data in the SSP controller is ready to transmit, SSPx_FRM asserts for 1 clock period. On the following clock, data to be transmitted is driven on SSPx_TXD 1 bit at a time, with the MSb first. For Receive data, the peripheral similarly drives data on the SSPx_RXD pin. Word length can be 8, 16, 18, or 32 bits. All output transitions occur on the rising edge of SSPx_CLK while data sampling occurs on the falling edge. The SSPx_TXD signal either retains the value of the last bit sent (bit 0) or goes to a high impedance state at the end of the transfer. If the SSPx port is disabled or reset, SSPx_TXD is forced to 0 (unless the TXD Tri-State Enable, SSP_SSCR1[TTE], bit is set, in which case it goes into a high impedance state).

Figure 77, Texas Instruments Synchronous Serial Frame Protocol (Single Transfers), on page 213 shows the TI Synchronous Serial Protocol for a single transmitted frame.

Figure 78, Texas Instruments Synchronous Serial Frame Protocol (Multiple Transfers), on page 214 shows the TI Synchronous Serial Protocol when back-to-back frames are transmitted.

Once the Transmit FIFO contains data, SSPx_FRM is pulsed high for 1 SSPx_CLK period and the value to be transmitted is transferred from the Transmit FIFO to the Transmit Logic Serial Shift register. On the next rising edge of SSPx_CLK, the most significant bit of the 8 to 32-bit data frame is shifted to the SSPx_TXD pin. Likewise, the MSb of the received data is shifted onto the SSPx_RXD pin by the off-chip serial slave device. Both the SSP port and the off-chip serial slave device then latch each data bit into the serial shifter on the falling edge of each SSPx_CLK. The received data is transferred from the serial shifter to the Receive FIFO on the first rising edge of SSPx_CLK after the last bit has been latched.

For back-to-back transfers, the start of 1 frame immediately follows the completion of the previous. The MSb of 1 transfer immediately follows the LSb of the preceding with no “dead” time between them.

When the enhanced SSPx port is a master to the frame synch (SSPx_FRM) and a slave to the clock (SSPx_CLK), then at least 3 extra clocks (SSPx_CLK) are needed at the beginning and end of each block of transfers to synchronize control signals from the ARM peripheral bus (APB) clock domain into the SSP clock domain (a block of transfers is a group of back-to-back continuous transfers).

Note: When configured as either master or slave to SSPx_CLK or SSPx_FRM, the SSP port continues to drive SSPx_TXD until the last bit of data is sent (the LSb) or the SSPx_TXD line becomes high impedance. If SSP_SSCR0[SSE] is cleared, the SSPx_TXD line goes low. SSP_SSSP[EDTS] has no effect when in SSP mode. SSPx_RXD is undefined before the MSb is sent and after the LSb is sent. SSPx_RXD must not float.

Figure 77: Texas Instruments Synchronous Serial Frame Protocol (Single Transfers)
16.4.5.3 Motorola SPI Format Details

The SPI format has 4 possible sub-modes depending on the SSPx_CLK edges selected for driving data and sampling received data and on the selection of the phase mode of SSPx_CLK (see Section 16.4.5.3.1, Serial Clock Phase (SPH), on page 215, for a complete description of each sub-mode).

When the SSP port is disabled or in idle mode, SSPx_CLK and SSPx_TXD are low and SSPx_FRM is high. When transmit data is ready to be sent, SSPx_FRM goes low (1 clock period before the first rising edge of SSPx_CLK) and stays low for the remainder of the frame. The most significant bit of the serial data is driven onto SSPx_TXD 1/2 cycle later. Halfway into the first bit period, SSPx_CLK asserts high and continues toggling for the remaining data bits. Data transitions on the falling edge of SSPx_CLK and is sampled on the rising edge of SSPx_CLK. 8, 16, 18, or 32 bits can be transferred per frame.

With the assertion of SSPx_FRM, Receive data is driven simultaneously from the peripheral on SSPx_RXD, MSb first. Data transitions on SSPx_CLK falling edges and is sampled by the controller on SSPx_CLK rising edges. At the end of the frame, SSPx_FRM is de-asserted high 1 clock period (1/2 clock cycle after the last falling edge of SSPx_CLK) after the last bit has been latched at its destination and the completed incoming word is shifted into the “incoming” FIFO. The peripheral can drive SSPx_RXD to a high-impedance state after sending the last bit of the frame. SSPx_TXD retains the last value transmitted when the controller goes into Idle mode, unless the enhanced SSPx port is disabled or reset (which forces SSPx_TXD to 0).

For back-to-back transfers, start and completion are like those of a single transfer, but SSPx_FRM does not de-assert between words. Both transmitter and receiver are configured for the word length and internally track the start and end of frames. There are no “dead” bits; the LSb of 1 frame is followed immediately by the MSb of the next.

When in Motorola SPI format, the enhanced SSPx port can be either a master or a slave device, but the clock and frame direction must be the same. For example, the SSP Serial Bit Rate Clock Direction, SSP_SSCR1[SCLKDIR], and the SSP Frame Direction, SSP_SSCR1[SFRMDIR], fields must either both be set or cleared.

When in Motorola SPI format, if the SSP port is the master and SSP_SSPSP[ETDS] is cleared, the end-of-transfer data state for SSPx_TXD is low. If the SSP port is the master and SSP_SSPSP[ETDS] is set, the end-of-transfer data state for SSPx_TXD remains at the last bit transmitted (LSb). If the SSP port is the slave, then the SSP_SSPSP[ETDS] is undefined.

SSPx_RXD is undefined before the frame is active and after the LSb is received. SSPRXD must not float. When the SSP port is configured as a master and SSP_SSCR1[TTE] is set, SSP_SSPSP[ETDS] is ignored and SSPx_TXD becomes high impedance between active transfers.

**Note:** The input clock to the SSPx port must not be active when SSPx_FRM is de-asserted. When the SSP port is slave to clock and frame, SSP_SSCR1[SCFR] must be set.
16.4.5.3.1 Serial Clock Phase (SPH)

The phase relationship between SSPx_CLK and SSPx_FRM when the Motorola SPI protocol is selected is controlled by SSP_SSCR1[SPH].

The combination of the SSP_SSCR1[SPO] and SSP_SSCR1[SPH] settings determine when SSPx_CLK is active during the assertion of SSPx_FRM and which SSPx_CLK edge transmits and receives data on SSPx_TXD and SSPx_RXD.

When SPH is cleared, SSPx_CLK remains in its inactive (idle) state (as determined by SSP_SSCR1[SPO]) for 1 full cycle after SSPx_FRM is asserted low at the beginning of a frame. SSPx_CLK continues to toggle for the rest of the frame. It is then held in its inactive state for 1/2 of an SSPx_CLK period before SSPx_FRM is de-asserted high at the end of the frame. When SPH is set, SSPx_CLK remains in its inactive or idle state (as determined by SSP_SSCR1[SPO]) for 1/2 cycle after SSPx_FRM is asserted low at the beginning of a frame. SSPx_CLK continues to toggle for the remainder of the frame and is then held in its inactive state for 1 full SSPx_CLK period before SSPx_FRM is de-asserted high at the end of the frame. When programming SSP_SSCR1[SPO] and SSP_SSCR1[SPH] to the same value (both set or both cleared), transmit data is driven on the falling edge of SSPx_CLK and receive data is latched on the rising edge of SSPx_CLK. When programming SSP_SSCR1[SPO] and SSP_SSCR1[SPH] to opposite values (1 set and the other cleared), transmit data is driven on the rising edge of SSPx_CLK and receive data is latched on the falling edge of SSPx_CLK.

See Figure 79, Figure 80, Figure 81, and Figure 82.

Figure 79: Motorola SPI Frame Protocol (Single Transfers)

Figure 80: Motorola SPI Frame Protocol (Multiple Transfers)
Figure 81: Motorola SPI Frame Protocols for SPO and SPH Programming (SPH Set)

Notes:
SSPx_TXD will be tri-stated at this point if TTE bit is set
SSPx_RXD should not float
SPH = 0

Figure 82: Motorola SPI Frame Protocols for SPO and SPH Programming (SPH Cleared)

Notes:
SSPx_TXD will be tri-stated at this point if TTE bit is set
SSPx_RXD should not float
SPH = 1
16.4.6 Programmable Serial Protocol (PSP) Format

The PSP format defines programmable parameters that determine the transfer timings between data samples. There are 4 serial clock modes defined in the Serial Bit-rate Clock Mode, SSP_SSPSP[SCMODE], field in the SSP Programmable Serial Protocol Register. These modes select the SSPx_CLK rising and falling edges for driving data, sampling received data, and the SSPx_CLK idle state.

Table 142, Programmable Protocol Parameters, on page 218 shows the Idle and Disable modes of the SSPx_TXD, SSPx_CLK, and SSPx_FRM interface signals are programmable using the following fields in the SSP Programmable Serial Protocol Register:
- End Of Transfer Data State (SSP_SSPSP[ETDS])
- Serial Frame Polarity (SSP_SSPSP[SFRMP])
- Serial Bit-rate Clock Mode (SSP_SSPSP[SCMODE])

When Transmit data is ready, SSPx_CLK remains in its idle state for the number of serial clock (SSPx_CLK) periods programmed into the Start Delay (SSP_SSPSP[STRTDLY]) field in the SSP Programmable Serial Protocol Register. SSPx_CLK then starts toggling. SSPx_TXD remains in the idle state for the number of serial clock periods programmed into the Dummy Start (SSP_SSPSP[DMYSTRT]) field in the SSP Programmable Serial Protocol Register. SSPx_FRM is asserted after the number of half serial clock periods programmed into the Serial Frame Delay (SSP_SSPSP[SFRMDLY]) field. SSPx_FRM remains asserted for the number of serial clock periods programmed into the Serial Frame Width (SSP_SSPSP[SFRMWDTH]) field in the SSP Programmable Serial Protocol Register, then SSPx_FRM de-asserts.

Serial data of 8, 16, 18, or 32 bits can be transferred per frame by setting the SSP_SSCR0[EDSS] and SSP_SSCR0[DSS] fields to the preferred data size select. Once the last bit (LSb) is transferred, SSPx_CLK continues toggling for the number of serial clock periods programmed into the Dummy Stop (SSP_SSPSP[DMYSTOP]) field. Depending on the value programmed into the End Of Transfer Data State (SSP_SSPSP[EDTS]) field when the SSPx port goes into Idle mode, SSPx_TXD either retains the last bit-value transmitted or is forced to 0 unless the SSPx port is disabled or reset, which forces SSPx_FRM to 0.

With the assertion of SSPx_FRM, Receive data is driven simultaneously from the peripheral onto SSPx_RXD, MSb first. Data transitions on the SSPx_CLK edge based on the serial-clock mode that is selected (SSP_SSPSP[SCMODE]) and is sampled by the SSPx port on the opposite clock edge. When the SSPx port is a master to SSPx_FRM and a slave to SSPx_CLK, at least 3 extra SSPSClks are needed at the beginning and end of each block of transfers to synchronize control signals from the APB clock domain into the SSP clock domain (a block of transfers is a group of back-to-back continuous transfers).

In general, because of the programmable nature of the PSP protocol, this protocol can be used to achieve a variety of serial protocols. For example: some DigRF protocol timing can be achieved by programming these values:
- Start Delay (SPP_SSPSP[STRTDLY]) = 0
- Dummy Start (SPP_SSPSP[DMYSTRT]) = 0
- Dummy Stop (SPP_SSPSP[DMYSTOP]) = 0
- Serial Frame Delay (SPP_SSPSP[SFRMDLY]) = 0

The SSPx port should be configured as a clock slave (SSP Serial Bit Rate Clock Direction (SSP_SSCR1[SCLKDIR]) = 1) and frame master (SSP Frame Direction (SSP_SSCR1[SFRMDIR]) = 0). Also, the Frame Sync Relative Timing Bit (SPP_SSPSP[FSRT]) field in the SSP Programmable Serial Protocol Register must be set for continuous transfers, and the Serial Frame Width (SSP_SSPSP[SFRMWDTH]) field should be equal to the data sample size.
The SSPx_FRM delay (T5) must not extend beyond the end of T4. The SSPx_FRM width (T6) must be asserted for at least 1 SSPx_CLK period and should be de-asserted before the end of T4 (for example, in terms of time, not bit values, to ensure that SSPx_FRM is asserted for at least 2 edges of SSPx_CLK).

\[(T5 + T6) \leq (T1 + T2 + T3 + T4), 1 \leq T6 < (T2 + T3 + T4), \text{and } (T5 + T6) \geq (T1 + 1)\]

Program T1 to 0b0 when SSPx_CLK is enabled by any of the SSP_SSCR1[SCFR], SSP_SSCR1[ECRA], or SSP_SSCR1[ECRB] fields in the SSP Control Register 1. While the PSP can be programmed to generate the assertion of SSPx_FRM during the middle of the data transfer (for example, after the MSb has been sent), the SSPx port is unable to Receive data in frame-Slave mode (SSP_SSPSP[SFRMDIR] is set, if the assertion of the frame is not before the MSb is sent (for example, T5 <= T2 if the SSP_SSCR1[SFRMDIR] bit is set). Transmit data transitions from the end-of-transfer-data state (SSP_SSPSP[ETDS]) to the next MSb data value upon assertion of the internal version of SSPx_FRM. Program the SSP_SSPSP[STRTDLY] field to 0x00 whenever SSPx_CLK or SSPx_FRM is configured as an input (for example, SSP_SSCR1[SCLKDIR] and SSP_SSCR1[SFRMDIR] are cleared.

See Figure 83, Programmable Serial Protocol Format, on page 219 and Figure 84, Programmable Protocol Format (Consecutive Transfers), on page 219.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Definition</th>
<th>Range</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>--</td>
<td>Serial clock mode (SSP_SSPSP[SCMODE])</td>
<td>(Drive, Sample, SSPx_CLK Idle) 0x0 = fall, rise, low 0x1 = rise, fall, low 0x2 = rise, fall, high 0x3 = fall, rise, high</td>
<td>--</td>
</tr>
<tr>
<td>--</td>
<td>Serial frame polarity (SSP_SSPSP[SFRMP])</td>
<td>High or low</td>
<td>--</td>
</tr>
<tr>
<td>T1</td>
<td>Start delay (SSP_SSPSP[STRTDLY])</td>
<td>0 to 7</td>
<td>clock period</td>
</tr>
<tr>
<td>T2</td>
<td>Dummy start (SSP_SSPSP[EDMYSTRT] + SSP_SSSP[DMYSTRT])</td>
<td>0 to 15</td>
<td>clock period</td>
</tr>
<tr>
<td>T3</td>
<td>Data size (SSP_SSCR0[EDSS] and SSP_SSCR0[DSS])</td>
<td>4 to 32</td>
<td>clock period</td>
</tr>
<tr>
<td>T4</td>
<td>Dummy stop (SSP_SSPSP[EDMYSTOP] + SSP_SSSP[DMYSTOP])</td>
<td>0 to 31</td>
<td>clock period</td>
</tr>
<tr>
<td>T5</td>
<td>SSPSFRM delay (SSP_SSPSP[SFRMDLY])</td>
<td>0 to 127</td>
<td>half-clock period</td>
</tr>
<tr>
<td>T6</td>
<td>SSPSFRM width (SSP_SSPSP[SFRMWDTH])</td>
<td>1 to 63</td>
<td>clock period</td>
</tr>
<tr>
<td>--</td>
<td>End of transfer data state (SSP_SSPSP[ETDS])</td>
<td>Low or Bit[0]</td>
<td>--</td>
</tr>
</tbody>
</table>
Figure 83: Programmable Serial Protocol Format

**Note:** If SSPx port is the master of SSPx_CLK (output) and SSPSP_x[ETDS=0], the End of Transfer data state (ETDS) for the SSPx_TXD line is 0. If the SSP is the master of the clock, and the SSPSP[ETDS] bit is set, then the SSPx_TXD line remains at the last bit transmitted (LSB).
If the SSPx port is a slave to SSPx_CLK (input), and modes 1 or 3 are used, then the ETDS can only change from the LSB if more SSPx_CLKs are sent to the SSPx port.

Figure 84: Programmable Protocol Format (Consecutive Transfers)
16.4.6.1 High Impedance on SSPx_TXD

The SSP supports placing the SSPx_TXD into high impedance during idle times instead of driving SSPx_TXD as controlled by the TXD Tri-State Enable (SSP_SSCR1[TTE]) and TXD Tri-State Enable On Last Phase (SSP_SSCR1[TTELP]) fields in the SSP Control Register 1. The SSP_SSCR1[TTE] enables a high-impedance state on SSPx_TXD. The SSP_SSCR1[TTELP] determines on which SSPx_CLK phase SSPx_TXD becomes high impedance.

See Figure 85, Figure 86, Figure 87, Figure 88, and Figure 89.

Figure 85: TI SSP with SSP_SSCR1[TTE] = 1 and SSP_SSCR1[TTELP] = 0

Figure 86: TI SSP with SSP_SSCR1[TTE] = 1 and SSP_SSCR1[TTELP] = 1

Figure 87: Motorola* SPI with <TXD Tri-State Enable> = 1 and <TXD Tri-State Enable On Last Phase> = 0
Figure 88: PSP Format with SSP_SSCR1[TTE] = 1, SSP_SSCR1[TTELP] = 0, and SSP_SSCR1[SFRMDIR] = 1

Figure 89: PSP Format with SSP_SSCR1[TTE] = 1, and either SSP_SSCR1[TTELP] = 1, or SSP_SSCR1[SFRMDIR] = 0
16.4.7 Network Mode

The SSP_SSCR0[MOD] bit selects between Normal and Network modes. Normal mode (MOD 0x0) is used when using the Texas Instruments* Synchronous Serial Protocol (SSP), and the Motorola* Serial Peripheral Interface (SPI). Network mode (MOD = 0x1) is used for emulating the I²S protocol. Software should set MOD only when using the PSP format. If the SSPx port is a master of the clock and SSP_SSCR1[SCLKDIR] is cleared, then setting MOD causes the SSPx_CLK to run continuously.

When in Network mode, only 1 SSPx_FRM is sent (master mode) or received (slave mode) for the number of time slots programmed into the SSP_SSCR0[FRDC] field. When beginning in Network mode, while the SSPx port is a master to the SSPx_FRM interface signal, the first SSPx_FRM signal does not occur until after data is in the TXFIFO. After assertion of the first SSPx_FRM signal, if the SSP is a master to SSPx_FRM, subsequent SSPx_FRM signals continue to assert regardless of whether data resides in the TXFIFO. Therefore, the transmit underrun bit, SSP_SSSR[TUR], is set to 0b1 if there is no data in the TXFIFO and the SSPx port is programmed to drive SSPx_TXD data in the current time slot, even if the SSPx port is master to SSPx_FRM. When using PSP format in Network mode, the parameters SFRMDLY, STRTDLY, DMYSTOP, DMYSTRT must all be 0b0. The other parameters SFRMP, SCMODE, FSRT, SFRMWDT are programmable.

When the SSPx port is a master to the SSPx_FRM signal and a need arises to exit from Network mode, software should:
1. Clear the SSP_SSCR0[MOD] bit. SSP_SSCR0[SSE] does not need to change.
2. Wait until SSP_SSTSS[NMBSY] is cleared.
3. Disable the SSPx port by clearing SSP_SSCR0[SSE].
4. Before exiting Network mode, verify the TXFIFO is empty (SSP_SSSR[TFL]=0b0000 and SSP_SSSR[TNF]=0b1).

If data remains in the TXFIFO after the Network mode is exited, a non-Network mode frame will be sent.

Due to synchronization delay between the internal bus and the SSPx port clock domain, 1 extra frame may be transmitted after software clears the SSP_SSCR0[MOD] bit. The SSPx port continues to drive SSPx_CLK (if SSP_SSCR1[SCLKDIR] is cleared) and SSPx_FRM (if SSP_SSCR1[SFRMDIR] is cleared) until the end of the last valid time slot.

If the SSPx port is a slave to both SSPx_CLK (SSP_SSCR1[SCLKDIR] set) and SSPx_FRM (SSP_SSCR1[SFRMDIR] set), the SSP_SSTSS[NMBSY] bit remains asserted until the SSP_SSCR0[MOD] bit is cleared or until 1 SSPx_CLK after the end of the last valid time slot.

Note: When operating in Slave mode (SSP_SSCR1[SCLKDIR] = SSP_SSCR1[SFRMDIR] = 1) the external codec must provide the correct number of bits as determined by the frame width (SSP_SSPSP[SFRMWDT]) and number of time slots (SSP_SSCR0[FRDC]). When the number of bits read in during a Frame cycle do not match the number expected, a Bit Count Error will occur (SSP_SSSR[BCE]) and the contents in the FIFO cannot be guaranteed. Software must be used to handle any error conditions when they occur.

Note: In the next example, a data format of 5 is used. However, a data format of 5 is not a supported data size for the SSP controller. A data size of 5 was used only to reduce the size of the diagram.

16.4.7.1 Network Mode Registers

The register bits and fields that must be programmed for the Network Mode are SSP_SSCR0[MOD], SSP_SSCR0[FRDC], SSP_SSPSP[FSRT], SSP_SSPSP[SFRMWDT], SSP_SSPSP[SCMODE], SSP_SSPSP[SFRMP], and SSP_SSPSP[SFRMDLY]. The definitions of each of these bits and fields is located in the registers document. See Figure 90.
A data format of 5 is not a supported data size for the SSP controller. A data size of 5 is used only to reduce the size of the diagram.

**Note:** This example has 5 bits of data per sample. The TxD3-state enable bit and the TxD3-state enable on last phase bit are both 0x1. The SSP is a master of SSPSCLK and SSPSFRM. The SSP has been programmed for 4 time slots (SSCR0.x[FRDC=0x11]), the Tx time Slot Active register is programmed to 0x0000_000A (SSTSA[TTS]=00001010), and the Rx Time Slot Active register has been set to 0x0000_0006 (SSRSA[RSTA]=00000110).

**Note:** A data format of 5 is not a supported data size for the SSP controller. A data size of 5 is used only to reduce the size of the diagram.

### Figure 90: Network Mode (Example Using 4 Time Slots)

<table>
<thead>
<tr>
<th>Time Slot 0</th>
<th>Time Slot 1</th>
<th>Time Slot 2</th>
<th>Time Slot 3</th>
<th>Time Slot 0</th>
<th>Time Slot 2</th>
<th>Time Slot 3</th>
<th>Time Slot 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSPSCLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SSPSFRM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SSPTXD</td>
<td>4/3/2/1/0</td>
<td>4/3/2/1/0</td>
<td>4/3/2/1/0</td>
<td>4/3/2/1/0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SSPRXD</td>
<td>Undefined</td>
<td>4/3/2/1/0</td>
<td>4/3/2/1/0</td>
<td>Undefined</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Note:**}

---

All information in this document is subject to legal disclaimers. © NXP B.V. 2020. All rights reserved.
16.4.8 I²S Emulation Using SSP

Network Mode (SSCR0[MOD] = 1) is used along with the Programmable Serial Protocol (PSP) format to emulate I²S mode.

Figure 91 shows a frame cycle where 4 time slots are being used and time slots 0 and 3 are being accessed.

The total number of time slots to use is defined by the SSCR0[FRDC] register. The slots that data is read into is defined by the RTSA field in the SSTRA register, and the slots that data is transmitted out on is defined by the TTSA field in the SSTSA register. The number of bits used for each time slot is defined by the Data Size Select bits (EDSS, DSS) in the SSCR0 register. When using master mode (SSCR1[SFRMDIR] = 0x0) the Serial Frame Width (SSPSP[SFRMWHT]) is used to determine the number of SSPx_CLK for the left and right channels.

Figure 91: Network Mode and PSP Frame Format
16.4.8.1 "Normal" Mode

The following bit fields must be configured for normal I²S mode (see Figure 92):

- SSP_SSCR0[EDSS] = 0b1 (32-bit data)
- SSP_SSCR0[DSS] = 0b1111 (32-bit data)
- SSP_SSCR0[FRF] = 0b11 (PSP format)
- SSP_SSCR0[FRDC] = 0b01 (Number of Time Slots+1)
- SSP_SSCR1[SCLKDIR] = 0b0 (SSP port is master of SSPx_CLK)
- SSP_SSCR1[SFRMDIR] = 0b0 (SSP port is master of SSPx_FRM)
- SSP_SSPSP[SFRMWDTH] = 0b100000 (Frame Width – 32 SSPx_CLK cycles)
- SSP_SSPSP[SFRMP] = 0b0 (Frame Polarity – Low)
- SSP_SSPSP[FSRT] = 0b1 (Frame Sync Timing – Delay audio data 1 SSPx_CLK cycle after SSPx_FRM transition)
- SSP_SSPSP[SCMODE] = 0x0 (Data driven on falling edge and sampled on rising)
- SSP_SSPSP[DMYSTOP] = 0b00 (Extended Dummy Stop)
- SSP_SSPSP[EDMYSTOP] = 0b000 (Extended Dummy Stop)
- SSP_SSTSA[TTSA] = 0x3 (Transmit Active Time Slots)
- SSP_SSRSA[RTSA] = 0x3 (Receive Active Time Slots)

Figure 92: Normal I²S Format
16.4.8.2 “MSb-justified” Mode

The following bit fields must be configured for MSb-Justified I2S mode (see Figure 93):

- SSP_SSCR0[EDSS] = 0b1 (32-bit data)
- SSP_SSCR0[DSS] = 0b1111 (32-bit data)
- SSP_SSCR0[FRF] = 0b11 (PSP format)
- SSP_SSCR0[FRDC] = 0b01 (Number of Time Slots+1)
- SSP_SSCR1[SCLKDIR] = 0b0 (SSP port is master of SSPx_CLK )
- SSP_SSCR1[SFRMDIR] = 0b0 (SSP port is master of SSPx_FRM)
- SSP_SSPPSP[SFRMWDT] = 0b100000 (Frame Width – 32 SSPx_CLK cycles)
- SSP_SSPPSP[SFRMP] = 0b0 (Frame Polarity – Low)
- SSP_SSPPSP[FSRT] = 0b0 (Frame Sync Timing – Audio data aligned with SSPx_FRM)
- SSP_SSPPSP[SCMODE] = 0x0 (Data driven on falling edge and sampled on rising)
- SSP_SSPPSP[EDMYSTOP] = 0b000 (Extended Dummy Stop)
- SSP_SSTSA[TTSA] = 0x3 (Transmit Active Time Slots)
- SSP_SSRSA[RTSA] = 0x3 (Receive Active Time Slots)

Figure 93: MSb-Justified I2S Format

16.5 Register Description

See Section 24.9.2, SSP Registers for a detailed description of the registers.
17 USB OTG Interface Controller (USBC)

17.1 Overview
The 88MW320/322 USB Interface includes a Universal Serial Bus (USB) On-the-Go (OTG) capable dual-role host/device controller that is compliant with the USB 2.0 specification.

17.2 Features
- Full USB OTG functionality with integrated transceiver, allowing support for an Enhanced Host Controller Interface (EHCI) host or a device
- Supports High-Speed/Full-Speed/Low-Speed USB 2.0 Host/Device/OTG modes
- Up to 16 configurable bi-directional endpoints for device mode
  - I/O Transfer types supported – Control, Interrupt, Bulk, or Isochronous
  - Endpoint 0 – Dedicated for control endpoint
- Control signals for external power supply and detection of voltages for OTG signaling
- Capability to respond as self- or bus-powered device and control to allow charging from bus
- 2 KB TxFIFOs for each endpoint, which can hold the largest USB 2.0 packet
- 2 KB shared Rx buffer for all incoming data

17.3 Interface Signal Description
Table 143 shows the interface signals.

**Note:** After Power-On Reset (POR), if USB is in host mode, USB_DP/USB_DM will be SE0. If USB is in device mode, USB_DP/USB_DM will be High-z.

### Table 143: USB OTG Controller Interface Signals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB_OTG_P (USB_DP)</td>
<td>I/O</td>
<td>USB D+</td>
</tr>
<tr>
<td>USB_OTG_N (USB_DM)</td>
<td>I/O</td>
<td>USB D-</td>
</tr>
<tr>
<td>USB_VBUS</td>
<td>I/O</td>
<td>VBUS Selection</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Input in device mode; unused in host mode. Output mode VDD 2.1V to 5.25V.</td>
</tr>
<tr>
<td>USB_DRV_VBUS (GPIO_27)</td>
<td>O</td>
<td>Drive 5V on VBUS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = do not drive VBUS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = drive 5V on VBUS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>The USB_DRV_VBUS port is connected to the SoC pad to drive an external</td>
</tr>
<tr>
<td></td>
<td></td>
<td>power management chip to provide power for USB_VBUS.</td>
</tr>
<tr>
<td>ID_PIN (USB_ID)</td>
<td>I</td>
<td>Pin Identification</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 = A-device</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 = B-device</td>
</tr>
</tbody>
</table>
Table 144 shows the Host Controller signals.

**Table 144: USB Host Controller Interface Signals**

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>USBH_P (USB_DP)</td>
<td>I/O</td>
<td>USB D+</td>
</tr>
<tr>
<td>USBH_N (USB_DM)</td>
<td>I/O</td>
<td>USB D-</td>
</tr>
</tbody>
</table>

### 17.4 Internal Bus Interface

The internal bus contains all the control and status registers that allow a processor to interface to the USB core. These registers allow a microprocessor to control the configuration of the core, ascertain the capabilities of the core, and control the core in operation for both host and device modes.

### 17.4.1 Block Diagram

*Figure 94 shows an overall block diagram.*

**Figure 94: USB Controller Block Diagram**
17.4.2 DMA Engine

The DMA Engine Block presents a bus initiator (master) interface to the internal bus. It is responsible for moving all of the data to be transferred over the USB between the USB core and buffers in the system memory.

The DMA controller must access both the control information and packet data from the system memory. The control information is contained in the link list-based queue structures. The DMA controller has state machines that can parse all of the data structures defined in this controller specification.

17.4.3 Dual Port RAM Controller

The Dual Port RAM controller, which is used for context information, builds configurable FIFOs between the Protocol Engine block and the DMA controller. These FIFOs decouple the system processor memory bus request from the extremely tight timing required by the USB itself. The use of the FIFO buffers differs between host and device mode operation. In Host mode, a single data channel is maintained in each direction through the dual-port memory. In Device mode, multiple FIFO channels are maintained for each of the active endpoints in the system.

17.4.4 Protocol Engine

The Protocol Engine parses all the USB tokens and generates the response packets. It is responsible for checking for errors, checking field generation, formatting all handshaking, ping, and data response packets on the bus, and for generating any signals based on a USB-based time frame. In Host mode, the Protocol Engine also generates all of the token packets that are required by the USB protocol. The Protocol Engine contains several sub-functions:

- The token state machines track all of the tokens on the bus and filter the traffic based on the address and endpoint information in the token. In Host mode, these state machines also generate the tokens required for data transfer and bus control.
- The CRC5 and CRC16 CRC generator/checker circuits check and generate the CRC check fields for the token and data packets.
- The data and handshake state machines generate any responses required on the USB and move the packet data through the dual-memory FIFOs to the DMA controller block.
- The Interval timers provide timing strobes that identify important bus timing events: bus timeout interval, microframe interval, start of frame interval, and bus reset, resume, and suspend intervals.
- Reports all transfer status to the DMA engine.

17.4.5 Port Controller

The Port controller block interfaces to the UTMI/UTMI+ compatible transceiver macrocell. The primary function of the Port controller block is to isolate the remainder of the USB core from the transceiver and to move all of the transceiver signaling into the primary clock domain of the USB core. This process allows the core to run synchronously with the system processor and its associated resources.
17.5 Functional Description

The USB OTG Controller is a fully-compliant USB peripheral device that can also assume the role of a USB host. The OTG state machines determine the role of the device based on the connector signals and then initializes the device in the appropriate mode of operation (host or peripheral) based upon its method of connection. After connecting, the devices can negotiate using the OTG protocols to assume the role of host or peripheral depending on the task to be accomplished. The attached peripherals share USB bandwidth through a host-scheduled, token-based protocol.

Figure 95 shows the endpoint queue head data structure.

Figure 95: End Point Queue Head Organization

17.5.1 Host Data Structure

The Host data structures are used to communicate control, status, and data between software and the Host Controller.

The Periodic Frame List is an array of pointers for the periodic schedule. A sliding window on the Periodic Frame List is used. The Asynchronous Transfer List is where all the control and bulk transfers are managed.

Figure 96 shows the structure.

Figure 96: Periodic Schedule Organization
17.6 USB Controller Operation

17.6.1 FIFO Operation in Device Mode

17.6.1.1 Streaming Mode

Device Mode, ISO IN—Streaming mode
- The controller starts fetching data after the software primes the endpoint, and fills the TX FIFO to the available space.
- When the respective IN arrives from the Host, the controller sends the data, fetching more data from system memory to TX FIFO as space becomes available.

Device Mode, ISO OUT—Streaming mode
- When ISO OUT arrives and data is sent from Host, the device controller begins storing it to RX buffer.
- The device controller starts sending data from RX FIFO to system memory as soon as a burst size of data is available.
- After all the ISO OUT data is received, and while the RX FIFO still has data inside waiting to be transferred to system memory, the device controller can receive other packets.
- If only 1 RX FIFO position is free, or full, the device "BTO" the OUT/DATA from Host.
- If there is more than 1 position free, the device accepts OUT/DATA from Host but if the FIFO is not read to system memory, an overflow occurs anyway, and the packet is NAKed.
Device Mode, Bulk IN—Streaming mode

- When the Host sends the IN, if the device has not primed the EP yet, it “NAKs” the IN.
- After EP is primed, DMA engine in the device controller starts fetching data to the TX buffer.
- When the protocol engine part of the controller is primed (after synchronization), the device controller responds to an IN with data.
- Device controller continues to fetch data as space is available in TX buffer (at least 1 burst worth of data of free space available).
- If during a packet the system bus is unable to buffer all the data for that packet on time, the packet is cut short due to underrun.
- During a transfer, the device controller “NAKs” an IN if the TX buffer is empty, or more specifically, if no data was loaded for the next packet.

Device Mode, Bulk OUT—Streaming Mode

- When the Bulk OUT arrives and data is sent from Host, the device controller begins storing it to the RX buffer.
- The device controller starts sending data from RX FIFO to system memory as soon as a burst worth of data is available.
- After all the Bulk OUT data is received and the RX FIFO still has data inside waiting to be transferred to system memory, the device controller can receive other packets.
- If only 1 RX FIFO position is free, or full, the device “BTOs” the OUT/DATA from Host.
- If there is more than 1 position free, the device accepts OUT/DATA from the Host; if the FIFO is not read to system memory, an overflow occurs anyway, and the packet NAKed.
- This behavior is the same as for ISO OUT.

17.6.1.2 Additional Notes on TX FIFO Buffering – IN Endpoints

Initial Priming

- When priming has started on DMA side, the controller loads the leading data into the TX buffer, and only then completes the priming operation (PE is primed). This pre-buffering is performed for the entire first packet, or until the TX FIFO is full.

Buffering after First Packet

- After the first packet, the second packet in a dTD is sent as long as at least 1 byte was loaded to the FIFO for the second packet.
- Once FIFO is loaded with the first packet, the entire dTD (all the packets in 1 dTD) is sent for every IN from Host, and the system bus must continue back-filling the TX FIFO to keep up with data being sent for the several packets.

BTO or NAK from Host to Data Packet

- If a packet is NAKed or BTOed by Host, device flushes TX buffer and removes the priming state.
- It then returns to repeat the buffer operation.
- If an IN arrives from the host in the meantime, it is NAKed.
- Once the packet is fully loaded inside the TX buffer again, or the TX buffer is full, the prime state in the PE is set to active.
- Only then does the device controller respond to the Host IN token with the data packet.
Underrun of Device TX FIFO

- If a TX FIFO underrun occurs, device clears the prime, flushes TX buffer, and then reloads all of failing packet to the TXFIFO.
- At the same time, the device “NAKs” an IN from the Host.
- Only when entire packet is in FIFO again or FIFO is full does the Device respond to the Host IN with a data packet.

Buffering Between dTDs

- When the Host sends an ACK to the last data packet of the first dTD, the device disables the primed state.
- This last data packet can either be maximum packet sized, a short packet, or a 0-length packet, depending on the transfer total length and the ZLT bit in the Queue head. Either is ACKed by the Host, and the priming is disabled after that.
- The device then retires the dTD back to system memory and loads the new dTD.
- In the meantime, any IN packet from the Host is NAKed.
- After loading the new dTD, the device starts buffering the first packet into the TX buffer.
- Once the packet is fully loaded inside the TX buffer again, or the TX buffer is full, the prime state in the PE is set to active.
- Only then does the device controller responds to the Host IN token with the data packet.
- This behavior is similar to the initial priming of the first dTD.

17.6.1.3 Non-Streaming Mode

Device Mode, ISO IN—Non-Streaming Mode

- Same as Streaming mode

Device Mode, ISO OUT—Non-Streaming Mode

- Same as Streaming mode

Device Mode, Bulk IN—Non-Streaming Mode

- When the Host sends the IN, if the device has not yet primed the EP; it “NAKs” the IN.
- After EP is primed, the DMA engine in device controller starts fetching data to the TX buffer.
- The device controller continues fetching data as space is available in the TX buffer.
- The device controller responds only to the first IN with data when the entire packet is fetched to the TX FIFO or the TX FIFO is full. In the meantime, it responds to the IN with NAK.
- The following packets are sent only if next packet is fully in FIFO, or if the FIFO is full again.

Device Mode, Bulk OUT—Non-Streaming Mode

- When Bulk OUT arrives and data is sent from Host, the device controller begins storing it to the RX buffer.
- The device controller starts sending data from RX FIFO to system memory as soon as a burst size of data is available.
- The device controller responds with NYET to this first packet of a transfer, so the Host sends PINGs after that.
- The device controller sends NAKs to the PINGs as long as data is still in the RX FIFO (RX FIFO not yet empty).
- Only when the RX FIFO is empty again does the device controller ACK the PING, and the Host sends the next IN.
17.6.1.4 FIFO Operation in Host Mode

Host Mode, ISO IN/OUT—Streaming Mode

- Taking the example of using Streaming mode: It is a 760-byte transfer, using a max packet size of 370 bytes, MULT=3.

For OUT Direction

- Assuming a watermark value of 512 bytes (larger than the 370-byte packet), the controller uses the packet size as watermark.
- Behavior is the same as in Non-Streaming mode.
- Host controller starts fetching the data to TX FIFO after the SOF is sent.
- In Host ISO OUT, the TXFIFOTHRES watermark applies to every packet in a transfer.
- Assuming a packet size if 1024 bytes, TX FIFO with a size of 1024 bytes, and a TX watermark of 512 bytes as well: The DMA writes the Packet Start TAG to the TX FIFO, and then proceeds to fill with data. As the Start TAG is read just after it is written, 512 bytes are again available on the FIFO. The DMA then fills the TX FIFO to the 512 bytes watermark.
- Only then does the controller send the OUT token and start the packet. As the controller reads the first bytes from the TX FIFO, it makes space available for the missing End Packet TAG, which then fits without any problems.
- If the packet size is 1024 for a transfer size of 3072, MULT=3, and using a TX watermark of 512 bytes, the behavior is the same as in the previous example, except that when the first packet starts being sent, the controller backfills the TX FIFO with the remaining data for the packet, as soon as 1 burst of data space is available. The behavior is the same for each of the MULT=3 packets.
- Using an ISO packet size larger than the TX FIFO size is not a problem, as long as the system bus has enough bandwidth to backfill the TX buffer after the packet started being sent.
- For a packet size = 1024 bytes, TX watermark set to 512 and TX FIFO size is 1024, the controller fills the TX FIFO to 512 bytes before sending the OUT token, and then continues backfilling the FIFO.

For IN Direction

- Behavior is the same as in Non-Streaming mode in the sense that the Host Controller is working with 1 packet at a time.
- Controller starts sending data from RX FIFO to system memory as soon as 1 burst of data is available.
- Controller always waits for all the packet data to be stored in system memory, and only then proceeds to the next packet; that is, it sends only the IN token for the next packet when the RX FIFO is empty.
- If the packet size is 1024 for a transfer size of 3072, MULT=3, the behavior is the same, each packet is taken care of as described above.

Host Mode, ISO IN/OUT—Non-Streaming Mode

The available slot for HS ISO within a micro-frame is up to 80%, which means that the buffering could extend until that time is exhausted with the resulting side effect of wasted bandwidth. It does work, but can become a low efficiency method.

Using Non-Streaming mode, 760 byte transfer, using a maximum packet size of 370 bytes, MULT=3.
For OUT Direction

- After the SOF is sent, the host controller begins fetching the data from memory to the TX FIFO.
- Only after the first 370 bytes are fetched (a full packet), it sends the first OUT token to the line.
- During the first OUT/DATA, the controller continues fetching data for the remaining packets (370+20 bytes).
- Controller continues fetching data (within the limit of the buffer size) until all data is fetched and all packets are sent;
- Non-Streaming mode is the same behavior as Streaming mode with the TX Fill level set to the same size as the TX FIFO.
- If the packet size is 1024 for a transfer size of 3072, MULT=3, the behavior is the same as in the previous example, except that when the first packet starts being sent, the controller backfills the TX FIFO with the remaining data for the packet, as soon as 1 burst of data space is available. The behavior is the same for each of the MULT=3 packets.
- For packet size = 1024 bytes, TX watermark set to 512 and TX FIFO size is 2048, the controller fills the TX FIFO to 1024 bytes before sending the OUT token.

For IN Direction

- After the SOF is sent, the Host Controller starts fetching the iTD from system memory. As soon as the iTD has been read, it issues the IN token if the RX buffer is empty.
- While data is being received from the device and being stored to the RX buffer, the controller writes data to system memory as soon as 1 burst worth of data is available.
- Only after all data has been stored from the RX buffer to system memory does the Host Controller issue the second IN, and the same for the third IN.
- When sending the IN, if the RX buffer is not empty at the calculated time, the host delays issuing IN token until the buffer is empty of packet data.
- If the packet size is 1024 for a transfer size of 3072, MULT=3, the behavior is the same, each packet is taken care of as described above.

Host Mode, Bulk OUT—Streaming Mode

For every packet in a transfer, the Host Controller pre-fetches the data until the TX FIFO is filled up to the level specified by the TXFIFOTHRES Register. Only then is the OUT token sent while the controller continues fetching more data to the TX FIFO. This is the same TXFIFOTHRES behavior as in ISO OUT.

TXFIFOTHRES is set in number of bursts; that is, if TXFIFOTHRES=2, the actual watermark level is, for example, 2xINCR8, or 2x(INCR of VUSB_HS_TX_BURST length)
- If the TX FIFO is full, the Host Controller re-fetches data for the next packet as soon as there is 1 burst worth of free space available on the TX FIFO, regardless of the current packet being sent. So as soon as the first bytes are transmitted for the current packet, the Host Controller starts fetching for the next. This method is valid in Streaming and Non-Streaming modes.

Host Mode, Bulk IN—Streaming Mode

Host issues IN token when the RX FIFO is empty which is valid for all packets in a transfer (qTD).
- The Host Controller starts sending data from RX FIFO to system memory as soon as there is 1 burst worth of data available on the RX FIFO (example: 1x INCR8, or 1x(INCR of VUSB_HS_TX_BURST length)), regardless of the current packet being received. This is valid in Streaming and Non-Streaming modes.
Host Mode, Bulk OUT—Non-Streaming Mode
Host issues OUT token when entire data packet is in the TX FIFO, or the FIFO is full.

- The Host Controller starts fetching data for the next packet as soon as there is 1 burst worth of free space available on the TX FIFO, regardless of the current packet being sent. So as soon as the first bytes are transmitted for the current packet, the Host Controller starts fetching for the next. This is valid in Streaming and Non-Streaming modes.

Host Mode, Bulk IN—Non-Streaming Mode
Host issues IN token when the RX FIFO is empty.

The Host Controller starts sending data to system memory as soon as there is 1 burst worth of data available on the RX FIFO, regardless of the current packet being received. This is valid in Streaming and Non-Streaming modes.

17.6.2 Clock Control and Enables
The USB OTG and Host Controllers have separate clock enables for their system and USB clocks.

The USB Clock/Reset Control Register (APULL_CTRL0) is used to enable the AXI interface to the USB OTG and Host controllers.

17.6.3 Programming Guidelines
Both USB controllers receive their clocks from their respective USB UTMI physical layer interfaces.

To use the USB EHCI host controller or the USB EHCI OTG controller their physical layer interfaces must be initialized prior to any USB controller operation such as register write access.

17.7 Register Description
See Section 24.3, USBC Address Block for a detailed description of the registers.
18 Quad Serial Peripheral Interface (QSPI) Controller

18.1 Overview

The 88MW320/322 includes a QSPI Controller. The QSPI Controller is muxed with the Flash Controller to connect to an external serial Flash device.

The QSPI Controller is a synchronous serial peripheral that can be connected to a variety of slave devices that communicate using SPI protocol for data transfer. The QSPI Controller always operates as a master and supports standard single bit, and high performance dual/quad output SPI as well as dual/quad I/O SPI. The QSPI Controller has an extremely flexible architecture where the command type, instruction encode, amount of data to be transferred and other parameters are all configurable through memory mapped registers.

18.2 Features

- Supports Standard SPI protocol with single bit Data In and Data Out
- Supports dual/quad output operations
- Supports dual/quad I/O operations
- Supports DMA and non-DMA modes for data transfer
- Separate FIFO for transmit and receive with the length of 8*32 bit
- Support for interrupts for a variety of events and conditions related to FIFOs
- 200 Mbps maximum serial data rate in quad mode with 50 MHz functional clock

18.3 Interface Signal Description

Table 145 shows the interface signals.

Table 145: QSPI Interface Signals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Width/Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_29/QSPI_CLK</td>
<td>O</td>
<td>1</td>
<td>QSPI bit clock</td>
</tr>
<tr>
<td>GPIO_28/QSPI_SSn</td>
<td>O</td>
<td>1</td>
<td>QSPI chip select, active low</td>
</tr>
<tr>
<td>GPIO_30/QSPI_D0</td>
<td>I/O</td>
<td>1</td>
<td>Data I/O 0</td>
</tr>
<tr>
<td>GPIO_31/QSPI_D1</td>
<td>I/O</td>
<td>1</td>
<td>Data I/O 1</td>
</tr>
<tr>
<td>GPIO_32/QSPI_D2</td>
<td>I/O</td>
<td>1</td>
<td>Data I/O 2</td>
</tr>
<tr>
<td>GPIO_33/QSPI_D3</td>
<td>I/O</td>
<td>1</td>
<td>Data I/O 3</td>
</tr>
</tbody>
</table>

1. See Section 22.11.2, QSPI Timing and Specifications, on page 295 for electrical specifications.

Note: GPIO pins are multiplexed with QSPI pins. Therefore, software must configure the appropriate PINMUX registers to use them as QSPI pins. See Section 6.2.1, PINMUX Alternate Functions and Section 24.17, PINMUX Address Block.
18.4 Function**al Description**

Serial data is transferred between the 88MW320/322 processor and serial peripheral through the FIFOs in the QSPI Controller. QSPI always operates as a master providing the Serial bit clock and Chip-Select or Frame-Sync. The Controller supports both the DMA and non-DMA modes of transferring data.

18.4.1 Block Diagram

Figure 97 shows an overall diagram.

**Figure 97: QSPI Controller Block Diagram**

18.4.2 Basic Operation

QSPI always operates as a master and can be configured to generate read or write transactions to the attached slave device. There are 2 varieties of frames that can be generated by the QSPI (Read frame and Write frame). A Read frame basically consists of instruction encode, address of the location to read from and data itself. A Write frame consists of a similar structure and consists of again instruction, address followed by outputting data.

Some attached slaves that need a few extra cycles for data setup for high performance operation can be supported by configuring the QSPI to generate “dummy clocks.”

For Write transactions, the required fields are:
- Instr.INSTR – determines the instruction encode or the command
- HdrCnt.INSTR_CNT – determines the number of clocks or bytes required for instruction encode
- HdrCnt.ADDR_CNT – determines number of bytes or clocks of address
- Addr.ADDR – determines the address inside the slave
- HdrCnt.DUMMY_CNT – determines the number of extra or dummy clocks required by a slave

For Read transaction, the required fields are:
- Instr.INSTR – determines the instruction encode or the command
- HdrCnt.INSTR_CNT – determines the number of clocks or bytes required for instruction encode
- HdrCnt.ADDR_CNT – determines number of bytes or clocks of address.
- Addr.ADDR – determines the address inside the slave
- HdrCnt.DUMMY_CNT – determines the number of extra or dummy clocks required by a slave
- DInCnt.DATA_IN_CNT – number of bytes of data to be transferred
QSPI Single, Dual or Quad mode operation is configurable by programming the Conf.DATA_PIN and Conf.ADDR_PIN fields.

Different values on Conf.DATA_PIN signify:
- 00 = use 1 serial interface pin (use in single mode)
- 01 = use 2 serial interface pins (use in dual mode)
- 10 = use 4 serial interface pins (use in quad mode)

Different values on Conf.ADDR_PIN signify:
- 0 = use 1 serial interface pin
- 1 = use the number of pins as indicated in Conf.DATA_PIN

### 18.4.3 Serial Flash Data Format

#### Figure 98: Frame of Data Format for Serial Flash Access

<table>
<thead>
<tr>
<th>Write frame</th>
<th>Instr[15:0]</th>
<th>Addr[31:0]</th>
<th>Dummy bytes</th>
<th>Dout</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read frame</td>
<td>Instr[15:0]</td>
<td>Addr[31:0]</td>
<td>RdMode[15:0]</td>
<td>Dummy bytes</td>
</tr>
</tbody>
</table>

- **Instr** – Serial Interface Instruction
  - After Conf.XFER_START is set to 1, the content of the Instr register is shifted out to the serial interface. HdrCnt.INSTR_CNT determines how the content is shifted out.
    - When HdrCnt.INSTR_CNT = 0, the content of this register is not shifted out to the serial interface
    - When HdrCnt.INSTR_CNT = 1, bits [7:0] are shifted out
    - When HdrCnt.INSTR_CNT = 2, bits [15:8] are shifted out first, followed by bits [7:0]

- **Addr** – Serial Interface Address
  - After the contents of the Instr register is shifted out, the content of the Addr register is shifted out to the serial interface. HdrCnt.ADDR_CNT determines how the content of the Addr register is shifted out on the serial interface.
    - When HdrCnt.ADDR_CNT = 0, the content of this register is not shifted out to the serial interface
    - When HdrCnt.ADDR_CNT = 1, bits [7:0] are shifted out
    - When HdrCnt.ADDR_CNT = 2, bits [15:8] are shifted out first, followed by bits [7:0]
    - When HdrCnt.ADDR_CNT = 3, bits [23:16] are shifted out first, followed by bits [15:8], then bits [7:0]
    - When HdrCnt.ADDR_CNT = 4, bits [31:24] are shifted out first, followed by bits [23:16], then bits [15:8] and finally bits [7:0]

- **RdMode** – Serial Interface Read Mode
  - After the contents of the Addr register is shifted out, the content of the RdMode register is shifted out to the serial interface. HdrCnt.RM_CNT determines how the contents of the RdMode register are shifted out.
    - When HdrCnt.RM_CNT = 0, the content of this register is not shifted out to the serial interface
    - When HdrCnt.RM_CNT = 1, bits [7:0] are shifted out
    - When HdrCnt.RM_CNT = 2, bits [15:8] are shifted out first, followed by bits [7:0]
• Dummy_byte bytes to shift out to the serial interface after the contents of RdMode register is shifted out. The number of dummy bytes shifted out is determined by HdrCnt.DUMMY_CNT. Different values on HdrCnt.DUMMY_CNT signify
  • 00: 0 byte
  • 01: 1 byte
  • 10: 2 bytes
  • 11: 3 bytes

**DOut – Serial Interface Data Out**

Data written to the DOut register is stored in the 8X32 bit Write FIFO. After the contents of the Instruction register (Instr), the Address register (Addr), the Read Mode register (RdMode) and Dummy value are transferred out to the serial interface, the data in the Write FIFO is shifted out. The serial interface clock stops when a Write FIFO empty condition occurs, i.e. Cntl.WFIFO_EMPTY = 1. The clock restarts when Write FIFO is not empty, i.e Cntl.WFIFO_EMPTY = 0. Conf.BYTE_LEN determines the number of bytes shifted out on the serial interface.

  • When Conf.BYTE_LEN = 0, only the first byte, for example, bits[7:0] of the Write FIFO is shifted out with bit 7 shifted out first and bit 0 shifted out last.
  • When Conf.BYTE_LEN = 1, all 4 bytes from each the Write FIFO are shifted out with bits [7:0] are shifted out (bit 7 shifted out first and bit 0 shifted out last), followed by bits [15:8] (bit 15 shifted out first and bit 8 shifted out last), then bits [23:16] (bit 23 shifted out first and bit 16 shifted out last) and finally bits [31:24] (bit 31 shifted out first and bit 24 shifted out last).

**Note:** To avoid a Write FIFO overflow condition (Cntl.WFIFO_OVRFLW = 1), check if Cntl.WFIFO_FULL = 0 before writing to the DOut register.

**DIn – Serial Interface Data In**

For read transfers, Conf.RW_EN = 0, data from the serial interface input pins are shifted in and stored in a 8X32 bit Read FIFO. The contents of the Read FIFO are read from this register. The serial interface clock stops when a Read FIFO full condition occurs, i.e Cntl.RFIFO_FULL = 1. The clock restarts when Read FIFO is not full, that is, Cntl.RFIFO_FULL = 0.

  • When Conf.BYTE_LEN = 0, data is shifted into bits [7:0] of the Read FIFO
  • When Conf.BYTE_LEN = 1, data is shifted into bits [7:0] first, followed by bits [15:8], then bits [23:16] and finally bits [31:24]

**Note:** To avoid a Read FIFO underflow condition, Conf.RFIFO_UNDRFLW = 1, check if Conf.RFIFO_EMPTY = 0 before reading the DIn register.

DMA transfer is supported in QSPI functions. The specific bits in register QSPI.CONF2 must be set for the DMA transfer.

*Figure 99 to Figure 102* show the data flow for Read and Write transactions using non-DMA and DMA operation of the QSPI Controller.
Figure 99: Non-DMA Mode Read Flow

Begin

Program FIFO_FLUSH (R04h[9]) = 1 to flush Write and Read FIFOs

FIFO_FLUSH (R04h[8]) == 0?

Y

Program SS_EN (R00h[0]) = 1 to assert SS_N
Program Header Count (R1Ch) register
Program Instruction (R10h) register
Program Address (R14h) register
Program Read Mode (R18h) register
Program Data In Count (R20h) register
Program Config (R04h) register with RW_EN (R04h[13]) = 0 and XFER_START (R04h[15]) = 1

N

Terminate before all data are transferred?

N

XFER_START (R04h[15]) == 0?

Y

Program XFER_STOP (R04h[14]) = 1 to stop the transfer

N

Read FIFO empty (R00h[4] == 1)?

Y

Read data from DATA_IN (R0Ch) register

N

XFER_START (R04h[15]) == 0?

Y

Read FIFO empty (R00h[4] == 1)?

N

Read data from DATA_IN (R0Ch) register

Y

Program SS_EN (R00h[0]) = 0 to de-assert SS_N

End
Figure 100: Non-DMA Mode Write Flow

Begin

Program FIFO_FLUSH (R04h[9]) = 1 to flush Write and Read FIFOs

FIFO_FLUSH (R04h[9]) == 0?

Y

Program SS_EN (R00h[0]) = 1 to assert SS_N
Program Header Count (R1Ch) register
Program Instruction (R10h) register
Program Address (R14h) register
Program Config (R04h) register with RW_EN (R04h[13]) = 1 and XFER_START (R04h[15]) = 1

N

Transfer data from Write FIFO?

XFER_RDY (R00h[1]) == 1?

N

Y

Terminate before all data are transferred?

Y

N

All data written on DATA_OUT (R08h)?

Y

Write FIFO empty (R00h[6] == 1)?

N

Y

Program XFER_STOP (R04h[14]) = 1 to stop the transfer

Y

N

Write FIFO full (R00h[7] == 1)?

N

Write data to DATA_OUT (R08h) register

End

Program SS_EN (R00h[0]) = 0 to de-assert SS_N
Figure 101: DMA Mode Read Flow

Begin

Program FIFO_FLUSH (R04h[9]) = 1 to flush Write and Read FIFOs

FIFO_FLUSH (R04h[9]) == 0?

Program DMA Controller registers

Program SS_EN (R00h[0]) = 1 to assert SS_N
Program Header Count (R1Ch) register
Program Instruction (R10h) register
Program Address (R14h) register
Program Read Mode (R18h) register
Program Data In Count (R20h) = 0 to continuously read data
Program DMA_RD_BURST (R28h[9:8]) and DMA_RD_EN (R28h[1]) = 1 to enable DMA read
Program XFER DONE_IC (R38h[0]) = 1 to clear XFER_DONE_IR (R34h[0])
Program Config (R04h) register with RW_EN (R04h[13]) = 0 for read transfer and XFER_START (R04h[15]) = 1

DMA Controller transfer completed?

XFER_DONE_IR (R34h[0]) == 1?

Program SS_EN (R00h[0]) = 0 to de-assert SS_N

End
Figure 102: DMA Mode Write Flow

Begin

Program FIFO_FLUSH (R04h[9]) = 1 to flush Write and Read FIFOs

FIFO_FLUSH (R04h[9]) == 0?

N

Y

Program DMA Controller registers

Program SS_EN (R00h[0]) = 1 to assert SS_N
Program Header Count (R1Ch) register
Program Instruction (R10h) register
Program Address (R14h) register
Program DMA_WR_BURST (R26h[13:12]) and DMA_WR_EN (R28[2]) = 1 to enable DMA write
Program XFER_DONE_IC (R38h[0]) = 1 to clear XFER_DONE_IR (R34h[0])
Program Config (R04h) register with RW_EN (R04h[13]) = 1 for write transfer and XFER_START (R04h[15]) = 1

DMA Controller transfer completed?

N

Y

XFER_DONE_IR (R34h[0]) == 1?

N

Y

Program SS_EN (R00h[0]) = 0 to de-assert SS_N

End
18.5 Register Description

See Section 24.8.2, QSPI Registers for a detailed description of the registers.
19 Analog Digital Converter (ADC)

19.1 Overview
The 88MW320/322 ADC is a 2-step converter with up to 16-bit resolution. The ADC includes an Analog Multiplexer (AMUX) and a Programmable Gain Amplifier (PGA) with as many as 8 individually configurable channels and a reference voltage regulator. The conversion results can be written to memory through the DMA. Several modes of operation are available.

19.2 Features
- Selectable throughput rates and resolution (12 to 16 bits)
- Throughput rate as fast as 2 MHz
- Single-ended and differential conversions from 8 external and 6 internal sources
- ADC gain setting support: 0.5x, 1x, 2x
- Additional PGA setting support: 4x, 8x, 16x, 32x
- Selectable reference voltage (Vref)
  - Internal reference 1.2V (Vref_12)
  - Vref_18
  - External reference (do not exceed 1.8V)
- Input voltage ranges (differential)
  - -Vref/PGA to + Vref/PGA
  - Do not exceed VDDIO_3 voltage level
  - Do not exceed VDD_IOx_y voltage level
- Offset and gain auto calibration
- Embedded temperature sensor with internal or external diode options
- DAC dual inputs
- Sequences with scan length up to 16
- Sequential conversion composed of any channel in any order
- 1-shot or continuous mode
- Scan average of 1, 2, 4, 8, 16
- Interrupt generation and/or DMA request
- Internal GPT trigger on ADC conversion
- Battery measurement capability
Interface Signal Description

The external interface of the ADC module is mainly given by the power and analog pads. The ADC clock is 64 MHz or 67.07 MHz and is provided by the AUPLL.

The analog unit uses an ADC clock divided-down clock (divided by 1 to 32). Access to the configuration and data registers of the ADC is provided through an APB. The digital unit internal to the ADC runs with the APB bus clock.

See Table 36, VCO Frequency Select, on page 64/Table 37, AUPLL Post Divider Programming, on page 65 for FVCO and clock divider settings.

- For normal ADC mode/temperature sensor mode, set FVCO to 128 MHz and the post divider value to 2 for 64 MHz operation.
- For voice applications, set FVCO to 134.14 MHz and the post divider value to 2 for 67.07 MHz operation.

Table 146 shows the interface signals.

Table 146: ADC Interface Signals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Source/Destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC0_CH[7:0]</td>
<td>A, I</td>
<td>GPIO to ADC</td>
<td>External Analog Inputs from GPIO ADC0_CH[7]: GPIO_49 ADC0_CH[6]: GPIO_48 ADC0_CH[5]: GPIO_47 ADC0_CH[4]: GPIO_46 ADC0_CH[3]: GPIO_45/External voltage reference (EXT_VREF) ADC0_CH[2]: GPIO_44/DACA ADC0_CH[1]: GPIO_43/External diode negative (TS_INN)/DACB/VOICE_N ADC0_CH[0]: GPIO_42/External diode positive (TS_INP)/VOICE_P</td>
</tr>
</tbody>
</table>

1. See Section 22.8, ADC Specifications, on page 284 for electrical specifications.
19.4 Functional Description

19.4.1 Block Diagram

Figure 103 shows the block diagram.

Figure 103: ADC Block Diagram

19.4.2 ADC On-Off Control and Conversion Trigger

The ADC can be directly reset by system reset or the ADC_REG_CMD.SOFT_RST bit.

The ADC is powered up by setting the ADC_REG_GENERAL.GLOBAL_EN bit to 1'b1, and it is fully powered down when this bit is set to 1'b0.

After the ADC is powered up, the data conversion can be activated by writing a 1'b1 to the ADC_REG_CMD.CONV_START bit if the ADC is in software control mode (ADC_REG_CONFIG.TRIGGER_EN = 1'b0).

The actual conversion starts after the ADC wakes up (T_WARM) from power-down mode where T_WARM is 32 us by default. The conversions can be stopped by writing a 1'b0 to the ADC_REG_CMD.CONV_START bit.

The ADC_REG_STATUS.ACT bit is set to high when the ADC is actively converting.
19.4.3 ADC Input

The ADC module can support as many as 8 external inputs. The actual input channels depend on the package types. Refer to the PINMUX function for details.

There are 8 external inputs that can be selected as 8 different single-ended inputs or 4 differential inputs. In addition, it is possible to select 6 single-ended internal inputs. The available selections are given in the ADC_REG_ANA.SINGLEDIFF and scan sequence registers ADC_REG_SCN1/2. Table 147 shows the various ADC input configurations.

Table 147: ADC Input Configurations
NOTE: AMUX_SEL refers to ADC_REG_SCN1/2.SCAN_CHAN_X.

<table>
<thead>
<tr>
<th>SINGLEDIFF/AMUX_SEL[3:0]</th>
<th>ADC Positive Input</th>
<th>ADC Negative Input</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0/0000</td>
<td>ADC_CH[0]</td>
<td>VSSA</td>
<td>External single-ended or Temperature sensor (external diode)</td>
</tr>
<tr>
<td>0/0001</td>
<td>ADC_CH[1]</td>
<td>VSSA</td>
<td>External single-ended</td>
</tr>
<tr>
<td>0/0010</td>
<td>ADC_CH[2]</td>
<td>VSSA</td>
<td>External single-ended</td>
</tr>
<tr>
<td>0/0011</td>
<td>ADC_CH[3]</td>
<td>VSSA</td>
<td>External single-ended</td>
</tr>
<tr>
<td>0/0100</td>
<td>ADC_CH[4]</td>
<td>VSSA</td>
<td>External single-ended</td>
</tr>
<tr>
<td>0/0101</td>
<td>ADC_CH[5]</td>
<td>VSSA</td>
<td>External single-ended</td>
</tr>
<tr>
<td>0/0110</td>
<td>ADC_CH[6]</td>
<td>VSSA</td>
<td>External single-ended</td>
</tr>
<tr>
<td>0/0111</td>
<td>ADC_CH[7]</td>
<td>VSSA</td>
<td>External single-ended</td>
</tr>
<tr>
<td>0/1000</td>
<td>VBAT_S</td>
<td>VSSA</td>
<td>Internal single-ended (nominal 1/3 VBAT)</td>
</tr>
<tr>
<td>0/1001</td>
<td>Vref_12</td>
<td>VSSA</td>
<td>Internal single-ended (internal reference 1.2V)</td>
</tr>
<tr>
<td>0/1010</td>
<td>DACA</td>
<td>VSSA</td>
<td>Internal single-ended (DACA internal output)</td>
</tr>
<tr>
<td>0/1011</td>
<td>DACB</td>
<td>VSSA</td>
<td>Internal single-ended (DACB internal output)</td>
</tr>
<tr>
<td>0/1100</td>
<td>VSSA</td>
<td>VSSA</td>
<td>Internal single-ended (internal analog ground)</td>
</tr>
<tr>
<td>0/1101-0/1110</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0/1111</td>
<td>TEMP_P</td>
<td>VSSA</td>
<td>Temperature Sensor (internal diode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Internal Temperature Sensor</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• ADC_REG_ANA.TSEXT_SEL=0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• External Temperature Sensor</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• ADC_REG_ANA.TSEXT_SEL=1</td>
</tr>
<tr>
<td>1/0000</td>
<td>ADC_CH[0]</td>
<td>ADC_CH[1]</td>
<td>External differential or Temperature sensor (external diode)</td>
</tr>
<tr>
<td>1/0100</td>
<td>DACA</td>
<td>DACB</td>
<td>Internal differential</td>
</tr>
</tbody>
</table>
19.4.4 Input Range

When configured to single-ended input, the voltage sampled is the difference between the input channel and VSSA:

$$\Delta V \text{ (differential voltage)} = \text{VIN\_CH (input channel)} - \text{VSSA}$$

When configured to differential input, the voltage sampled is the difference between the odd and even channels:

$$\Delta V \text{ (differential voltage)} = \text{VIN\_EVEN (even channel)} - \text{VIN\_ODD (odd channel)}$$

The input voltage for each external channel must be positive and cannot exceed the VDDIO_3 voltage level and VDD_IOx_y voltage level. For 16-bit and 16-bit audio settings, the input signal should be limited to within 99.7% of the ADC voltage conversion range to avoid overflow in offset/gain calibration.

Table 148 shows the detailed input range.

<table>
<thead>
<tr>
<th>Single-ended or Differential Input (ADC_REG_ANA.SINGLE_DIFF bit)</th>
<th>ADC Gain Setting (ADC_REG_ANA.INBUF_GAIN[1:0] bits)</th>
<th>Input Range (ΔV)</th>
</tr>
</thead>
<tbody>
<tr>
<td>single-ended</td>
<td>0.5</td>
<td>0 to 2*Vref</td>
</tr>
<tr>
<td>single-ended</td>
<td>1</td>
<td>0 to Vref</td>
</tr>
<tr>
<td>single-ended</td>
<td>2</td>
<td>0 to 0.5*Vref</td>
</tr>
<tr>
<td>differential</td>
<td>0.5</td>
<td>-2<em>Vref to 2</em>Vref</td>
</tr>
<tr>
<td>differential</td>
<td>1</td>
<td>-Vref to Vref</td>
</tr>
<tr>
<td>differential</td>
<td>2</td>
<td>-0.5<em>Vref to 0.5</em>Vref</td>
</tr>
</tbody>
</table>
19.4.5 Temperature Measurement

The on-chip temperature sensor is used either to provide an absolute measurement of the device temperature or to detect changes in the ambient temperature (see Figure 104). The emitter and the collector/base of a PNP can be selected as 2 differential inputs of the ADC for temperature measurement. To do so, set the ADC_REG_ANA.TS_EN bit to 1'b1 and ADC_REG_SCN channels to 4'b1111.

Users have the option to measure the off-chip temperature by connecting an external diode (for example, 2N3906) onto GPIO input pins (ADC_CH[0] – ADC_CH[1]) with ADC_REG_ANA.TSEXT_SEL = 1'b1, or to monitor the on-chip temperature by using an embedded PNP with ADC_REG_ANA.TSEXT_SEL = 1'b0.

By selecting internal voltage reference 1.2V (Vref_12), 16-bit audio ADC accuracy and by measuring the internal temperature sensor, the temperature is calculated according to the following formula:

\[ T_{\text{meas}} \text{ (in } \degree C) = \frac{\text{ADC_REG_RESULT.DAT}[15:0]}{\text{TS_GAIN}} - \text{TS_OFFSET} \]

where:
- \( \text{ADC_REG_RESULT.DAT} \) is denoted as signed 16 bits
- \( \text{TS_OFFSET} \) and \( \text{TS_GAIN} \) are by default equal to:
  - For internal sensor: \( \text{TS_OFFSET} = 305; \text{TS_GAIN} = 6.295 \)
  - For external sensor: \( \text{TS_OFFSET} = 282; \text{TS_GAIN} = 6.39 \)
19.4.6 **ADC Reference Voltage**

ADC_REG_ANA.VREF_SEL is used to select the reference voltage. Change the reference voltage only when no conversion is running.

The positive reference voltage for analog-to-digital conversions is selectable as either the internal reference 1.2V (Vref_12), Vref_18, or external reference applied to the GPIO pin (GPIO_45). The external reference should not exceed 1.8V.

19.4.7 **ADC Throughput and Resolution**

When the ADC clock is 64 MHz, through programming ADC_REG_GENERAL.CLK_DIV_RATIO[5:0] and ADC_REG_ANA.RES_SEL[1:0], the ADC throughput and resolution is listed in ADC Conversion Time and Throughput Rate Lookup Table. **Table 149** shows the Lookup table.

**Table 149: ADC Conversion Time and Throughput Rate Lookup Table**

<table>
<thead>
<tr>
<th>CLK_DIV_RATIO[5:0]</th>
<th>RES_SEL[1:0]</th>
<th>64 MHz Main Clock</th>
<th>Significant Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>1-Shot Latency (µs)</td>
<td>Throughput Rate (ksps)</td>
</tr>
<tr>
<td>N (divide-by-N, N=1 to 32)</td>
<td>00</td>
<td>N*(0.5+T_WARM)</td>
<td>1000/(N*0.5)</td>
</tr>
<tr>
<td></td>
<td>01</td>
<td>N*(5.5+T_WARM)</td>
<td>1000/(N*5.5)</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>N*(17.5+T_WARM)</td>
<td>1000/(N*17.5)</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>N*(65.5+T_WARM)</td>
<td>1000/(N*65.5)</td>
</tr>
<tr>
<td>00000 (divide-by-1)</td>
<td>00</td>
<td>0.5+T_WARM</td>
<td>2000</td>
</tr>
<tr>
<td></td>
<td>01</td>
<td>5.5+T_WARM</td>
<td>181.8</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>17.5+T_WARM</td>
<td>57.1</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>65.5+T_WARM</td>
<td>15.27</td>
</tr>
</tbody>
</table>
19.4.8 ADC Conversion Results

The digital conversion result is represented in 2's complement form (see Table 150, Table 151, Table 152, and Table 152). The digital conversion result is available in ADC_REG_RESULT.DATA[15:0] when ADC_REG_ISR.RDY is set to 1'b1.

Table 150: ADC Conversion Result Format (OSR[1:0]=2'b11 or =2'b10)

<table>
<thead>
<tr>
<th>$\Delta V /V_{ref}$</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Binary</td>
</tr>
<tr>
<td>1</td>
<td>0111 1111 1111 1111</td>
</tr>
<tr>
<td>0.5</td>
<td>0100 0000 0000 0000</td>
</tr>
<tr>
<td>1/32768</td>
<td>0000 0000 0000 0001</td>
</tr>
<tr>
<td>0</td>
<td>0000 0000 0000 0000</td>
</tr>
<tr>
<td>-1/32768</td>
<td>1111 1111 1111 1111</td>
</tr>
<tr>
<td>-0.5</td>
<td>1100 0000 0000 0000</td>
</tr>
<tr>
<td>-1</td>
<td>1000 0000 0000 0000</td>
</tr>
</tbody>
</table>

Table 151: ADC Conversion Result Format (OSR[1:0]=2'b01)

<table>
<thead>
<tr>
<th>$\Delta V /V_{ref}$</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Binary</td>
</tr>
<tr>
<td>1</td>
<td>0001 1111 1111 1111</td>
</tr>
<tr>
<td>0.5</td>
<td>0001 0000 0000 0000</td>
</tr>
<tr>
<td>1/8192</td>
<td>0000 0000 0000 0001</td>
</tr>
<tr>
<td>0</td>
<td>0000 0000 0000 0000</td>
</tr>
<tr>
<td>-1/8192</td>
<td>1111 1111 1111 1111</td>
</tr>
<tr>
<td>-0.5</td>
<td>1111 0000 0000 0000</td>
</tr>
<tr>
<td>-1</td>
<td>1110 0000 0000 0000</td>
</tr>
</tbody>
</table>
19.4.9 ADC Interrupts

The ADC outputs a single active high-level interrupt signal when any of the following exceptions is pending:

- Sequence conversion has completed and corresponding 16-bit final data in ADC_REG_RESULT.DATA[15:0] is ready for reading
- Overflow occurred in the offset calibration process
- Overflow occurred in the gain calibration process
- Source data negative side saturation occurred
- Source data positive side saturation occurred
- FIFO overrun occurred
- FIFO underrun occurred

ADC_REG_ISR, the interrupt status register, is read only. Every non-reserved bit in this register represents 1 exception. A bit read as 1 means the corresponding exception is pending; the masked exception is not captured in this register.

ADC_REG_IMR, the interrupt mask register, is readable and writable. This register is used to mask off unused exceptions. When a bit is set to 1, the corresponding exception is masked off and it does not trigger the interrupt signal. By default, all the non-reserved bits should be 1.

ADC_REG_IRSR, the interrupt raw status register, is read-only. All the pending exceptions are captured in this register regardless of the values in the interrupt mask register.

ADC_REG_ICR, the interrupt clear register, is write only. Write a 1 to a bit to clear the corresponding pending exception.

---

### Table 152: ADC Conversion Result Format (OSR[1:0]=2'b00)

<table>
<thead>
<tr>
<th>ΔV /Vref</th>
<th>Results</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Binary</td>
</tr>
<tr>
<td>1</td>
<td>0000 0111 1111 1111</td>
</tr>
<tr>
<td>0.5</td>
<td>0000 0100 0000 0000</td>
</tr>
<tr>
<td>1/2048</td>
<td>0000 0000 0000 0001</td>
</tr>
<tr>
<td>0</td>
<td>0000 0000 0000 0000</td>
</tr>
<tr>
<td>-1/2048</td>
<td>1111 1111 1111 1111</td>
</tr>
<tr>
<td>-0.5</td>
<td>1111 1011 0000 0000</td>
</tr>
<tr>
<td>-1</td>
<td>1111 1000 0000 0000</td>
</tr>
</tbody>
</table>
19.4.10 ADC Calibration

Sampling of internal connections VSSA or Vref_12 allows for self/system offset and gain calibration of the ADC to correct error due to process and temperature variations where absolute accuracy is important. This calibration must be done individually for each reference used and each ADC decimation rate.

Automatic calibration measurement is activated by the following steps (the sequence cannot be reversed):
1. Stop ADC conversion by setting ADC_REG_CMD.CONV_START=0.
2. Enable automatic calibration by setting ADC_REG_GENERAL.ADC_CAL_EN=1.
3. Start ADC conversion by setting ADC_REG_CMD.CONV_START=1.

After the automatic calibration, ADC_REG_GENERAL.ADC_CAL_EN is cleared by hardware. Measured data is stored in ADC_REG_OFFSET_CAL.OFFSET_CAL and ADC_REG_GAIN_CAL.GAIN_CAL. Setting ADC_REG_CONFIG.CAL_DATA_RST=1 resets the offset to 0 (ADC_REG_OFFSET_CAL = 0) and gain factor to 0 (ADC_REG_GAIN_CAL = 0).

Instead of using the automatic offset/gain calibration, the user can set the calibration coefficients by setting ADC_REG_CONFIG.CAL_DATA_SEL=1. Calibration data is then defined by entering data into ADC_REG_OFFSET_CAL.OFFSET_CAL_USR and ADC_REG_GAIN_CAL.GAIN_CAL_USR.

Table 153 shows the equations used to calculated the gain and offset correction values.

### Table 153: Equations for Gain and Offset Correction

<table>
<thead>
<tr>
<th>Calibration Type</th>
<th>Calibration Correction Value (INBUF_GAIN = 1)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Self Offset, input buffer disabled. Vref = Vref_12</td>
<td>N(VSSA-VSSA)</td>
</tr>
<tr>
<td>Self Gain, input buffer disabled. Vref = Vref_12</td>
<td>1-N(1.2-VSSA) /0x7FFF</td>
</tr>
<tr>
<td>System Gain, input buffer disabled. Vref = external 1.25V</td>
<td>1-N(1.2-VSSA) /0x7AE1</td>
</tr>
</tbody>
</table>

Equation Notes:
- All N are 16-bit 2’s complement numbers.
- \( N(VSSA-VSSA) \) is a differential sampling of 0 with input positive and negative sides connected to VSSA when offset calibration mode and it yields a 2’s complement value close to 0.
- \( N(1.2-VSSA) \) is a sampling of Vref_12 and it yields a 2’s complement value close to 0x7FFF in OSR[1:0] = 2'b11 mode.
- \( N(1.2-VSSA) \) is a sampling of Vref_12 with external accurate voltage reference (1.25V from ADC_CH[3]) and yields a 2’s complement value close to 0x7AE1 in OSR[1:0] = 2'b11 mode.

19.4.11 DMA Request

With ADC_REG_DMAR.DMA_EN to 1'b1, the ADC sends out a DMA request every time the converted data in FIFO achieves the number of ADC_REG_DMAR.FIFO_THL. This request is automatically cleared when the corresponding result register is read and a DMA acknowledge signal sent from DMA has been received (optional).
19.4.12 Battery Monitor
The internal power supply monitor allows the battery voltage to be measured by programming ADC_REG_ANA.SINGLEDIFF to 1'b0 and ADC_REG_ANA_AMUX_SEL[3:0] to 4'b1000. This monitoring is achieved with a potential divider that reduces the voltage by a factor of 0.33 (nominal), allowing it to fall inside the ADC input range. After the battery voltage measurement is finished, ADC_REG_ANA_AMUX_SEL[3:0] should be assigned another value other than 4'b1000 to disable the resistor chain that performs the voltage reduction, thereby avoiding a continuous drain on the power supply.

19.4.13 External Trigger from GPT
It is also possible to trigger conversions from an event. Once the ADC is powered up by setting the ADC_REG_GENERAL_GLOBAL_EN bit to 1, the data conversion can be activated by external trigger source (GPT0 for ADC0) by writing 1 to the ADC_REG_CONFIG_TRIGGER_EN bit to enable the Event Trigger mode.

19.5 Register Description
20 Digital Analog Converter (DAC)

20.1 Overview
The 88MW320/322 integrates a register string-based DAC with true 10-bit resolution. It includes 2 channels. Each channel can output a single-ended signal or combine both channels to output a differential signal.

20.2 Features
- 10-bit resolution
- Throughput rate as fast as 2 $\mu$s (500 kHz)
- Capable of directly driving a piezo speaker with 5 kΩ load
- Flexible waveform generator (sinusoidal, triangle, noise, etc.) at various frequency range
- Selectable output mode: single-ended or differential
- Internal or external reference voltage
- Interrupt generation and/or DMA request
- 3 selectable output ranges
- Supports event trigger from GPT or GPIO

20.3 Interface Signal Description
Table 154 shows the interface signals.

Table 154: DAC Interface Signals

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Type</th>
<th>Default Value</th>
<th>Source/Destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>EXT_VREF</td>
<td>A, I</td>
<td>n/a</td>
<td>GPIO to DAC</td>
<td>External voltage reference from GPIO_45</td>
</tr>
<tr>
<td>DACA</td>
<td>A, O</td>
<td>n/a</td>
<td>DAC to GPIO</td>
<td>DAC channel A output to GPIO_44</td>
</tr>
<tr>
<td>DACB</td>
<td>A, O</td>
<td>n/a</td>
<td>DAC to GPIO</td>
<td>DAC channel A output to GPIO_43</td>
</tr>
</tbody>
</table>

1. See Section 22.9, DAC Specifications, on page 291 for electrical specifications.
20.4 Functional Description

20.4.1 Configuration

The 88MW320/322 DAC can support 2 independent single-ended channels or 1 differential channel, as set by the DAC.BCTRL.B_WAVE register bits.

In single-ended mode, each channel output can be sent to the pad by setting DAC.xCTRL.x_IO_EN register bit (x can be A or B). Each channel can be powered on by the DAC.xCTRL.x_EN register bit (x can be A or B).

Table 155 shows the output voltage calculation.

Table 155: Output Voltage Calculation Formula

<table>
<thead>
<tr>
<th>A_Range[1:0]</th>
<th>REF_SEL</th>
<th>Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>0.16+(0.64*input code/1023)</td>
</tr>
<tr>
<td>01/10</td>
<td>0</td>
<td>0.19+(1.01*input code/1023)</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0.18+(1.42*input code/1023)</td>
</tr>
<tr>
<td>00</td>
<td>1</td>
<td>0.08<em>Vref_ext+(0.32</em>Vref_ext*input code/1023)</td>
</tr>
<tr>
<td>01/10</td>
<td>1</td>
<td>0.095<em>Vref_ext+(0.505</em>Vref_ext*input code/1023)</td>
</tr>
<tr>
<td>11</td>
<td>1</td>
<td>0.09<em>Vref_ext+(0.71</em>Vref_ext*input code/1023)</td>
</tr>
</tbody>
</table>

- DAC.ACTRL.A_RANGE impacts the output range of both channel A and B simultaneously
- DAC can be operated in differential mode by setting DAC.BCTRL.B_WAVE to 2'b11
- Each DAC channel can be powered on by setting the corresponding DAC.xCTRL.x_EN bit to 1 (x can be A or B)
- DAC conversion rate is selectable by setting the DAC.CLK.CLK_CTRL bits. See Section 3.5.6, AUPLL for Audio Clock and GAU Clock, on page 64 for AUPLL setting for 64 MHz OCLK.

Table 156 shows the clock divisor.

Table 156: Clock Divisor

<table>
<thead>
<tr>
<th>gpdac_clk_ctrl (DAC.CLK.CLK_CTRL)</th>
<th>DAC Conversion Rate</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>62.5 kHz</td>
</tr>
<tr>
<td>01</td>
<td>125 kHz</td>
</tr>
<tr>
<td>10</td>
<td>250 kHz</td>
</tr>
<tr>
<td>11</td>
<td>500 kHz</td>
</tr>
</tbody>
</table>
20.4.2 Synchronous Mode

Each DAC channel can operate in synchronous mode by setting the DAC.xCTRL.x_MODE register bit (x can be A or B). In this mode, each DAC channel has a timing requirement for input data refresh speed. Figure 105 shows the timing.

Figure 105: Synchronous Mode

20.4.3 Asynchronous Mode

In this mode, the DAC works in passive mode, and does not have a time-sequence requirement for input data refreshing.

20.4.4 Sinusoidal Waveform Generation

This function is enabled by setting DAC.ACTRLA.WAVE[1:0] register bits to 2'b10. The amplitude of the sine signal is controlled by the DAC.ACTRLA.RANGE[1:0] register bits. Each period, starting at 0 degree consists of 16 samples and the frequency is given by the equation:

\[ f_{\text{sine}} = \frac{f_{\text{clk}}}{16} \]

The sine wave is output on Channel A. In differential mode, the sine wave is output on both channels (if 2 channels have been enabled), but inverted. See Figure 106.

Figure 106: Sinusoidal Waveform Generation
20.4.5 Triangle Waveform Generation

20.4.5.1 Up and Down Mode

- Amplitude of triangle wave configured through the DAC.ACTRL.A_RANGE[1:0] register bits
- Triangle counter increases 3 clock cycles after each trigger event
- Triangle counter increases while less than maximum amplitude set by DAC.ACTRL.A_TRIA_MAMP_SEL[3:0] register field
- Increment step is defined by the DAC.ACTRL.A_TRIA_STEP_SEL[1:0] register
- Once configured amplitude is reached, counter is decremented down to base value defined by the DAC.ADATA register

Figure 107 shows the timing.

20.4.5.2 Up Mode

This mode is set by the DAC.ACTRL.TRIA_HALF bit in the DAC.ACTRL register. The remaining control information with respect to setting the amplitude, maximum amplitude, increment step are configured using the DAC.ACTRL.A_RANGE[1:0], DAC.ACTRL.A_TRIA_MAMP_SEL[3:0] and DAC.ACTRL.A_TRIA_STEP_SEL[1:0] register fields. See Section 20.4.5.1, Up and Down Mode for a detailed description of how the register fields are used. The difference from the Up and Down mode is that once the configured amplitude is reached, the counter is directly down to the base value.

Figure 108 shows the timing.
20.4.6 Noise Generation

The DAC can generate pseudo noise.

20.4.7 DMA Request

Each DAC channel supports DMA data transfer. A DAC DMA request is generated each time when previous data conversion is complete and new data is requested to be loaded to DAC.x_DATA[x_DATA][9:0] while the DAC.xCTRL.x_DEN register field (x can be A or B) is set to 1. If the DAC.xCTRL.x_DEN register field is set for both channel A and B, 2 DMA requests are generated.

20.4.8 Event Trigger from GPT or GPIO

Events from GPT or GPIO can trigger the reload of new data from DAC.x_Data.x_DATA (x can be A or B) to DAC for conversion. The DAC event trigger mode is activated by writing DAC.xCTRL.x_EN bit to 1 and DAC.xCTRL.x_TRIG_EN bit to 1 (x can be A or B).

Each DAC channel accepts up to 4 trigger sources: GPT2, GPT3, GPIO_41, and GPIO_40. DAC.xCTRL.x_TRIG_SEL[1:0] defines the appropriate trigger.

GPT match interrupt can generate the trigger event.

In addition, the transition edge of selected external GPIO source can trigger the reload of new data. Rising edge, falling edge, or both edges can be selected by DAC.xCTRL.x_TRIG_TPY[1:0].

When there is no event occurred, the DAC continuously converts previous 10-bit data and hold the analog conversion result at the output.

When a trigger event is generated, a new 10-bit data block is loaded in the DAC and a new analog conversion result is presented at the output.

20.5 Registers Description

See Section 24.15.2, DAC Registers for a detailed description of the registers.
21 Analog Comparator (ACOMP)

21.1 Overview
The 88MW320/322 has 2 analog identical comparators, ACOMP0 and ACOMP1, which are designed to have true rail-to-rail inputs and operate over the full voltage range of the power supply VDDIO_3. The comparator outputs are latched and can be used as interrupts.

21.1.1 Features
- 8 selectable external positive inputs
- 8 selectable external negative inputs
- 2 selectable internal positive inputs
  - DACA output
  - DACB output
- 5 selectable internal negative inputs
  - DACA output
  - DACB output
  - VDDIO_3, VDDIO_3*0.75, VDDIO_3*0.5, VDDIO_3*0.25
  - Internal reference 1.2V (Vref_12)
  - VSSA
- Selectable positive and negative hysteresis between 0 and 70 mV, with 10 mV step
- Selectable response time as fast as 130 ns
- Interrupt generation on selectable edges (rising edge and/or falling edge) or levels.
- Extremely low-power mode
- Configurable output when inactive
- Comparator output on GPIOs through alternate functionality, output inversion available
21.2 Interface Signal Description

The external interface signals of the ACOMP0/1 include power supply and analog inputs. Table 157 shows the interface signals.

Table 157: ACOMP Module Interface Signals

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Type</th>
<th>Default Value</th>
<th>Source/Destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACOMP0_IN [7:0]</td>
<td>A, I</td>
<td>n/a</td>
<td>GPIO to ACOMP</td>
<td>External Analog Inputs from GPIO</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0_GPIO_OUT: GPIO_40</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1_GPIO_OUT: GPIO_40</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP0_EDGE_PULSE: GPIO_41</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ACOMP1_EDGE_PULSE: GPIO_41</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1. See Section 22.10, ACOMP Specifications, on page 293 for electrical specifications.</td>
</tr>
</tbody>
</table>

21.3 Functional Description

21.3.1 ACOMP0/1 Control Signals

The ACOMP.CTRL[x].POS_SEL[3:0] field and the ACOMP.CTRL[x].NEG_SEL[3:0] field select which signals are connected to the 2 inputs of the comparator.

21.3.1.1 Warm-up Time

When the ACOMP.CTRL[x].EN bit is set from low to high, ACOMPx is turned on and compares the 2 analog inputs. The warm-up time of the comparator after turn-on is programmable in the ACOMP.CTRL[x].WARMTIME[1:0] field. When it is warmed up, the ACOMP.STATUS[x].ACT bit is set high.

21.3.1.2 Response Time

When the voltage of input signals changes and triggers a polarity flip at the comparator output, the delay from input to output is the response time of the comparator. The response time is also programmable through the ACOMP.CTRL[x].BIAS_PROG[1:0] field.
21.3.1.3 Hysteresis

The programmable hysteresis in ACOMP0/1 can be used to filter input fluctuations due to noise, and only changes that are big enough to reach the hysteresis threshold trigger an output change, as shown in Figure 109.

Figure 109: Comparator Hysteresis

The hysteresis voltage levels for the positive input and the negative input are set in the ACOMP.CTRL[x].HYST_SEL[x][2:0] and ACOMP.CTRL[x].HYST_SEL[2:0] field.
21.3.2 Comparator Output
The outputs from ACOMP0/1 are available in ACOMP.STATUS[x].OUT, or as alternate functions to the GPIO pins. Set the ACOMP.ROUTE[x].PE bit to 1 to enable output to pin.

21.3.2.1 Asynchronous Comparison Output at Register
When comparator is enabled by ACOMP.CTRL[x].EN, real time comparator output is available in ACOMP.STATUS[x].OUT.

When comparator is disabled, comparator output in ACOMP.STATUS[x].OUT can be set by ACOMP.CTRL[x].INACT_VAL.

21.3.2.2 Synchronous/Asynchronous Comparison Output at GPIO
The comparator output at GPIO can be programmed to be synchronized with the main clock of the comparator, or asynchronized by setting ACOMP.ROUTE[x].OUTSEL.

When powered down, the output values can be set through register bit ACOMP.CTRL[x].INACT_VAL.

21.3.2.3 Comparison Output Inversion
The comparison output to GPIO can be inverted by the ACOMP.CTRL[x].GPIOINV bit.

21.3.3 Comparator Output Edge Detection
The comparator output edge detection can be enabled by selecting ACOMP.CTRL[x].RIE (rising edge) or ACOMP.CTRL[x].FIE (falling edge). The edge detection results are routed to GPIOs.

Figure 110, Comparator Output Edge Detection, on page 266 shows the timing.
Figure 110: Comparator Output Edge Detection

ACOMP.CTRL[x].RIE=0
ACOMP.CTRL[x].FIE=0

ACOMP
Main clock

ACOMP.STATUS[x].OUT
(synchronized)

ACOMPx_EDGE_PULSE

ACOMP.CTRL[x].RIE=1
ACOMP.CTRL[x].FIE=0

ACOMP
Main clock

ACOMP.STATUS[x].OUT
(synchronized)

ACOMPx_EDGE_PULSE

ACOMP.CTRL[x].RIE=0
ACOMP.CTRL[x].FIE=1

ACOMP
Main clock

ACOMP.STATUS[x].OUT
(synchronized)

ACOMPx_EDGE_PULSE

ACOMP.CTRL[x].RIE=1
ACOMP.CTRL[x].FIE=1

ACOMP
Main clock

ACOMP.STATUS[x].OUT
(synchronized)

ACOMPx_EDGE_PULSE
21.3.4 Interrupt

An interrupt is generated upon detection of level or edge changes of ACOMP0/1 comparison results. Interrupt trigger type and active mode can be selected by ACOMP.CTRL[x].EDGE_LEVL_SEL and ACOMP.CTRL[x].INT_ACT_HI. Figure 111 shows the timing.

Figure 111: Interrupt
21.4 Register Description

See Section 24.16, ACOMP Address Block for a detailed description of the registers.
# 22 Electrical Specifications

## 22.1 Absolute Maximum Ratings

**Note:** The absolute maximum ratings define limitations for electrical and thermal stresses. These limits prevent permanent damage to the device. These ratings are not operating ranges. Operation at absolute maximum ratings is not guaranteed.

### Table 158: Absolute Maximum Ratings

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDD11</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>1.1</td>
<td>1.26</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_0</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>1.8</td>
<td>1.98</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_3</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>2.5</td>
<td>2.75</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_1</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>1.8</td>
<td>2.16</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_2</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>2.5</td>
<td>3.0</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_AON</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>3.3</td>
<td>4.0</td>
<td>V</td>
</tr>
<tr>
<td>GPIO VIL</td>
<td>GPIO input low voltage</td>
<td>-0.4</td>
<td>--</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td>GPIO VIH</td>
<td>GPIO input high voltage</td>
<td>--</td>
<td>--</td>
<td>VDDIO\textsuperscript{1}+0.4</td>
<td>V</td>
</tr>
<tr>
<td>VTR_VDD33</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>3.3</td>
<td>4.0</td>
<td>V</td>
</tr>
<tr>
<td>USB_AVDD33</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>3.3</td>
<td>4.0</td>
<td>V</td>
</tr>
<tr>
<td>USB_VBUS</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>5</td>
<td>5.5</td>
<td>V</td>
</tr>
<tr>
<td>AVDD33</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>3.3</td>
<td>4.0</td>
<td>V</td>
</tr>
<tr>
<td>AVDD18</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>1.8</td>
<td>1.98</td>
<td>V</td>
</tr>
<tr>
<td>VBAT_IN</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>BUCK18_VBAT_IN</td>
<td>Power supply voltage with respect to VSS</td>
<td>--</td>
<td>3.3</td>
<td>4.3</td>
<td>V</td>
</tr>
<tr>
<td>T\textsubscript{STORAGE}</td>
<td>Storage temperature</td>
<td>-55</td>
<td>--</td>
<td>+125</td>
<td>°C</td>
</tr>
</tbody>
</table>

1. VDDIO\textsubscript{group} is the VDDIO power for the individual GPIO pin.
22.2 Recommended Operating Conditions

Note: Operation beyond the recommended operating conditions is neither recommended nor guaranteed.

Table 159: Recommended Operating Conditions

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDD11</td>
<td>1.1V core power supply</td>
<td>--</td>
<td>--</td>
<td>1.1</td>
<td>1.21</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_0</td>
<td>1.8V digital I/O power supply</td>
<td>--</td>
<td>1.62</td>
<td>1.8</td>
<td>1.98</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_1</td>
<td>2.5V digital I/O power supply</td>
<td>--</td>
<td>2.25</td>
<td>2.5</td>
<td>2.75</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_2</td>
<td>3.3V digital I/O power supply</td>
<td>--</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_3(^1)</td>
<td>3.3V digital I/O power supply</td>
<td>--</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>VDDIO_AON</td>
<td>3V digital I/O power supply</td>
<td>--</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>VTR_VDD33</td>
<td>3V OTP analog power supply or floating for Read OTP only operation</td>
<td>--</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>USB_AVDD33</td>
<td>3.3V USB analog power supply</td>
<td>--</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>USB_VBUS</td>
<td>5V analog power supply—high-power port 5 unit loads. 1 unit load = 100 mA.</td>
<td>--</td>
<td>4.75</td>
<td>5.0</td>
<td>5.25</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>5V analog power supply—low-power port 1 unit load only.</td>
<td>--</td>
<td>4.40</td>
<td>5.0</td>
<td>5.25</td>
<td>V</td>
</tr>
<tr>
<td>AVDD33</td>
<td>3.3V analog power supply</td>
<td>--</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>AVDD18</td>
<td>1.8V analog power supply</td>
<td>--</td>
<td>1.71</td>
<td>1.8</td>
<td>1.89</td>
<td>V</td>
</tr>
<tr>
<td>VBAT_IN</td>
<td>LDO18 power supply</td>
<td>--</td>
<td>1.84</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>BUCK18_</td>
<td>BUCK18 power supply</td>
<td>--</td>
<td>2.4</td>
<td>3.3</td>
<td>4.3</td>
<td>V</td>
</tr>
<tr>
<td>VBAT_IN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>T(_A)</td>
<td>Ambient operating temperature</td>
<td>Commercial</td>
<td>0</td>
<td>--</td>
<td>70</td>
<td>°C</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Extended</td>
<td>-30</td>
<td>--</td>
<td>85</td>
<td>°C</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Industrial</td>
<td>-40</td>
<td>--</td>
<td>105</td>
<td>°C</td>
</tr>
<tr>
<td>T(_J)</td>
<td>Maximum junction temperature</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>125</td>
<td>°C</td>
</tr>
</tbody>
</table>

1. When the VDDIO_3 domain pad is used as GAU, in a typical 1.8V condition, the minimum is -5% (1.71V).
### 22.3 Digital Pad Ratings

#### 22.3.1 I/O Static Ratings

**Table 160: I/O Static Ratings, 1.8V VDDIO**

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VIL</td>
<td>Input low voltage</td>
<td>--</td>
<td>-0.4</td>
<td>--</td>
<td>VDDIO*30%</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>Input high voltage</td>
<td>--</td>
<td>VDDIO*70%</td>
<td>--</td>
<td>VDDIO+0.4</td>
<td>V</td>
</tr>
<tr>
<td>VHYS</td>
<td>Input hysteresis</td>
<td>--</td>
<td>150</td>
<td>--</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td>IOL @0.4V</td>
<td>Output drive low</td>
<td>V(PAD) = 0.4V</td>
<td>4</td>
<td>6</td>
<td>12123</td>
<td>mA</td>
</tr>
<tr>
<td><a href="mailto:IOH@VDDIO-0.5V">IOH@VDDIO-0.5V</a></td>
<td>Output drive high</td>
<td>V(PAD) = VDDIO - 0.5V</td>
<td>3</td>
<td>4.5</td>
<td>12123</td>
<td>mA</td>
</tr>
<tr>
<td>Input capacitance</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>5</td>
<td>pF</td>
</tr>
<tr>
<td>Input leakage 1</td>
<td>--</td>
<td>VDDIO is ON, 0&lt;V(PAD)&lt;VDDIO</td>
<td>--</td>
<td>--</td>
<td>5</td>
<td>μA</td>
</tr>
</tbody>
</table>

1. Maximum current is based on best case conditions. Not all parts can achieve this.
2. The absolute maximum DC current is 20 mA for IOL / IOH, per pad. The user should not exceed this.
3. Each VDDIO_0/_1/_2/_3/_AON supply domain can only have maximum absolute DC current of 40 mA for driving low and maximum absolute DC current 40 mA for driving high.

**Table 161: I/O Static Ratings, 2.5V VDDIO**

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VIL</td>
<td>Input low voltage</td>
<td>--</td>
<td>-0.4</td>
<td>--</td>
<td>VDDIO*30%</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>Input high voltage</td>
<td>--</td>
<td>VDDIO*70%</td>
<td>--</td>
<td>VDDIO+0.4</td>
<td>V</td>
</tr>
<tr>
<td>VHYS</td>
<td>Input hysteresis</td>
<td>--</td>
<td>150</td>
<td>--</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td>IOL @0.4V</td>
<td>Output drive low</td>
<td>V(PAD) = 0.4V</td>
<td>4</td>
<td>6</td>
<td>12123</td>
<td>mA</td>
</tr>
<tr>
<td><a href="mailto:IOH@VDDIO-0.5V">IOH@VDDIO-0.5V</a></td>
<td>Output drive high</td>
<td>V(PAD) = VDDIO - 0.5V</td>
<td>3</td>
<td>4.5</td>
<td>12123</td>
<td>mA</td>
</tr>
<tr>
<td>Input capacitance</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>5</td>
<td>pF</td>
</tr>
<tr>
<td>Input leakage 1</td>
<td>--</td>
<td>VDDIO is ON, 0&lt;V(PAD)&lt;VDDIO</td>
<td>--</td>
<td>--</td>
<td>5</td>
<td>μA</td>
</tr>
</tbody>
</table>

1. Maximum current is based on best case conditions. Not all parts can achieve this.
2. The absolute maximum DC current is 20 mA for IOL / IOH, per pad. The user should not exceed this.
3. Each VDDIO_0/_1/_2/_3/_AON supply domain can only have maximum absolute DC current of 40 mA for driving low and maximum absolute DC current 40 mA for driving high.
Table 162: I/O Static Ratings, 3.3V VDDIO

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VIL</td>
<td>Input low voltage</td>
<td>--</td>
<td>-0.4</td>
<td>--</td>
<td>VDDIO*30%</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>Input high voltage</td>
<td>--</td>
<td>VDDIO*70%</td>
<td>--</td>
<td>VDDIO+0.4</td>
<td>V</td>
</tr>
<tr>
<td>VHYS</td>
<td>Input hysteresis</td>
<td>--</td>
<td>150</td>
<td>--</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td><a href="mailto:IOL@0.4V">IOL@0.4V</a></td>
<td>Output drive low</td>
<td>V(PAD) = 0.4V</td>
<td>4</td>
<td>6</td>
<td>12</td>
<td>mA</td>
</tr>
<tr>
<td><a href="mailto:IOH@VDDIO-0.5V">IOH@VDDIO-0.5V</a></td>
<td>Output drive high</td>
<td>V(PAD) = VDDIO - 0.5V</td>
<td>3</td>
<td>4.5</td>
<td>12</td>
<td>mA</td>
</tr>
<tr>
<td>Input capacitance</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>5</td>
<td>pF</td>
</tr>
<tr>
<td>Input leakage 1</td>
<td>--</td>
<td>VDDIO is ON, 0&lt;V(PAD)&lt;VDDIO</td>
<td>--</td>
<td>--</td>
<td>5</td>
<td>μA</td>
</tr>
</tbody>
</table>

1. Maximum current is based on best case conditions. Not all parts can achieve this.
2. The absolute maximum DC current is 20 mA for IOL / IOH, per pad. The user should not exceed this.
3. Each VDDIO_0/_1/_2/_3/_AON supply domain can only have maximum absolute DC current of 40 mA for driving low and maximum absolute DC current 40 mA for driving high.
22.3.2 Current Consumption

22.3.2.1 WLAN Subsystem

Table 163: WLAN Tx/Rx Current Consumption

<table>
<thead>
<tr>
<th>Parameter</th>
<th>3.3V (Typ)</th>
<th>1.8V (Typ)</th>
<th>1.1V (Typ)</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Transmit</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tx_802.11b 11 Mbps 20 MHz @4 dBm</td>
<td>59.0</td>
<td>89.7</td>
<td>27.6</td>
<td>mA</td>
</tr>
<tr>
<td>Tx_802.11b 11 Mbps 20 MHz @18 dBm</td>
<td>183.3</td>
<td>91.2</td>
<td>28.2</td>
<td>mA</td>
</tr>
<tr>
<td>Tx_802.11g 54 Mbps 20 MHz @4 dBm</td>
<td>61.1</td>
<td>89.7</td>
<td>29.5</td>
<td>mA</td>
</tr>
<tr>
<td>Tx_802.11g 54 Mbps 20 MHz @14 dBm</td>
<td>150.9</td>
<td>93.9</td>
<td>29.5</td>
<td>mA</td>
</tr>
<tr>
<td>Tx_802.11n MCS7 20 MHz @4 dBm</td>
<td>60.2</td>
<td>75.3</td>
<td>29.7</td>
<td>mA</td>
</tr>
<tr>
<td>Tx_802.11n MCS7 20 MHz @14 dBm</td>
<td>154.0</td>
<td>93.2</td>
<td>29.8</td>
<td>mA</td>
</tr>
<tr>
<td>Tx_802.11n MCS7 20 MHz @4 dBm AMPDU on</td>
<td>60.7</td>
<td>87.6</td>
<td>29.4</td>
<td>mA</td>
</tr>
<tr>
<td>Tx_802.11n MCS7 20 MHz @14 dBm AMPDU on</td>
<td>154.7</td>
<td>93.8</td>
<td>29.9</td>
<td>mA</td>
</tr>
<tr>
<td><strong>Receive</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Rx_802.11b 11 Mbps 20 MHz</td>
<td>0.0</td>
<td>42.5</td>
<td>29.3</td>
<td>mA</td>
</tr>
<tr>
<td>Rx_802.11g 54 Mbps 20 MHz</td>
<td>0.0</td>
<td>43.8</td>
<td>33.4</td>
<td>mA</td>
</tr>
<tr>
<td>Rx_802.11n MCS7 20 MHz</td>
<td>0.0</td>
<td>45.2</td>
<td>35.3</td>
<td>mA</td>
</tr>
</tbody>
</table>

**NOTE:** The above current measurement is at room temperature condition.
- 1.1V current to VDD11 pins.
- 1.8V current to AVDD18 pins.
- 3.3V current to AVDD33 pin.
### Table 164: WLAN Estimated Tx PA Power vs. Current Consumption

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>18.5 dBm</td>
<td>3.3V</td>
<td>--</td>
<td>--</td>
<td>270</td>
<td>mA</td>
</tr>
<tr>
<td>18 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>250</td>
<td></td>
</tr>
<tr>
<td>16 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>220</td>
<td></td>
</tr>
<tr>
<td>15 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>200</td>
<td></td>
</tr>
<tr>
<td>14 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>190</td>
<td></td>
</tr>
<tr>
<td>10 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>150</td>
<td></td>
</tr>
<tr>
<td>8 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>135</td>
<td></td>
</tr>
<tr>
<td>5 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>120</td>
<td></td>
</tr>
<tr>
<td>4 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>115</td>
<td></td>
</tr>
<tr>
<td>0 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>100</td>
<td></td>
</tr>
<tr>
<td>-5 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>85</td>
<td></td>
</tr>
<tr>
<td>-10 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>75</td>
<td></td>
</tr>
<tr>
<td>-20 dBm</td>
<td></td>
<td>--</td>
<td>--</td>
<td>70</td>
<td></td>
</tr>
</tbody>
</table>
### 22.3.2.2 MCI Subsystem

#### Table 165: MCI VBAT Consumption

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
</table>
| PM0    | Active (Power Mode = 00) | PLL = on  
All peripherals clock = off | --   | 15.8 | --   | mA    |
|        |           | PLL = on  
Typical peripherals clock = on | --   | 25   | --   | mA    |
|        |           | PLL = on  
All peripherals clock = on | --   | 28.3 | --   | mA    |
|        |           | RC32M = on  
All peripherals clock = off | --   | 3.62 | --   | mA    |
|        |           | RC32M = on  
Typical peripherals clock = on | --   | 4.77 | --   | mA    |
|        |           | RC32M = on  
All peripherals clock = on | --   | 5.3  | --   | mA    |
| PM1    | Idle (Power Mode = 00) | RC32M = on  
All peripherals clock = off | --   | 3.59 | --   | mA    |
|        |           | RC32M = on  
Typical peripherals clock = on | --   | 4.74 | --   | mA    |
|        |           | RC32M = on  
All peripherals clock = on | --   | 5.27 | --   | mA    |
| PM2    | Standby (Power Mode = 01) | RC32M = on  
All peripherals clock = off, except RC32K | --   | 282  | --   | μA    |
| PM3    | Sleep (Power Mode = 10) | RC32K = on  
SRAM = retention mode  
RTC = on  
ULP comparator = off  
Brown-out detection = off | 12   | 70   | 91   | μA    |
| PM4    | Deep sleep (Power Mode = 11) | AON domain = on  
SRAM = retention mode  
RTC = on  
ULP comparator = off  
Brown-out detection = off | 9.2  | 45   | 58   | μA    |

**NOTE:** The above current measurement is at room temperature condition.
## 22.4 Regulators

### Table 166: LDO11 Specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDO11_VIN</td>
<td>Input voltage</td>
<td>--</td>
<td>1.62</td>
<td>1.8</td>
<td>1.98</td>
<td>V</td>
</tr>
<tr>
<td>LDO11_VOUT</td>
<td>Output voltage</td>
<td>--</td>
<td>1.045</td>
<td>1.1</td>
<td>1.155</td>
<td>V</td>
</tr>
<tr>
<td>LDO11_VOUTss</td>
<td>Control step size</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>25</td>
<td>mV</td>
</tr>
<tr>
<td>LDO11_max</td>
<td>Output load current</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>50</td>
<td>mA</td>
</tr>
<tr>
<td>LDO11_icons</td>
<td>Current consumption</td>
<td>--</td>
<td>--</td>
<td>10</td>
<td>--</td>
<td>µA</td>
</tr>
<tr>
<td>C_load</td>
<td>Load capacitance</td>
<td>--</td>
<td>0.7</td>
<td>1</td>
<td>10</td>
<td>µF</td>
</tr>
</tbody>
</table>

### Table 167: BUCK18 Specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUCK18_VBAT_IN</td>
<td>Input voltage</td>
<td>--</td>
<td>2.4</td>
<td>3.3</td>
<td>4.3</td>
<td>V</td>
</tr>
<tr>
<td>BUCK18_VOUT</td>
<td>Output voltage</td>
<td>1.8V</td>
<td>1.71</td>
<td>1.8</td>
<td>1.89</td>
<td>V</td>
</tr>
<tr>
<td>BUCK18_VOUTss</td>
<td>Control step size</td>
<td>--</td>
<td>--</td>
<td>20</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td>BUCK18_max</td>
<td>Output load current</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>180</td>
<td>mA</td>
</tr>
<tr>
<td>BUCK18_icons</td>
<td>Current consumption</td>
<td>--</td>
<td>--</td>
<td>10</td>
<td>--</td>
<td>µA</td>
</tr>
<tr>
<td>C_load</td>
<td>Load capacitance</td>
<td>Low-ESR capacitor</td>
<td>--</td>
<td>10</td>
<td>--</td>
<td>µF</td>
</tr>
<tr>
<td>L_load</td>
<td>Load inductance</td>
<td>--</td>
<td>--</td>
<td>2.2</td>
<td>--</td>
<td>µH</td>
</tr>
</tbody>
</table>
Table 168: Efficiency vs. BUCK18_VBAT_IN @ 147 mA Output

<table>
<thead>
<tr>
<th>VBAT (V)</th>
<th>IBAT (mA)</th>
<th>VOUT (V)</th>
<th>Efficiency (%)</th>
</tr>
</thead>
<tbody>
<tr>
<td>4.8</td>
<td>66</td>
<td>1.762</td>
<td>81.8</td>
</tr>
<tr>
<td>4.5</td>
<td>70</td>
<td>1.762</td>
<td>82.3</td>
</tr>
<tr>
<td>4.2</td>
<td>74</td>
<td>1.761</td>
<td>83.3</td>
</tr>
<tr>
<td>3.9</td>
<td>79</td>
<td>1.761</td>
<td>84.0</td>
</tr>
<tr>
<td>3.6</td>
<td>85</td>
<td>1.761</td>
<td>84.7</td>
</tr>
<tr>
<td>3.3</td>
<td>92</td>
<td>1.760</td>
<td>85.3</td>
</tr>
<tr>
<td>3.0</td>
<td>100</td>
<td>1.760</td>
<td>86.3</td>
</tr>
<tr>
<td>2.7</td>
<td>110</td>
<td>1.759</td>
<td>87.2</td>
</tr>
<tr>
<td>2.4</td>
<td>122</td>
<td>1.758</td>
<td>88.4</td>
</tr>
</tbody>
</table>

1. This information is provided as a reference to typical characteristics and should be used for estimation purposes only.

Figure 112 shows the efficiency vs. current for BUCK18_VBAT_IN = 2.7V.

Figure 112: BUCK18_VBAT_IN = 2.7V Efficiency vs. Current

1. This information is provided as a reference to typical characteristics and should be used for estimation purposes only.
### NOTE: LDO11 Specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDO11_VOUT</td>
<td>Output voltage</td>
<td>VBAT = 3.3V</td>
<td>1.05</td>
<td>1.1</td>
<td>1.20</td>
<td>V</td>
</tr>
<tr>
<td>LDO11_{max}</td>
<td>Output load current</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>100</td>
<td>mA</td>
</tr>
<tr>
<td>C_{load}</td>
<td>Load capacitance</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>µF</td>
</tr>
</tbody>
</table>

1. Recommend X7R or X5R ceramic capacitors with low ESR.

### NOTE: LDO18 Specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDO18_VIN (VBAT_IN)</td>
<td>Input voltage</td>
<td>--</td>
<td>1.84</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>LDO18_VOUT</td>
<td>Output voltage</td>
<td>VBAT = 3.3V</td>
<td>1.72</td>
<td>1.80</td>
<td>1.88</td>
<td>V</td>
</tr>
<tr>
<td>LDO18_{max}</td>
<td>Output load current</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>150</td>
<td>mA</td>
</tr>
<tr>
<td>C_{load}</td>
<td>Load capacitance</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>--</td>
<td>µF</td>
</tr>
</tbody>
</table>
# 22.5 Package Thermal Conditions

## 22.5.1 68-Pin QFN

### Table 169: Thermal Conditions—68-pin QFN

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Typ</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \theta_{JA} )</td>
<td>Thermal resistance&lt;br&gt;Junction to ambient of package.&lt;br&gt;( \theta_{JA} = (T_J - T_A)/ P )&lt;br&gt;( P = ) total power dissipation</td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>24.2</td>
<td>°C/W</td>
</tr>
<tr>
<td></td>
<td></td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;1 meter/sec air flow</td>
<td>21.5</td>
<td>°C/W</td>
</tr>
<tr>
<td></td>
<td></td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;2 meter/sec air flow</td>
<td>20.5</td>
<td>°C/W</td>
</tr>
<tr>
<td></td>
<td></td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;3 meter/sec air flow</td>
<td>19.9</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_{JT} )</td>
<td>Thermal characteristic parameter&lt;br&gt;Junction to top-center of package.&lt;br&gt;( \psi_{JT} = (T_J - T_{TOP})/P )&lt;br&gt;( T_{TOP} = ) temperature on top-center of package</td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>0.28</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_{JB} )</td>
<td>Thermal characteristic parameter&lt;br&gt;Junction to bottom surface, center of PCB.&lt;br&gt;( \psi_{JB} = (T_J - T_B)/P )&lt;br&gt;( T_B = ) surface temperature of PCB</td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>14.8</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_{JC} )</td>
<td>Thermal resistance&lt;br&gt;Junction to case of the package&lt;br&gt;( \theta_{JC} = (T_J - T_C)/ P_{TOP} )&lt;br&gt;( T_C = ) temperature on top-center of package&lt;br&gt;( P_{TOP} = ) power dissipation from top of package</td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>9.7</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_{JB} )</td>
<td>Thermal resistance&lt;br&gt;Junction to board of package&lt;br&gt;( \theta_{JB} = (T_J - T_B)/ P_{BOTTOM} )&lt;br&gt;( P_{BOTTOM} = ) power dissipation from bottom of package to PCB surface</td>
<td>JEDEC&lt;br&gt;3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>15.0</td>
<td>°C/W</td>
</tr>
</tbody>
</table>
## 22.5.2 88-Pin QFN

### Table 170: Thermal Conditions—88-pin QFN

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Typ</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \theta_{JA} )</td>
<td>Thermal resistance&lt;br&gt;Junction to ambient of package.&lt;br&gt;( \theta_{JA} = (T_J - T_A)/ P )&lt;br&gt;( P ) = total power dissipation</td>
<td>JEDEC 3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>25.8</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_{JT} )</td>
<td>Thermal characteristic parameter&lt;br&gt;Junction to top-center of package.&lt;br&gt;( \psi_{JT} = (T_J - T_{TOP})/P )&lt;br&gt;( T_{TOP} ) = temperature on top-center of package</td>
<td>JEDEC 3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>0.3</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_{JB} )</td>
<td>Thermal characteristic parameter&lt;br&gt;Junction to bottom surface, center of PCB.&lt;br&gt;( \psi_{JB} = (T_J - T_B)/P )&lt;br&gt;( T_B ) = surface temperature of PCB</td>
<td>JEDEC 3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>15.0</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_{JC} )</td>
<td>Thermal resistance&lt;br&gt;Junction to case of the package&lt;br&gt;( \theta_{JC} = (T_J - T_C)/ P_{TOP} )&lt;br&gt;( T_C ) = temperature on top-center of package&lt;br&gt;( P_{TOP} ) = power dissipation from top of package</td>
<td>JEDEC 3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>10.0</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_{JB} )</td>
<td>Thermal resistance&lt;br&gt;Junction to board of package&lt;br&gt;( \theta_{JB} = (T_J - T_B)/ P_{BOTTOM} )&lt;br&gt;( P_{BOTTOM} ) = power dissipation from bottom of package to&lt;br&gt;PCB surface</td>
<td>JEDEC 3 x 4.5 inch, 4-layer PCB&lt;br&gt;no air flow</td>
<td>15.2</td>
<td>°C/W</td>
</tr>
</tbody>
</table>
22.6 Clock Specifications

22.6.1 RC32K Specifications

Table 171: RC32K\textsuperscript{1} Specifications

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Frequency before calibration</td>
<td>--</td>
<td>18.6</td>
<td>31.8</td>
<td>39.8</td>
<td>kHz</td>
</tr>
<tr>
<td>Startup time</td>
<td>--</td>
<td>--</td>
<td>0.9</td>
<td>--</td>
<td>ms</td>
</tr>
<tr>
<td>After-calibration frequency accuracy</td>
<td>Use 32.768 kHz crystal as reference clock</td>
<td>32.3</td>
<td>32.7</td>
<td>33.1</td>
<td>kHz</td>
</tr>
<tr>
<td>Temperature tolerance</td>
<td>--</td>
<td>--</td>
<td>65</td>
<td>--</td>
<td>ppm/C</td>
</tr>
<tr>
<td>Duty cycle</td>
<td>--</td>
<td>40</td>
<td>50</td>
<td>60</td>
<td>%</td>
</tr>
</tbody>
</table>

1. -40 to 85\degree C, \text{VBAT} = 3.6V with default setting unless otherwise specified.

22.6.2 Single-Ended Clock Input Modes Specifications

Table 172: CMOS Mode\textsuperscript{1} Specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>V\textsubscript{IH}</td>
<td>Input high voltage</td>
<td>AVDD18 - 0.5</td>
<td>1.98</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>V\textsubscript{IL}</td>
<td>Input low voltage</td>
<td>0</td>
<td>0</td>
<td>0.4</td>
<td></td>
<td>V</td>
</tr>
</tbody>
</table>

1. Typical input capacitance is approximately 2 pF and input resistance is >20 k\textohm.

Table 173: Phase Noise—2.4 GHz Operation Specifications

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Test Conditions</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>F\textsubscript{ref} = 38.4 MHz</td>
<td>Offset = 1 kHz</td>
<td>--</td>
<td>--</td>
<td>-123</td>
<td>dBc/Hz</td>
</tr>
<tr>
<td></td>
<td>Offset = 10 kHz</td>
<td>--</td>
<td>--</td>
<td>-134</td>
<td>dBc/Hz</td>
</tr>
<tr>
<td></td>
<td>Offset = 100 kHz</td>
<td>--</td>
<td>--</td>
<td>-140</td>
<td>dBc/Hz</td>
</tr>
<tr>
<td></td>
<td>Offset &gt; 1 MHz</td>
<td>--</td>
<td>--</td>
<td>-140</td>
<td>dBc/Hz</td>
</tr>
</tbody>
</table>
### 22.6.3 Crystal Specifications

#### 22.6.3.1 38.4 MHz

Table 174: Crystal Specifications (38.4 MHz)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Typical</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Fundamental Frequencies</td>
<td>--</td>
<td>38.4</td>
<td>MHz</td>
</tr>
<tr>
<td>Frequency Tolerance</td>
<td>Over operating temperature</td>
<td>&lt; ±10</td>
<td>ppm</td>
</tr>
<tr>
<td></td>
<td>Over process at 25°C</td>
<td>&lt; ±10</td>
<td>ppm</td>
</tr>
<tr>
<td>SMD and AT Cut Height</td>
<td>--</td>
<td>&lt;1.2</td>
<td>mm</td>
</tr>
<tr>
<td>Load Capacitor</td>
<td>--</td>
<td>10</td>
<td>pF</td>
</tr>
<tr>
<td>Maximum Series Resistance</td>
<td>--</td>
<td>60</td>
<td>Ω</td>
</tr>
<tr>
<td>Resonance Mode</td>
<td>--</td>
<td>A1, Fundamental</td>
<td>--</td>
</tr>
</tbody>
</table>

#### 22.6.3.2 32.768 kHz

Table 175: Crystal Specifications (32.768 kHz)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Crystal frequency</td>
<td>--</td>
<td>--</td>
<td>32.768</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td>Frequency accuracy tolerance</td>
<td>--</td>
<td>-40</td>
<td>--</td>
<td>40</td>
<td>ppm</td>
</tr>
<tr>
<td>Startup time</td>
<td>--</td>
<td>--</td>
<td>600</td>
<td></td>
<td>ms</td>
</tr>
<tr>
<td>Duty cycle tolerance</td>
<td>--</td>
<td>--</td>
<td>50</td>
<td>--</td>
<td>%</td>
</tr>
<tr>
<td>Crystal load capacitance</td>
<td>--</td>
<td>--</td>
<td>12.5</td>
<td>--</td>
<td>pF</td>
</tr>
<tr>
<td>Crystal shunt capacitance</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>7</td>
<td>pF</td>
</tr>
<tr>
<td>Equivalent Series Resistance (ESR)</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>100</td>
<td>kΩ</td>
</tr>
</tbody>
</table>
22.7 Power and Brown-Out Detection Specifications

22.7.1 Power-On Reset (POR) Specifications

Table 176: POR Specifications

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>--</td>
<td>POR threshold (rising edge)</td>
<td>--</td>
<td>1.25</td>
<td>--</td>
<td>V</td>
<td></td>
</tr>
</tbody>
</table>

22.7.2 Brown-Out Detection (BOD) Specifications

Table 177: VBAT BOD Timing Data

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vtrig (BOD) – Vbat Brown-out trigger level</td>
<td>BRNTRIG_VBAT_CNTL = 0x0</td>
<td>--</td>
<td>1.6</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>BRNTRIG_VBAT_CNTL = 0x1</td>
<td>--</td>
<td>1.7</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>BRNTRIG_VBAT_CNTL = 0x2</td>
<td>--</td>
<td>1.8</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>BRNTRIG_VBAT_CNTL = 0x3</td>
<td>--</td>
<td>2.7</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>BRNTRIG_VBAT_CNTL = 0x4 (default)</td>
<td>--</td>
<td>2.6</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>BRNTRIG_VBAT_CNTL = 0x5</td>
<td>--</td>
<td>2.8</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>BRNTRIG_VBAT_CNTL = 0x6</td>
<td>--</td>
<td>2.9</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>BRNTRIG_VBAT_CNTL = 0x7</td>
<td>--</td>
<td>3.0</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td>Vhys (BOD) – Vbat Brown-out hysteresis</td>
<td>BRNHYST_VBAT_CNTL = 0x0</td>
<td>--</td>
<td>0</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td>BRNHYST_VBAT_CNTL = 0x1</td>
<td>--</td>
<td>41</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td>BRNHYST_VBAT_CNTL = 0x2</td>
<td>--</td>
<td>66</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td>BRNHYST_VBAT_CNTL = 0x3</td>
<td>--</td>
<td>85</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td>Ton (BOD) – Vbat Brown-out detector turn-on time</td>
<td>--</td>
<td>--</td>
<td>20</td>
<td>--</td>
<td>µs</td>
</tr>
</tbody>
</table>

NOTE: \( V_{\text{fall(BOD)}} = \text{BOD falling edge, } V_{\text{fall(BOD)}} = V_{\text{trig(BOD)}} - V_{\text{hys(BOD)}} \)  
NOTE: \( V_{\text{rise(BOD)}} = \text{BOD rising edge, } V_{\text{rise(BOD)}} = V_{\text{trig(BOD)}} + V_{\text{hys(BOD)}} \)
### 22.8 ADC Specifications

#### 22.8.1 ADC

**Table 178: ADC Specifications**

**NOTE: Typical values:** $T_A = 25^\circ C$, VDDIO_3 = 3.3V (for 1.8V <= VDD <= 3.6V voltage range), unless otherwise noted.

These are design guidelines and are based on bench characterization results and/or design simulation.

**Minimum and maximum values:** Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench.

Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
</table>
| --     | ADC main clock | • See Table 36, VCO Frequency Select, on page 64 (128 MHz).  
• See Table 37, AUPLL Post Divider Programming, on page 65 (ratio = 2). | $F_{VCO}=128$ MHz post divider ratio = 2 | -- | 64 | -- | MHz |
| --     | Reference Voltage | Internal reference voltage | -- | 1.20 | 1.22 | 1.23 | V |
| --     | Analog Inputs | Input voltage | Input buffer disabled | 0 | -- | 1.83 | V |
|        |           | Input buffer enabled | 0.2 | -- | VDDIO_3 - 0.2 | V |
| --     | ADC voltage conversion range | For 16-bit and 16-bit audio setting, input signal should be limited within 99.7% of the ADC voltage conversion range.  
• Vref stands for the voltage reference of the ADC. Could be an internal 1.22V, analog 1.8V power supply(1.8V), or an external voltage (<1.8V). | -- | $-2*v_{ref}$ or $-VDDIO_3$ | -- | $2*v_{ref}$ or $VDDIO_3$ | V |
| $C_{ADC}$ | Internal sampling and hold capacitance | -- | -- | 1000 | -- | fF |
| $R_{ADC}$ | Internal sampling switch resistance | -- | 1 | -- | -- | kΩ |
| $R_{MUX}$ | Input multiplexer impedance | -- | 1 | -- | -- | kΩ |
Table 178: ADC Specifications (Continued)

**NOTE:** Typical values: $T_A = 25^\circ C$, VDDIO_3 = 3.3V (for 1.8V <= VDD <= 3.6V voltage range), unless otherwise noted. These are design guidelines and are based on bench characterization results and/or design simulation.

Minimum and maximum values: Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench. Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$R_S$</td>
<td>External input resistance $R_S$ maximum formula: $\frac{1}{F_{ADC}} = \frac{4 \times \ln(2^{15})}{C_{ADC}} \times \left(\frac{R_{ADC} + R_{MUX}}{2}\right)$</td>
<td>2 MHz ADC operating clock without input buffer 16-bit settling accuracy</td>
<td>--</td>
<td>--</td>
<td>8</td>
<td>kΩ</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 MHz ADC operating clock with input buffer 16-bit settling accuracy</td>
<td>--</td>
<td>--</td>
<td>46</td>
<td>kΩ</td>
</tr>
<tr>
<td>--</td>
<td>Input frequency range</td>
<td>With input buffer</td>
<td>--</td>
<td>31</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td>Defined as input signal -3 dB bandwidth through analog path.</td>
<td>Without input buffer</td>
<td>--</td>
<td>130</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td><strong>Conversion Rate (ADC main clock frequency is 64 MHz)</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>--</td>
<td>ADC sampling clock frequency</td>
<td>Fast mode</td>
<td>--</td>
<td>2</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Low-power mode</td>
<td>--</td>
<td>0.2</td>
<td>2</td>
<td>MHz</td>
</tr>
<tr>
<td>--</td>
<td>Conversion time in ADC clocks</td>
<td>12-bit setting</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>clock cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>14-bit setting</td>
<td>--</td>
<td>11</td>
<td>--</td>
<td>clock cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>16-bit setting</td>
<td>--</td>
<td>35</td>
<td>--</td>
<td>clock cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td>16-bit audio setting</td>
<td>--</td>
<td>131</td>
<td>--</td>
<td>clock cycles</td>
</tr>
<tr>
<td>--</td>
<td>1-shot latency (It is recommended to perform a calibration after each power-up.)</td>
<td>16-bit audio setting @ 2 MHz</td>
<td>65.5</td>
<td>--</td>
<td>--</td>
<td>µs</td>
</tr>
<tr>
<td></td>
<td></td>
<td>16-bit setting @ 2 MHz</td>
<td>17.5</td>
<td>--</td>
<td>--</td>
<td>µs</td>
</tr>
<tr>
<td></td>
<td></td>
<td>14-bit setting @ 2 MHz</td>
<td>5.5</td>
<td>--</td>
<td>--</td>
<td>µs</td>
</tr>
<tr>
<td></td>
<td></td>
<td>12-bit setting @ 2 MHz</td>
<td>0.5</td>
<td>--</td>
<td>--</td>
<td>µs</td>
</tr>
</tbody>
</table>

Table 178: ADC Specifications (Continued)

Symbol | Parameter | Condition | Min | Typ | Max | Units   |
--------|-----------|-----------|-----|-----|-----|---------|
$R_S$   | External input resistance $R_S$ maximum formula: $\frac{1}{F_{ADC}} = \frac{4 \times \ln(2^{15})}{C_{ADC}} \times \left(\frac{R_{ADC} + R_{MUX}}{2}\right)$ | 2 MHz ADC operating clock without input buffer 16-bit settling accuracy | --   | --   | 8    | kΩ      |
|        | 2 MHz ADC operating clock with input buffer 16-bit settling accuracy | --   | --   | 46   | kΩ      |
| --      | Input frequency range                                                     | With input buffer                                                         | --   | 31   | --   | MHz     |
|         | Defined as input signal -3 dB bandwidth through analog path.             | Without input buffer                                                      | --   | 130  | --   | MHz     |
|         | **Conversion Rate (ADC main clock frequency is 64 MHz)**                 |                                                                           |      |      |      |         |
| --      | ADC sampling clock frequency                                             | Fast mode                                                                 | --   | 2    | --   | MHz     |
|         |                                                                           | Low-power mode                                                           | --   | 0.2  | 2    | MHz     |
| --      | Conversion time in ADC clocks                                            | 12-bit setting                                                           | --   | 1    | --   | clock cycles |
|         |                                                                           | 14-bit setting                                                           | --   | 11   | --   | clock cycles |
|         |                                                                           | 16-bit setting                                                           | --   | 35   | --   | clock cycles |
|         |                                                                           | 16-bit audio setting                                                     | --   | 131  | --   | clock cycles |
| --      | 1-shot latency (It is recommended to perform a calibration after each power-up.) | 16-bit audio setting @ 2 MHz                                             | 65.5 | --   | --   | µs      |
|         |                                                                           | 16-bit setting @ 2 MHz                                                   | 17.5 | --   | --   | µs      |
|         |                                                                           | 14-bit setting @ 2 MHz                                                   | 5.5  | --   | --   | µs      |
|         |                                                                           | 12-bit setting @ 2 MHz                                                   | 0.5  | --   | --   | µs      |
Table 178: ADC Specifications (Continued)

**NOTE:** Typical values: $T_A = 25^\circ$C, $V_{DDIO_3} = 3.3$V (for 1.8V <= $V_{DD}$ <= 3.6V voltage range), unless otherwise noted.

These are design guidelines and are based on bench characterization results and/or design simulation.

**Minimum and maximum values:** Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench.

Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Data rate</td>
<td>16-bit audio setting @ 2 MHz</td>
<td>--</td>
<td>15.27</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td>16-bit setting @ 2 MHz</td>
<td>--</td>
<td>57.14</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td>14-bit setting @ 2 MHz</td>
<td>--</td>
<td>181.81</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td>12-bit setting @ 2 MHz</td>
<td>--</td>
<td>2000</td>
<td>--</td>
<td>kHz</td>
</tr>
</tbody>
</table>

**DC Accuracy**

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Resolution</td>
<td>Single-ended</td>
<td>--</td>
<td>11</td>
<td>15</td>
<td>bits</td>
</tr>
<tr>
<td></td>
<td>Differential</td>
<td>--</td>
<td>12</td>
<td>16</td>
<td>bits</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Offset error</td>
<td>Before calibration 16-bit setting</td>
<td>--</td>
<td>±30</td>
<td>--</td>
<td>LSb</td>
</tr>
<tr>
<td></td>
<td>After calibration 16-bit setting</td>
<td>--</td>
<td>±4</td>
<td>--</td>
<td>LSb</td>
<td></td>
</tr>
</tbody>
</table>

**Dynamic Performance**

**SNDR**
- Signal-to-Noise and Distortion Ratio
  - With internal 1.22V reference, signal amplitude is 1.15Vp.
  - 1 kHz sine-wave differential input, 0 dB of full scale, 2 MHz ADC clock.
- 12-bit setting | -- | 64 | -- | dB |
- 14-bit setting | -- | 70 | -- | dB |
- 16-bit setting | -- | 76 | -- | dB |
- 16-bit audio setting | -- | 82 | -- | dB |

**Dynamic Range**
- With internal 1.22V reference, signal amplitude is 1mVp.
- 1 kHz sine-wave differential input, -60 dB of full scale, 4 MHz ADC clock.
- 12-bit setting | -- | 66 | -- | dB |
- 14-bit setting | -- | 72 | -- | dB |
- 16-bit setting | -- | 78 | -- | dB |
- 16-bit audio setting | -- | 84 | -- | dB |

**Warm-up Time**
Table 178: ADC Specifications (Continued)

NOTE: Typical values: $T_A = 25^\circ\text{C}, VDDIO_3 = 3.3\text{V}$ (for $1.8\text{V} \leq VDD \leq 3.6\text{V}$ voltage range), unless otherwise noted. These are design guidelines and are based on bench characterization results and/or design simulation.

Minimum and maximum values: Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench. Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$T_{\text{WARM}}$</td>
<td>Warm-up time of ADC and internal reference generator ($T_{\text{WARM}}$)</td>
<td>- Total warm-up time ($T_{\text{WARM}}$) depends on the current energy mode and ‘gpadc_timebase’ setting.</td>
<td>--</td>
<td>1</td>
<td>--</td>
<td>32</td>
</tr>
</tbody>
</table>
## 22.8.2 Temperature Sensor

### Table 179: ADC Temperature Sensor Specifications

**NOTE:** Typical values: $T_A = 25^\circ C$, $V_{DDIO_3} = 3.3V$ (for 1.8V <= $V_{DD}$ <= 3.6V voltage range), unless otherwise noted.

- These are design guidelines and are based on bench characterization results and/or design simulation.
- On-chip temperature can be measured by using the ADC with an internal voltage reference and 16-bit resolution setting.
- **Minimum and maximum values:** Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench.
- Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC main clock</td>
<td>FVCO = 128 MHz post divider ratio = 2 clk_div_ratio value = 4</td>
<td>--</td>
<td>16</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td>• See Table 36, VCO Frequency Select, on page 64 (128 MHz).</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>• See Table 37, AUPLL Post Divider Programming, on page 65 (ratio = 2).</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>• See Table 517, ADC General Register (adc_reg_general), on page 568 (clk_div_ratio value = 4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Internal reference voltage</td>
<td>--</td>
<td>1.20</td>
<td>1.22</td>
<td>1.23</td>
<td>V</td>
</tr>
<tr>
<td>ADC operating clock frequency</td>
<td>--</td>
<td>--</td>
<td>500</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td>Conversion time in ADC operating clocks</td>
<td>16-bit setting</td>
<td>--</td>
<td>131</td>
<td>--</td>
<td>clock cycles</td>
</tr>
<tr>
<td>Data rate</td>
<td>ADC main clock frequency is 16 MHz.</td>
<td>--</td>
<td>3.82</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td>Measurement latency</td>
<td>ADC main clock frequency is 16 MHz.</td>
<td>--</td>
<td>$262 + T_{WARM}$</td>
<td>--</td>
<td>µs</td>
</tr>
<tr>
<td></td>
<td>Total warm-up time ($T_{WARM}$) depends on the current energy mode and 'gpadc_timebase' setting.</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Resolution</td>
<td>$1\text{LSb}=1.2V/2^{15}$</td>
<td>--</td>
<td>0.15</td>
<td>--</td>
<td>°C/LSb</td>
</tr>
<tr>
<td>Measurement accuracy</td>
<td>Initial accuracy w/o calibration</td>
<td>--</td>
<td>±5</td>
<td>--</td>
<td>°C</td>
</tr>
<tr>
<td></td>
<td>1-temperature calibration</td>
<td>--</td>
<td>±3</td>
<td>--</td>
<td>°C</td>
</tr>
</tbody>
</table>
22.8.3 Battery Voltage Monitor

Table 180: ADC Battery Voltage Monitor Specifications

NOTE: Typical values: $T_A = 25°C$, $VDDIO_{3} = 3.3V$ (for $1.8V <= VDD <= 3.6V$ voltage range), unless otherwise noted.
These are design guidelines and are based on bench characterization results and/or design simulation.

Minimum and maximum values: Unless otherwise specified, the minimum and maximum values are guaranteed in
the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench.
Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3
times the standard deviation.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC main clock</td>
<td>• See Table 36, VCO Frequency Select, on page 64 (FVCO = 128 MHz).</td>
<td>FVCO = 128 MHz post divider ratio = 2</td>
<td>64</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td>• See Table 37, AUPLL Post Divider Programming, on page 65 (ratio = 2).</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Internal reference voltage</td>
<td>--</td>
<td>1.20</td>
<td>1.22</td>
<td>1.23</td>
<td>V</td>
</tr>
<tr>
<td>Data rate (ADC main clock frequency is 64 MHz.)</td>
<td>14-bit setting 2 MHz ADC operating clock</td>
<td>--</td>
<td>181.81</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td>Measurement latency</td>
<td>Total warm-up time ($T_{WARM}$) depends on the current energy mode and 'gpadc_timebase' setting.</td>
<td>14-bit setting 2 MHz ADC operating clock</td>
<td>--</td>
<td>5.5+$T_{WARM}$</td>
<td>µs</td>
</tr>
<tr>
<td>Measurement accuracy</td>
<td>Based on characterization, not tested in production.</td>
<td>Initial accuracy w/o calibration Internal Vref $T = -40°C$ to 125°C</td>
<td>-2</td>
<td>--</td>
<td>2%</td>
</tr>
</tbody>
</table>

22.8.4 Audio Mode

Table 181: ADC Audio Mode Specifications

NOTE: $T_A = 25°C$, $VDDIO_{3} = 3.3V$, $AVDD18 = 1.8V$, unless otherwise noted.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC main clock</td>
<td>• See Table 36, VCO Frequency Select, on page 64 (134.14 MHz).</td>
<td>FVCO = 134.14 MHz post divider ratio = 2</td>
<td>67.07</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td>• See Table 37, AUPLL Post Divider Programming, on page 65 (ratio = 2).</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADC operating clock frequency</td>
<td>--</td>
<td></td>
<td>2.1</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td>Conversion time in ADC operating clocks</td>
<td>16-bit audio setting</td>
<td></td>
<td>131</td>
<td>--</td>
<td>clock cycles</td>
</tr>
<tr>
<td>Data rate</td>
<td>2.1 MHz ADC operating clock</td>
<td>--</td>
<td>16</td>
<td>--</td>
<td>kHz</td>
</tr>
</tbody>
</table>

PGA Input

| Analog input voltage               | Any pin (in analog input mode)                                           | 0         | --     | AVDD18 | V     |
### Table 181: ADC Audio Mode Specifications (Continued)

NOTE: \( T_A = 25^\circ \text{C}, \ V_{DDIO_3} = 3.3\text{V}, \ AVDD_{18} = 1.8\text{V}, \) unless otherwise noted.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Maximum differential input signal swing</td>
<td>--</td>
<td>1.2 / PGA_Gain</td>
<td>--</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td>Common mode input range</td>
<td>For DC couple input</td>
<td>0.9</td>
<td>--</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td>Differential input impedance</td>
<td>PGA_GAIN = 4x</td>
<td>80</td>
<td>--</td>
<td>--</td>
<td>k(\Omega)</td>
</tr>
<tr>
<td></td>
<td>PGA_GAIN = 8x</td>
<td>40</td>
<td>--</td>
<td>--</td>
<td>k(\Omega)</td>
</tr>
<tr>
<td></td>
<td>PGA_GAIN = 16x</td>
<td>20</td>
<td>--</td>
<td>--</td>
<td>k(\Omega)</td>
</tr>
<tr>
<td></td>
<td>PGA_GAIN = 32x</td>
<td>10</td>
<td>--</td>
<td>--</td>
<td>k(\Omega)</td>
</tr>
<tr>
<td>Analog source resistance</td>
<td>--</td>
<td>100</td>
<td>--</td>
<td>--</td>
<td>(\Omega)</td>
</tr>
<tr>
<td>The analog signal source resistance should be kept as minimum as possible for PGA gain accuracy.</td>
<td>--</td>
<td>100</td>
<td>--</td>
<td>--</td>
<td>(\Omega)</td>
</tr>
</tbody>
</table>

#### PGA Performance

| PGA gain                          | ADC.AUDIO.PGA_GAIN = 3'b000 | 4     | --     | --     |       |
|                                  | ADC.AUDIO.PGA_GAIN = 3'b001 | 8     | --     | --     |       |
|                                  | ADC.AUDIO.PGA_GAIN = 3'b010 | 16    | --     | --     |       |
|                                  | ADC.AUDIO.PGA_GAIN = 3'b011 | 32    | --     | --     |       |
| ADC gain                         | --                         | PGA_Gain \* Input buffer_Gain | --     |       |
| The PGA must work together with the input buffer for sufficient driving capability. If the input buffer is bypass when PGA is on, distortion may occur. The total ADC gain is the multiplication of PGA gain and the input buffer gain \((0.5/1/2)\). | --                         | PGA_Gain \* Input buffer_Gain | --     |       |
| Input signal bandwidth           | --                         | --    | --     | 1      | MHz   |
| Gain switching settling time      | --                         | --    | --     | 10     | \(\mu\text{s}\) |
## 22.9 DAC Specifications

### Table 182: DAC Specifications

**NOTE:** Typical values: $T_A = 25 \degree C$, $VDDIO_3 = 3.3V$ (for 1.8V <= VDD <= 3.6V voltage range), unless otherwise noted. These are design guidelines and are based on bench characterization results and/or design simulation.

**Minimum and maximum values:** Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench. Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>DAC main clock</td>
<td>FVCO = 128 MHz post divider ratio = 2</td>
<td>--</td>
<td>64</td>
<td>--</td>
<td>MHz</td>
</tr>
<tr>
<td>Reference Voltage (Vref)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Internal reference voltage</td>
<td>gpdac_a_range[1:0]=11</td>
<td>--</td>
<td>1.42</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>gpdac_a_range[1:0]=10/01</td>
<td>--</td>
<td>1.01</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>gpdac_a_range[1:0]=00</td>
<td>--</td>
<td>0.64</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td>External reference voltage</td>
<td>gpdac_a_range[1:0]=11</td>
<td>--</td>
<td>Vref_ext*0.71</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>gpdac_a_range[1:0]=10/01</td>
<td>--</td>
<td>Vref_ext*0.505</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>gpdac_a_range[1:0]=00</td>
<td>--</td>
<td>Vref_ext*0.32</td>
<td>--</td>
<td>V</td>
</tr>
<tr>
<td>Externally supplied reference voltage (Vref_ext)</td>
<td>Ref_sel=1</td>
<td>1.5</td>
<td>--</td>
<td>2</td>
<td>V</td>
</tr>
<tr>
<td>Conversion Range</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Analog output range</td>
<td>Single ended</td>
<td>0.12</td>
<td>--</td>
<td>1.6</td>
<td>V</td>
</tr>
<tr>
<td>Output Load</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Resistive load (minimum resistive load between DAC output and VSS)</td>
<td>single-ended</td>
<td>5</td>
<td>--</td>
<td>--</td>
<td>kΩ</td>
</tr>
<tr>
<td></td>
<td>differential</td>
<td>5</td>
<td>--</td>
<td>--</td>
<td>kΩ</td>
</tr>
<tr>
<td>Capacitive load (maximum capacitive load at DAC output)</td>
<td>--</td>
<td>--</td>
<td>--</td>
<td>50</td>
<td>pF</td>
</tr>
<tr>
<td>Conversion Rate</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Conversion rate</td>
<td>clk_ctrl[1:0]=2'b11</td>
<td>--</td>
<td>500</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td>clk_ctrl[1:0]=2'b10</td>
<td>--</td>
<td>250</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td>clk_ctrl[1:0]=2'b01</td>
<td>--</td>
<td>125</td>
<td>--</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td>clk_ctrl[1:0]=2'b00 (default)</td>
<td>--</td>
<td>62.5</td>
<td>--</td>
<td>kHz</td>
</tr>
</tbody>
</table>
### Table 182: DAC Specifications (Continued)

**NOTE:** Typical values: $T_A = 25^\circ{\rm C}$, $V_{DDIO_3} = 3.3{\rm V}$ (for $1.8{\rm V} \leq V_{DD} \leq 3.6{\rm V}$ voltage range), unless otherwise noted. These are design guidelines and are based on bench characterization results and/or design simulation. **Minimum and maximum values:** Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench. Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>DC Accuracy</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Resolution</td>
<td>single-ended</td>
<td>--</td>
<td>--</td>
<td>10</td>
<td>bits</td>
</tr>
<tr>
<td></td>
<td>differential</td>
<td>--</td>
<td>--</td>
<td>10</td>
<td>bits</td>
</tr>
<tr>
<td>Differential nonlinearity (RMS)</td>
<td>Guaranteed monotonic, internal 1.2V reference</td>
<td>--</td>
<td>±0.5</td>
<td>--</td>
<td>Lb(^1)</td>
</tr>
<tr>
<td>Integral nonlinearity (best-fit method)</td>
<td>Internal reference</td>
<td>--</td>
<td>±2</td>
<td>--</td>
<td>Ls(b)</td>
</tr>
<tr>
<td>Offset error</td>
<td>a(<em>{range})=2'b11, internal (v</em>{ref}) (See Table 155, Output Voltage Calculation Formula, on page 258.) (difference between measured value at code 0x0 and the ideal value ((0.18{\rm V})))</td>
<td>--</td>
<td>20</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td>Gain error (after offset removal)</td>
<td>a(<em>{range})=2'b11, internal (v</em>{ref})</td>
<td>--</td>
<td>2</td>
<td>--</td>
<td>%</td>
</tr>
<tr>
<td>PSRR</td>
<td>Power supply rejection ratio (to AVDD18) (static DC measurement)</td>
<td>--</td>
<td>60</td>
<td>--</td>
<td>dB</td>
</tr>
</tbody>
</table>

1. \(1\text{ Ls}= \frac{V_{ref}}{1024}\)
### 22.10 ACOMP Specifications

Table 183: ACOMP Specifications

NOTE: Typical values: $T_A = 25^\circ C$, $VDDIO_3 = 3.3V$ (for $1.8V \leq VDD \leq 3.6V$ voltage range), unless otherwise noted.

These are design guidelines and are based on bench characterization results and/or design simulation.

Minimum and maximum values: Unless otherwise specified, the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage, and frequencies by tests on bench.

Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value ±3 times the standard deviation.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Analog Input</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>--</td>
<td>Analog input voltage</td>
<td>Any pin (in analog input mode)</td>
<td>0</td>
<td>--</td>
<td>VDDIO_3</td>
<td>V</td>
</tr>
<tr>
<td>--</td>
<td>Common mode input range</td>
<td>--</td>
<td>0</td>
<td>--</td>
<td>VDDIO_3</td>
<td>V</td>
</tr>
<tr>
<td><strong>Reference Voltage</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>--</td>
<td>Internal reference voltage</td>
<td>--</td>
<td>1.20</td>
<td>1.22</td>
<td>1.23</td>
<td>V</td>
</tr>
<tr>
<td><strong>Analog Response Time (no digital delay)</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>--</td>
<td>Fast response mode MODE 3, Vcm = 1.5V</td>
<td>Overdrive (COMP_P – COMP_N = ±100 mV)</td>
<td>--</td>
<td>130</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>--</td>
<td>Medium response mode MODE 2, Vcm = 1.5V</td>
<td>Overdrive (COMP_P – COMP_N = ±100 mV)</td>
<td>--</td>
<td>190</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>--</td>
<td>Slow response mode MODE 1, Vcm = 1.5V</td>
<td>Overdrive (COMP_P – COMP_N = ±100 mV)</td>
<td>--</td>
<td>450</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td><strong>DC Offset</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>--</td>
<td>Offset voltage</td>
<td>--</td>
<td>--</td>
<td>±14</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td>--</td>
<td>Hysteresis</td>
<td>Programmed in 7 steps and 0</td>
<td>--</td>
<td>10</td>
<td>--</td>
<td>mV</td>
</tr>
<tr>
<td>--</td>
<td></td>
<td></td>
<td>--</td>
<td>20</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>--</td>
<td></td>
<td></td>
<td></td>
<td>30</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>--</td>
<td></td>
<td></td>
<td></td>
<td>40</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>--</td>
<td></td>
<td></td>
<td></td>
<td>50</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>--</td>
<td></td>
<td></td>
<td></td>
<td>60</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td>--</td>
<td></td>
<td></td>
<td></td>
<td>70</td>
<td></td>
<td>mV</td>
</tr>
<tr>
<td><strong>Warm-up Time</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>T_WARM</td>
<td>Warm-up time of ACOMP and internal reference generator</td>
<td>$VDDIO_3 = 3.3V$</td>
<td>--</td>
<td>0.5</td>
<td>1.0</td>
<td>μs</td>
</tr>
<tr>
<td></td>
<td></td>
<td>$VDDIO_3 = 1.8V$</td>
<td>--</td>
<td>1.0</td>
<td>1.3</td>
<td>μs</td>
</tr>
</tbody>
</table>
22.11 AC Specifications

22.11.1 SSP Timing and Specifications

Figure 113: SSP Serial Frame Format Timing Diagram

Table 184: SSP Timing Data

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{\text{out(TX)}}$</td>
<td>TX delay time</td>
<td>master</td>
<td>--</td>
<td>--</td>
<td>3</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>slave</td>
<td>--</td>
<td>--</td>
<td>11.5</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{\text{hold(TX)}}$</td>
<td>TX hold time</td>
<td>master</td>
<td>0</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>slave</td>
<td>0</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{\text{su(RX)}}$</td>
<td>Setup time RX valid before clock low</td>
<td>master</td>
<td>12</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>slave</td>
<td>4</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{\text{h(RX)}}$</td>
<td>Hold time, RX data valid after clock low</td>
<td>master</td>
<td>0</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>slave</td>
<td>2</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{\text{cyc}}$</td>
<td>Serial bit clock cycle time</td>
<td>master</td>
<td>40</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>slave</td>
<td>40</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{w}$</td>
<td>Serial clock high/low time</td>
<td>master</td>
<td>$\frac{T_{\text{cyc}}}{2} - 0.5$</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td>slave</td>
<td>$\frac{T_{\text{cyc}}}{2} - 0.5$</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
</tbody>
</table>
22.11.2 QSPI Timing and Specifications

Figure 114: QSPI Timing Diagram (Normal)

Note: When the [CLK_CAPT_EDGE] = 1'b1, the interface clock frequency can be up to 50 MHz. \( t_{cy} = 20 \text{ ns} \). Used only in mode[0,0) and mode(1,0).

Figure 115: QSPI Timing Diagram (Use Second Clock Capture Edge)

Note: When the [CLK_CAPT_EDGE] = 1'b1, the interface clock frequency can be up to 50 MHz. \( t_{cy} = 20 \text{ ns} \). Used only in mode[0,0) and mode(1,0).
Table 185: QSPI Timing Data
NOTE: Capacitive load C=5 pF. Minimum annotated transition = 0.5 ns. Maximum annotated transition=1.5 ns.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>tcyc</td>
<td>QSPI clock cycle time</td>
<td>master</td>
<td>40</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>tw</td>
<td>Clock high and low time</td>
<td>master</td>
<td>$\frac{t_{\text{SYS}}}{2} - 0.5$</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>tsu(RX)</td>
<td>Data input setup time</td>
<td>master</td>
<td>8</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>th(RX)</td>
<td>Data input hold time</td>
<td>master</td>
<td>0</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
<tr>
<td>tout(TX)</td>
<td>Data output delay time</td>
<td>master</td>
<td>--</td>
<td>--</td>
<td>7</td>
<td>ns</td>
</tr>
<tr>
<td>thold(TX)</td>
<td>TX hold time</td>
<td>master</td>
<td>0</td>
<td>--</td>
<td>--</td>
<td>ns</td>
</tr>
</tbody>
</table>

22.11.3 USB Timing and Specifications

Figure 116: USB Timing Diagram

Table 186: USB Timing Data

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>VBUS</td>
<td>High-power pin</td>
<td>--</td>
<td>4.75</td>
<td>--</td>
<td>5.25</td>
<td>V</td>
</tr>
<tr>
<td>VBUS</td>
<td>Low-power pin</td>
<td>--</td>
<td>4.40</td>
<td>--</td>
<td>5.25</td>
<td>V</td>
</tr>
</tbody>
</table>

Input Level for High Speed

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vhssq</td>
<td>High-speed squelch detection</td>
<td>threshold</td>
<td>100</td>
<td>--</td>
<td>150</td>
<td>mV</td>
</tr>
<tr>
<td>Vhdsc</td>
<td>High-speed disconnect detection</td>
<td>threshold</td>
<td>525</td>
<td>--</td>
<td>625</td>
<td>mV</td>
</tr>
<tr>
<td>Vhscm</td>
<td>High-speed data signaling</td>
<td>common mode voltage range</td>
<td>-50</td>
<td>--</td>
<td>500</td>
<td>mV</td>
</tr>
</tbody>
</table>

Input Level for Low/Full Speed

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vih</td>
<td>High (driven)</td>
<td>Measured at A or B connector</td>
<td>2</td>
<td>--</td>
<td>--</td>
<td>V</td>
</tr>
</tbody>
</table>
**Table 186: USB Timing Data (Continued)**

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vihz</td>
<td>High (floating)</td>
<td>Measured at A or B connector</td>
<td>2.7</td>
<td>--</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>Vll</td>
<td>Low</td>
<td>Measured at A or B connector</td>
<td>--</td>
<td>--</td>
<td>0.8</td>
<td>V</td>
</tr>
</tbody>
</table>

**Output Level for High Speed**

| Vhsol  | High-speed idle level      | --                                      | --  | --  | -10.0| mV    |
| Vhsoh  | High-speed data signaling high | --                                      | 360 | --  | 440  | mV    |
| Vhsol  | High-speed data signaling low | --                                      | --  | --  | 10.0 | mV    |
| Vchirpj | Chirp J level              | --                                      | 700 | --  | 1100 | mV    |
| Vchirpk | Chirp K level              | --                                      | --  | --  | -900 | mV    |

**Output Level for Low/Full Speed**

| Vll    | Low                       | Measured with RL of 1.425k to 3.6V     | 0.0 | --  | 0.3  | V     |
| Vlh    | High (driven)             | Measured with RL of 14.25k to ground    | 2.8 | --  | 3.6  | V     |
| Vcrs   | Output signal crossover voltage | Excluding first transition from Idle state | 1.3 | --  | 2.0  | V     |

**High-Speed Source Electrical Characteristics**

| Thsr   | Rise time                | --                                      | 500 | --  | --   | ps    |
| Thsf   | Fall time                | --                                      | 500 | --  | --   | ps    |

**Full-Speed Source Electrical Characteristics**

| Tfr    | Rise time                | --                                      | 4   | --  | 20   | ns    |
| Tff    | Fall time                | --                                      | 4   | --  | 20   | ns    |
| Tfrfm  | Rise and fall time matching | Tfr/Tff                                 | 90  | --  | 111.11 | %    |

**Low-Speed Source Electrical Characteristics**

| Tlr    | Rise time                | --                                      | 75  | --  | 300  | ns    |
| Tlf    | Fall time                | --                                      | 75  | --  | 300  | ns    |
| Tlrfm  | Rise and fall time matching | Tlr/Tlf                                 | 80  | --  | 125  | %     |
22.11.4  RESETn Pin Specification

Table 187: RESETn Pin Specification

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Minimum reset pulse width on RESETn pin</td>
<td></td>
<td>80</td>
<td></td>
<td></td>
<td>μs</td>
</tr>
</tbody>
</table>

22.12  WLAN Radio Specifications

The 88MW320/322 WLAN radio interface pin is powered from the AVDD33 voltage supply.

22.12.1  Receive Mode Specifications

Table 188: LNA and Rx RF Mixer Specifications—802.11n/g/b

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>RF frequency range</td>
<td>2.4 GHz—IEEE 802.11n/g/b</td>
<td>2400</td>
<td></td>
<td>2500</td>
<td>MHz</td>
</tr>
<tr>
<td>Rx input IP3 at RF high gain (In-Band)</td>
<td>Rx input IP3 when LNA in high gain mode (24 dB) at chip input</td>
<td>--</td>
<td>-15</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>Maximum input level (802.11b, 1 Mbps)</td>
<td></td>
<td>--</td>
<td>--</td>
<td>0</td>
<td>dBm</td>
</tr>
<tr>
<td>Maximum input level (802.11g, 54 Mbps)</td>
<td></td>
<td>--</td>
<td>--</td>
<td>-3</td>
<td>dBm</td>
</tr>
<tr>
<td>Maximum input level (802.11n, MCS7)</td>
<td></td>
<td>--</td>
<td>--</td>
<td>-6</td>
<td>dBm</td>
</tr>
</tbody>
</table>

Maximum Receive Sensitivity

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>802.11b, 1 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11b, 2 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11b, 5.5 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11b, 11 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 6 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 9 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 12 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 18 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 24 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 36 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 48 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 54 Mbps</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS0</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS1</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS2</td>
<td></td>
<td></td>
<td></td>
<td>dBm</td>
</tr>
</tbody>
</table>
Table 188: LNA and Rx RF Mixer Specifications—802.11n/g/b (Continued)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>802.11n, MCS3</td>
<td>--</td>
<td>--</td>
<td>-82.5</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS4</td>
<td>--</td>
<td>--</td>
<td>-79</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS5</td>
<td>--</td>
<td>--</td>
<td>-74.5</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS6</td>
<td>--</td>
<td>--</td>
<td>-73</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS7</td>
<td>--</td>
<td>--</td>
<td>-71.5</td>
<td>--</td>
<td>dBm</td>
</tr>
</tbody>
</table>

1. The receive sensitivity is measured at the RF pin of the Wireless SoC.

22.12.2 Transmit Mode Specifications

Table 189: Tx Mode Specifications—802.11n/g/b

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>RF frequency range</td>
<td>2.4 GHz—IEEE 802.11n/g/b</td>
<td>2400</td>
<td>--</td>
<td>2500</td>
<td>MHz</td>
</tr>
<tr>
<td>Tx output saturation power at chip output</td>
<td>2.4 GHz—IEEE 802.11n/g/b</td>
<td>--</td>
<td>26</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>Tx carrier suppression (CW)</td>
<td>Carrier suppression at chip output</td>
<td>--</td>
<td>-36</td>
<td>--</td>
<td>dB</td>
</tr>
<tr>
<td>Tx I/Q suppression with IQ calibration</td>
<td>I/Q suppression at chip output</td>
<td>--</td>
<td>-45</td>
<td>--</td>
<td>dBc</td>
</tr>
</tbody>
</table>

Tx power with mask and EVM compliance to IEEE limits—normal power mode

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>802.11b, 1 Mbps</td>
<td>17</td>
<td>19</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 6 Mbps</td>
<td>17</td>
<td>19</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 54 Mbps</td>
<td>16</td>
<td>18</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS0</td>
<td>17</td>
<td>19</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS7</td>
<td>16</td>
<td>18</td>
<td>--</td>
<td>dBm</td>
</tr>
</tbody>
</table>

Tx power with mask and EVM compliance to IEEE limits—low power mode

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>802.11b, 1 Mbps</td>
<td>10</td>
<td>11</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 6 Mbps</td>
<td>10</td>
<td>11</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11g, 54 Mbps</td>
<td>10</td>
<td>11</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS0</td>
<td>10</td>
<td>11</td>
<td>--</td>
<td>dBm</td>
</tr>
<tr>
<td>802.11n, MCS7</td>
<td>10</td>
<td>11</td>
<td>--</td>
<td>dBm</td>
</tr>
</tbody>
</table>
## 22.12.3 Local Oscillator Specifications

Table 190: Local Oscillator Specifications

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Phase noise</td>
<td>Measured at 2.438 GHz at 100 kHz offset</td>
<td>--</td>
<td>-103</td>
<td>--</td>
<td>dBc/Hz</td>
</tr>
<tr>
<td>Integrated RMS phase noise at RF output</td>
<td>Reference clock frequency = 38.4 MHz (2.4 GHz)</td>
<td>--</td>
<td>0.6</td>
<td>--</td>
<td>degrees</td>
</tr>
<tr>
<td>Frequency resolution</td>
<td>--</td>
<td>0.02</td>
<td>--</td>
<td>--</td>
<td>kHz</td>
</tr>
</tbody>
</table>
23 Ordering Information/Package Marking

23.1 Ordering Information

Refer to NXP Field Application Engineers (FAEs) or representatives for further information when ordering parts.

Figure 117: Part Numbering Scheme

![Part Numbering Scheme Diagram]

Table 191: Part Order Options

<table>
<thead>
<tr>
<th>Package Type</th>
<th>Part Order Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>88MW320</td>
<td></td>
</tr>
<tr>
<td>68-pin QFN (tray)</td>
<td>88MW320-A0-NAPC/AK</td>
</tr>
<tr>
<td>68-pin QFN (tape-and-reel)</td>
<td>88MW320-A0-NAPC/AZ</td>
</tr>
<tr>
<td>68-pin QFN (tray)</td>
<td>88MW320-A0-NAPE/AK</td>
</tr>
<tr>
<td>68-pin QFN (tape-and-reel)</td>
<td>88MW320-A0-NAPE/AZ</td>
</tr>
<tr>
<td>68-pin QFN (tray)</td>
<td>88MW320-A0-NAPI/AK</td>
</tr>
<tr>
<td>68-pin QFN (tape-and-reel)</td>
<td>88MW320-A0-NAPI/AZ</td>
</tr>
<tr>
<td>88MW322</td>
<td></td>
</tr>
<tr>
<td>88-pin QFN (tray)</td>
<td>88MW322-A0-NXUC/AK</td>
</tr>
<tr>
<td>88-pin QFN (tape-and-reel)</td>
<td>88MW322-A0-NXUC/AZ</td>
</tr>
<tr>
<td>88-pin QFN (tray)</td>
<td>88MW322-A0-NXUE/AK</td>
</tr>
<tr>
<td>88-pin QFN (tape-and-reel)</td>
<td>88MW322-A0-NXUE/AZ</td>
</tr>
<tr>
<td>88-pin QFN (tray)</td>
<td>88MW322-A0-NXUI/AK</td>
</tr>
<tr>
<td>88-pin QFN (tape-and-reel)</td>
<td>88MW322-A0-NXUI/AZ</td>
</tr>
</tbody>
</table>

1. See Table 159, Recommended Operating Conditions, on page 270 for supported temperature ranges.
23.2 Package Marking

Figure 118 shows a sample package marking and pin 1 location for the 88MW320 device.

Figure 118: Package Marking and Pin 1 Location—88MW320

Note: The above drawing is not drawn to scale. Location of markings is approximate.

Figure 119 shows a sample package marking and pin 1 location for the 88MW322 device.

Figure 119: Package Marking and Pin 1 Location—88MW322

Note: The above drawing is not drawn to scale. Location of markings is approximate.
# 88MW320/322 Register Set

## 24.1 Overall Memory Map

Table 192: Overall Memory Map

<table>
<thead>
<tr>
<th>Register Block</th>
<th>Register Name</th>
<th>Base Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMA</td>
<td>DMAC Address Block</td>
<td>0x4400_0000</td>
</tr>
<tr>
<td>USBC</td>
<td>USBC Address Block</td>
<td>0x4400_1000</td>
</tr>
<tr>
<td>FlashC</td>
<td>Flash Controller Address Block</td>
<td>0x4400_3000</td>
</tr>
<tr>
<td>AES</td>
<td>AES Address Block</td>
<td>0x4404_0000</td>
</tr>
<tr>
<td>CRC</td>
<td>CRC Address Block</td>
<td>0x4404_5000</td>
</tr>
<tr>
<td>I2C0</td>
<td>I2C Address Block</td>
<td>0x4600_0000</td>
</tr>
<tr>
<td>QSPI</td>
<td>QSPI Address Block</td>
<td>0x4601_0000</td>
</tr>
<tr>
<td>SSP0</td>
<td>SSP Address Block</td>
<td>0x4602_0000</td>
</tr>
<tr>
<td>UART0</td>
<td>UART Address Block</td>
<td>0x4604_0000</td>
</tr>
<tr>
<td>GPIO</td>
<td>GPIO Address Block</td>
<td>0x4606_0000</td>
</tr>
<tr>
<td>GPT0</td>
<td>GPT Address Block</td>
<td>0x4607_0000</td>
</tr>
<tr>
<td>GPT1</td>
<td>GPT Address Block</td>
<td>0x4608_0000</td>
</tr>
<tr>
<td>--</td>
<td>Reserved</td>
<td>0x4609_0000</td>
</tr>
<tr>
<td>RC32</td>
<td>RC32 Address Block</td>
<td>0x460A_0000</td>
</tr>
<tr>
<td>ADC</td>
<td>ADC Address Block</td>
<td>0x460B_0000</td>
</tr>
<tr>
<td>DAC</td>
<td>DAC Address Block</td>
<td>0x460B_0200</td>
</tr>
<tr>
<td>ACOMP</td>
<td>ACOMP Address Block</td>
<td>0x460B_0400</td>
</tr>
<tr>
<td>UART1</td>
<td>UART Address Block</td>
<td>0x460C_0000</td>
</tr>
<tr>
<td>SSP1</td>
<td>SSP Address Block</td>
<td>0x460D_0000</td>
</tr>
<tr>
<td>SSP2</td>
<td>SSP Address Block</td>
<td>0x4800_0000</td>
</tr>
<tr>
<td>Pin Mux</td>
<td>PINMUX Address Block</td>
<td>0x4801_0000</td>
</tr>
<tr>
<td>UART2</td>
<td>UART Address Block</td>
<td>0x4802_0000</td>
</tr>
<tr>
<td>WDT</td>
<td>WDT Address Block</td>
<td>0x4804_0000</td>
</tr>
<tr>
<td>I2C1</td>
<td>I2C Address Block</td>
<td>0x4805_0000</td>
</tr>
<tr>
<td>Reserved</td>
<td>Reserved</td>
<td>0x4806_0000</td>
</tr>
<tr>
<td>GPT2</td>
<td>GPT Address Block</td>
<td>0x4807_0000</td>
</tr>
<tr>
<td>GPT3</td>
<td>GPT Address Block</td>
<td>0x4808_0000</td>
</tr>
<tr>
<td>RTC</td>
<td>RTC Address Block</td>
<td>0x4809_0000</td>
</tr>
<tr>
<td>PMU</td>
<td>PMU Address Block</td>
<td>0x480A_0000</td>
</tr>
<tr>
<td>SYS_CTL</td>
<td>System Control Address Block</td>
<td>0x480B_0000</td>
</tr>
<tr>
<td>4k_MEM</td>
<td>4k_MEM</td>
<td>0x480C_0000</td>
</tr>
</tbody>
</table>
## 24.2 DMAC Address Block

### 24.2.1 DMAC Register Map

Table 193: DMAC Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x000</td>
<td>MASK_BLOCKINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Block Transfer Interrupt Mask Register</td>
<td>Page: 311</td>
</tr>
<tr>
<td>0x004</td>
<td>STATUS_BLOCKINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Block Transfer Interrupt Register</td>
<td>Page: 315</td>
</tr>
<tr>
<td>0x008</td>
<td>MASK_TFRINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Transfer Completion Interrupt Mask Register</td>
<td>Page: 319</td>
</tr>
<tr>
<td>0x00C</td>
<td>STATUS_TFRINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Transfer Completion Interrupt Register</td>
<td>Page: 324</td>
</tr>
<tr>
<td>0x010</td>
<td>MASK_BUSERRINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Bus Error Interrupt Mask Register</td>
<td>Page: 327</td>
</tr>
<tr>
<td>0x014</td>
<td>STATUS_BUSERRINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Bus Error Interrupt Mask Register</td>
<td>Page: 331</td>
</tr>
<tr>
<td>0x018</td>
<td>MASK_ADDRERRINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Source/target Address Alignment Error Interrupt Mask Register</td>
<td>Page: 336</td>
</tr>
<tr>
<td>0x01C</td>
<td>STATUS_ADDRERRINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Source/target Address Alignment Error Interrupt Register</td>
<td>Page: 341</td>
</tr>
<tr>
<td>0x020</td>
<td>STATUS_CHLINT</td>
<td>0x0000_0000</td>
<td>DMA Channel Interrupt Register</td>
<td>Page: 345</td>
</tr>
<tr>
<td>0x080</td>
<td>HPROT</td>
<td>0x0000_0003</td>
<td>Protection Control Signals Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x100</td>
<td>SADR0</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x104</td>
<td>TADR0</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x108</td>
<td>CTRLA0</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x10C</td>
<td>CTRLB0</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x110</td>
<td>CHL_EN0</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x114</td>
<td>CHL_STOP0</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x130</td>
<td>SADR1</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x134</td>
<td>TADR1</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x138</td>
<td>CTRLA1</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x13C</td>
<td>CTRLB1</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x140</td>
<td>CHL_EN1</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x144</td>
<td>CHL_STOP1</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x160</td>
<td>SADR2</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x164</td>
<td>TADR2</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
</tbody>
</table>
### Table 193: DMAC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x168</td>
<td>CTRLA2</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x16C</td>
<td>CTRLB2</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x170</td>
<td>CHL_EN2</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x174</td>
<td>CHL_STOP2</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x190</td>
<td>SADR3</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x194</td>
<td>TADR3</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x198</td>
<td>CTRLA3</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x19C</td>
<td>CTRLB3</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x1A0</td>
<td>CHL_EN3</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x1A4</td>
<td>CHL_STOP3</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x1C0</td>
<td>SADR4</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x1C4</td>
<td>TADR4</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x1C8</td>
<td>CTRLA4</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x1CC</td>
<td>CTRLB4</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x1D0</td>
<td>CHL_EN4</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x1D4</td>
<td>CHL_STOP4</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x1F0</td>
<td>SADR5</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x1F4</td>
<td>TADR5</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x1F8</td>
<td>CTRLA5</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x1FC</td>
<td>CTRLB5</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x200</td>
<td>CHL_EN5</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x204</td>
<td>CHL_STOP5</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x220</td>
<td>SADR6</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x224</td>
<td>TADR6</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x228</td>
<td>CTRLA6</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x22C</td>
<td>CTRLB6</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x230</td>
<td>CHL_EN6</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x234</td>
<td>CHL_STOP6</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x250</td>
<td>SADR7</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x254</td>
<td>TADR7</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x258</td>
<td>CTRLA7</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>Offset</td>
<td>Name</td>
<td>HW Rst</td>
<td>Description</td>
<td>Details</td>
</tr>
<tr>
<td>--------</td>
<td>----------</td>
<td>--------------</td>
<td>--------------------------------------------------</td>
<td>-----------</td>
</tr>
<tr>
<td>0x25C</td>
<td>CTRLB7</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x260</td>
<td>CHL_EN7</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x264</td>
<td>CHL_STOP7</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x280</td>
<td>SADR8</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x284</td>
<td>TADR8</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x288</td>
<td>CTRLA8</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x28C</td>
<td>CTRLB8</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x290</td>
<td>CHL_EN8</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x294</td>
<td>CHL_STOP8</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x2B0</td>
<td>SADR9</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x2B4</td>
<td>TADR9</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x2B8</td>
<td>CTRLA9</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x2BC</td>
<td>CTRLB9</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x2C0</td>
<td>CHL_EN9</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x2C4</td>
<td>CHL_STOP9</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x2E0</td>
<td>SADR10</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x2E4</td>
<td>TADR10</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x2E8</td>
<td>CTRLA10</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x2EC</td>
<td>CTRLB10</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x2F0</td>
<td>CHL_EN10</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x2F4</td>
<td>CHL_STOP10</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x310</td>
<td>SADR11</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x314</td>
<td>TADR11</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x318</td>
<td>CTRLA11</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x31C</td>
<td>CTRLB11</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x320</td>
<td>CHL_EN11</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x324</td>
<td>CHL_STOP11</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x340</td>
<td>SADR12</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x344</td>
<td>TADR12</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x348</td>
<td>CTRLA12</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x34C</td>
<td>CTRLB12</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
</tbody>
</table>
### Table 193: DMAC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x350</td>
<td>CHL_EN12</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x354</td>
<td>CHL_STOP12</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x370</td>
<td>SADR13</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x374</td>
<td>TADR13</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x378</td>
<td>CTRLA13</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x37C</td>
<td>CTRLB13</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x380</td>
<td>CHL_EN13</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x384</td>
<td>CHL_STOP13</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x3A0</td>
<td>SADR14</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x3A4</td>
<td>TADR14</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x3A8</td>
<td>CTRLA14</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x3AC</td>
<td>CTRLB14</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x3B0</td>
<td>CHL_EN14</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x3B4</td>
<td>CHL_STOP14</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x3D0</td>
<td>SADR15</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x3D4</td>
<td>TADR15</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x3D8</td>
<td>CTRLA15</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x3DC</td>
<td>CTRLB15</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x3E0</td>
<td>CHL_EN15</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x3E4</td>
<td>CHL_STOP15</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x400</td>
<td>SADR16</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x404</td>
<td>TADR16</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x408</td>
<td>CTRLA16</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x40C</td>
<td>CTRLB16</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x410</td>
<td>CHL_EN16</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x414</td>
<td>CHL_STOP16</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x430</td>
<td>SADR17</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x434</td>
<td>TADR17</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x438</td>
<td>CTRLA17</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x43C</td>
<td>CTRLB17</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x440</td>
<td>CHL_EN17</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
</tbody>
</table>
Table 193: DMAC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x444</td>
<td>CHL_STOP17</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x460</td>
<td>SADR18</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x464</td>
<td>TADR18</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x468</td>
<td>CTRLA18</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x46C</td>
<td>CTRLB18</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x470</td>
<td>CHL_EN18</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x474</td>
<td>CHL_STOP18</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x490</td>
<td>SADR19</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x494</td>
<td>TADR19</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x498</td>
<td>CTRLA19</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x49C</td>
<td>CTRLB19</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x4A0</td>
<td>CHL_EN19</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x4A4</td>
<td>CHL_STOP19</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x4C0</td>
<td>SADR20</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x4C4</td>
<td>TADR20</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x4C8</td>
<td>CTRLA20</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x4CC</td>
<td>CTRLB20</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x4D0</td>
<td>CHL_EN20</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x4D4</td>
<td>CHL_STOP20</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x4F0</td>
<td>SADR21</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x4F4</td>
<td>TADR21</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x4F8</td>
<td>CTRLA21</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x4FC</td>
<td>CTRLB21</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x500</td>
<td>CHL_EN21</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x504</td>
<td>CHL_STOP21</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x520</td>
<td>SADR22</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x524</td>
<td>TADR22</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x528</td>
<td>CTRLA22</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x52C</td>
<td>CTRLB22</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x530</td>
<td>CHL_EN22</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x534</td>
<td>CHL_STOP22</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
</tbody>
</table>
### Table 193: DMAC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x550</td>
<td>SADR23</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x554</td>
<td>TADR23</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x558</td>
<td>CTRLA23</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x55C</td>
<td>CTRLB23</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x560</td>
<td>CHL_EN23</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x564</td>
<td>CHL_STOP23</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x580</td>
<td>SADR24</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x584</td>
<td>TADR24</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x588</td>
<td>CTRLA24</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x58C</td>
<td>CTRLB24</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x590</td>
<td>CHL_EN24</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x594</td>
<td>CHL_STOP24</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x5B0</td>
<td>SADR25</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x5B4</td>
<td>TADR25</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x5B8</td>
<td>CTRLA25</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x5BC</td>
<td>CTRLB25</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x5C0</td>
<td>CHL_EN25</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x5C4</td>
<td>CHL_STOP25</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x5E0</td>
<td>SADR26</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x5E4</td>
<td>TADR26</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x5E8</td>
<td>CTRLA26</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x5EC</td>
<td>CTRLB26</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x5F0</td>
<td>CHL_EN26</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x5F4</td>
<td>CHL_STOP26</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x610</td>
<td>SADR27</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x614</td>
<td>TADR27</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x618</td>
<td>CTRLA27</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x61C</td>
<td>CTRLB27</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x620</td>
<td>CHL_EN27</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x624</td>
<td>CHL_STOP27</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x640</td>
<td>SADR28</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>Offset</td>
<td>Name</td>
<td>HW Rst</td>
<td>Description</td>
<td>Details</td>
</tr>
<tr>
<td>--------</td>
<td>---------------</td>
<td>-----------</td>
<td>--------------------------------------------</td>
<td>---------------</td>
</tr>
<tr>
<td>0x644</td>
<td>TADR28</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x648</td>
<td>CTRLA28</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x64C</td>
<td>CTRLB28</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x650</td>
<td>CHL_EN28</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x654</td>
<td>CHL_STOP28</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x670</td>
<td>SADR29</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x674</td>
<td>TADR29</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x678</td>
<td>CTRLA29</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x67C</td>
<td>CTRLB29</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x680</td>
<td>CHL_EN29</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x684</td>
<td>CHL_STOP29</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x6A0</td>
<td>SADR30</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x6A4</td>
<td>TADR30</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x6A8</td>
<td>CTRLA30</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x6AC</td>
<td>CTRLB30</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x6B0</td>
<td>CHL_EN30</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x6B4</td>
<td>CHL_STOP30</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x6D0</td>
<td>SADR31</td>
<td>0x0000_0000</td>
<td>DMA Source Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x6D4</td>
<td>TADR31</td>
<td>0x0000_0000</td>
<td>DMA Target Address Register</td>
<td>Page: 348</td>
</tr>
<tr>
<td>0x6D8</td>
<td>CTRLA31</td>
<td>0x0000_0000</td>
<td>DMA Control Register A</td>
<td>Page: 349</td>
</tr>
<tr>
<td>0x6DC</td>
<td>CTRLB31</td>
<td>0x0000_0000</td>
<td>DMA Control Register B</td>
<td>Page: 350</td>
</tr>
<tr>
<td>0x6E0</td>
<td>CHL_EN31</td>
<td>0x0000_0000</td>
<td>DMA Channel Enable Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x6E4</td>
<td>CHL_STOP31</td>
<td>0x0000_0000</td>
<td>DMA Channel Stop Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x800</td>
<td>ACK_DELAY</td>
<td>0x0000_0000C</td>
<td>DMA Ack Delay Cycle For Single Transfer In M2p Transfer Type Register</td>
<td>Page: 351</td>
</tr>
<tr>
<td>0x900</td>
<td>ERR_INFO0</td>
<td>0x0000_0000</td>
<td>DMA Error Information Register 0</td>
<td>Page: 352</td>
</tr>
<tr>
<td>0x904</td>
<td>ERR_INFO1</td>
<td>0x0000_0000</td>
<td>DMA Error Information Register 1</td>
<td>Page: 352</td>
</tr>
<tr>
<td>0x908</td>
<td>DIAGNOSE_INFO0</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 0</td>
<td>Page: 353</td>
</tr>
<tr>
<td>0x90C</td>
<td>DIAGNOSE_INFO1</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 1</td>
<td>Page: 353</td>
</tr>
<tr>
<td>0x910</td>
<td>DIAGNOSE_INFO2</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 2</td>
<td>Page: 353</td>
</tr>
<tr>
<td>0x914</td>
<td>DIAGNOSE_INFO3</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 3</td>
<td>Page: 354</td>
</tr>
</tbody>
</table>
24.2.2 DMAC Registers

24.2.2.1 DMA Channel BLOCK TRANSFER INTERRUPT MASK Register (MASK_BLOCKINT)

Table 193: DMAC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x918</td>
<td>DIAGNOSE_INFO4</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 4</td>
<td>Page: 354</td>
</tr>
<tr>
<td>0x91C</td>
<td>DIAGNOSE_INFO5</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 5</td>
<td>Page: 354</td>
</tr>
<tr>
<td>0x920</td>
<td>DIAGNOSE_INFO6</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 6</td>
<td>Page: 355</td>
</tr>
<tr>
<td>0x924</td>
<td>DIAGNOSE_INFO7</td>
<td>0x0000_0000</td>
<td>DMA Diagnose Information Register 7</td>
<td>Page: 356</td>
</tr>
</tbody>
</table>

Table 194: DMA Channel BLOCK TRANSFER INTERRUPT MASK Register (MASK_BLOCKINT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>mask_blockint31</td>
<td>R/W 0x0</td>
<td>DMA Channel 31 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT31 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>30</td>
<td>mask_blockint30</td>
<td>R/W 0x0</td>
<td>DMA Channel 30 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT30 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>29</td>
<td>mask_blockint29</td>
<td>R/W 0x0</td>
<td>DMA Channel 29 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT29 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>28</td>
<td>mask_blockint28</td>
<td>R/W 0x0</td>
<td>DMA Channel 28 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT28 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>27</td>
<td>mask_blockint27</td>
<td>R/W 0x0</td>
<td>DMA Channel 27 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT27 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
</tbody>
</table>
### Table 194: DMA Channel BLOCK TRANSFER INTERRUPT MASK Register (MASK_BLOCKINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>26</td>
<td>mask_blockint26</td>
<td>R/W 0x0</td>
<td>DMA Channel 26 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT26 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>25</td>
<td>mask_blockint25</td>
<td>R/W 0x0</td>
<td>DMA Channel 25 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT25 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>24</td>
<td>mask_blockint24</td>
<td>R/W 0x0</td>
<td>DMA Channel 24 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT24 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>23</td>
<td>mask_blockint23</td>
<td>R/W 0x0</td>
<td>DMA Channel 23 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT23 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>22</td>
<td>mask_blockint22</td>
<td>R/W 0x0</td>
<td>DMA Channel 22 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT22 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>21</td>
<td>mask_blockint21</td>
<td>R/W 0x0</td>
<td>DMA Channel 21 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT21 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>20</td>
<td>mask_blockint20</td>
<td>R/W 0x0</td>
<td>DMA Channel 20 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT20 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>19</td>
<td>mask_blockint19</td>
<td>R/W 0x0</td>
<td>DMA Channel 19 Block Transfer Interrupt Mask Bit This bit enables the interrupt when STATUS_BLOCKINT19 bit in STATUS_BLOCKINT is set. 0x0 = mask the corresponding block interrupt 0x1 = unmask the corresponding block interrupt</td>
</tr>
</tbody>
</table>
Table 194: DMA Channel BLOCK TRANSFER INTERRUPT MASK Register (MASK_BLOCKINT)  
(Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 18   | mask_blockint18 | R/W 0x0      | DMA Channel 18 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT18 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
| 17   | mask_blockint17 | R/W 0x0      | DMA Channel 17 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT17 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
| 16   | mask_blockint16 | R/W 0x0      | DMA Channel 16 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT16 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
| 15   | mask_blockint15 | R/W 0x0      | DMA Channel 15 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT15 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
| 14   | mask_blockint14 | R/W 0x0      | DMA Channel 14 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT14 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
| 13   | mask_blockint13 | R/W 0x0      | DMA Channel 13 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT13 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
| 12   | mask_blockint12 | R/W 0x0      | DMA Channel 12 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT12 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
| 11   | mask_blockint11 | R/W 0x0      | DMA Channel 11 Block Transfer Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BLOCKINT11 bit in STATUS_BLOCKINT is set.  
0x0 = mask the corresponding block interrupt  
0x1 = unmask the corresponding block interrupt |
Table 194: DMA Channel BLOCK TRANSFER INTERRUPT MASK Register (MASK BLOCKINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>mask_blockint10</td>
<td>R/W 0x0</td>
<td>DMA Channel 10 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT10 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>9</td>
<td>mask_blockint9</td>
<td>R/W 0x0</td>
<td>DMA Channel 9 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT9 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>8</td>
<td>mask_blockint8</td>
<td>R/W 0x0</td>
<td>DMA Channel 8 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT8 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>7</td>
<td>mask_blockint7</td>
<td>R/W 0x0</td>
<td>DMA Channel 7 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT7 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>6</td>
<td>mask_blockint6</td>
<td>R/W 0x0</td>
<td>DMA Channel 6 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT6 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>5</td>
<td>mask_blockint5</td>
<td>R/W 0x0</td>
<td>DMA Channel 5 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT5 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>4</td>
<td>mask_blockint4</td>
<td>R/W 0x0</td>
<td>DMA Channel 4 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT4 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>3</td>
<td>mask_blockint3</td>
<td>R/W 0x0</td>
<td>DMA Channel 3 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS BLOCKINT3 bit in STATUS BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
</tbody>
</table>
Table 194: DMA Channel BLOCK TRANSFER INTERRUPT MASK Register (MASK_BLOCKINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>mask_blockint2</td>
<td>R/W 0x0</td>
<td>DMA Channel 2 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT2 bit in STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>1</td>
<td>mask_blockint1</td>
<td>R/W 0x0</td>
<td>DMA Channel 1 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT1 bit in STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
<tr>
<td>0</td>
<td>mask_blockint0</td>
<td>R/W 0x0</td>
<td>DMA Channel 0 Block Transfer Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BLOCKINT0 bit in STATUS_BLOCKINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding block interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding block interrupt</td>
</tr>
</tbody>
</table>

Table 195: DMA Channel BLOCK TRANSFER INTERRUPT Register (STATUS_BLOCKINT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STATUS_BLOCKINT</td>
<td>0x004</td>
</tr>
</tbody>
</table>

24.2.2.2 DMA Channel BLOCK TRANSFER INTERRUPT Register (STATUS_BLOCKINT)

Table 195: DMA Channel BLOCK TRANSFER INTERRUPT Register (STATUS_BLOCKINT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>status_blockint31</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 31 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 31 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>30</td>
<td>status_blockint30</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 30 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 30 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>--------------------</td>
<td>-------------</td>
<td>--------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
</tbody>
</table>
| 29   | status_blockint29  | R/W1CLR 0x0 | DMA Channel 29 Block Transfer Interrupt Bit  
This interrupt is generated on channel 29 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 28   | status_blockint28  | R/W1CLR 0x0 | DMA Channel 28 Block Transfer Interrupt Bit  
This interrupt is generated on channel 28 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 27   | status_blockint27  | R/W1CLR 0x0 | DMA Channel 27 Block Transfer Interrupt Bit  
This interrupt is generated on channel 27 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 26   | status_blockint26  | R/W1CLR 0x0 | DMA Channel 26 Block Transfer Interrupt Bit  
This interrupt is generated on channel 26 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 25   | status_blockint25  | R/W1CLR 0x0 | DMA Channel 25 Block Transfer Interrupt Bit  
This interrupt is generated on channel 25 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 24   | status_blockint24  | R/W1CLR 0x0 | DMA Channel 24 Block Transfer Interrupt Bit  
This interrupt is generated on channel 24 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 23   | status_blockint23  | R/W1CLR 0x0 | DMA Channel 23 Block Transfer Interrupt Bit  
This interrupt is generated on channel 23 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 22   | status_blockint22  | R/W1CLR 0x0 | DMA Channel 22 Block Transfer Interrupt Bit  
This interrupt is generated on channel 22 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
### Table 195: DMA Channel BLOCK TRANSFER INTERRUPT Register (STATUS_BLOCKINT)  
(Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 21   | status_blockint21 | R/W1CLR 0x0  | DMA Channel 21 Block Transfer Interrupt Bit  
This interrupt is generated on channel 21 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 20   | status_blockint20 | R/W1CLR 0x0  | DMA Channel 20 Block Transfer Interrupt Bit  
This interrupt is generated on channel 20 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 19   | status_blockint19 | R/W1CLR 0x0  | DMA Channel 19 Block Transfer Interrupt Bit  
This interrupt is generated on channel 19 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 18   | status_blockint18 | R/W1CLR 0x0  | DMA Channel 18 Block Transfer Interrupt Bit  
This interrupt is generated on channel 18 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 17   | status_blockint17 | R/W1CLR 0x0  | DMA Channel 17 Block Transfer Interrupt Bit  
This interrupt is generated on channel 17 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 16   | status_blockint16 | R/W1CLR 0x0  | DMA Channel 16 Block Transfer Interrupt Bit  
This interrupt is generated on channel 16 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 15   | status_blockint15 | R/W1CLR 0x0  | DMA Channel 15 Block Transfer Interrupt Bit  
This interrupt is generated on channel 15 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
| 14   | status_blockint14 | R/W1CLR 0x0  | DMA Channel 14 Block Transfer Interrupt Bit  
This interrupt is generated on channel 14 DMA block burst/single transfer completion.  
0x0 = DMA block burst/single transfer is not completed  
0x1 = DMA block burst/single transfer is completed |
### Table 195: DMA Channel BLOCK TRANSFER INTERRUPT Register (STATUS_BLOCKINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13</td>
<td>status_block13</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 13 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 13 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>12</td>
<td>status_block12</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 12 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 12 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>11</td>
<td>status_block11</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 11 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 11 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>10</td>
<td>status_block10</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 10 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 10 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>9</td>
<td>status_block9</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 9 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 9 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>8</td>
<td>status_block8</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 8 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 8 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>7</td>
<td>status_block7</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 7 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 7 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
<tr>
<td>6</td>
<td>status_block6</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 6 Block Transfer Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on channel 6 DMA block burst/single transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA block burst/single transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA block burst/single transfer is completed</td>
</tr>
</tbody>
</table>
Table 195: DMA Channel BLOCK TRANSFER INTERRUPT Register (STATUS_BLOCKINT)  (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 5    | status_blockint5 | R/W1CLR 0x0   | DMA Channel 5 Block Transfer Interrupt Bit  
|      |                |              | This interrupt is generated on channel 5 DMA block burst/single transfer completion.  
|      |                |              | 0x0 = DMA block burst/single transfer is not completed  
|      |                |              | 0x1 = DMA block burst/single transfer is completed  |
| 4    | status_blockint4 | R/W1CLR 0x0   | DMA Channel 4 Block Transfer Interrupt Bit  
|      |                |              | This interrupt is generated on channel 4 DMA block burst/single transfer completion.  
|      |                |              | 0x0 = DMA block burst/single transfer is not completed  
|      |                |              | 0x1 = DMA block burst/single transfer is completed  |
| 3    | status_blockint3 | R/W1CLR 0x0   | DMA Channel 3 Block Transfer Interrupt Bit  
|      |                |              | This interrupt is generated on channel 3 DMA block burst/single transfer completion.  
|      |                |              | 0x0 = DMA block burst/single transfer is not completed  
|      |                |              | 0x1 = DMA block burst/single transfer is completed  |
| 2    | status_blockint2 | R/W1CLR 0x0   | DMA Channel 2 Block Transfer Interrupt Bit  
|      |                |              | This interrupt is generated on channel 2 DMA block burst/single transfer completion.  
|      |                |              | 0x0 = DMA block burst/single transfer is not completed  
|      |                |              | 0x1 = DMA block burst/single transfer is completed  |
| 1    | status_blockint1 | R/W1CLR 0x0   | DMA Channel 1 Block Transfer Interrupt Bit  
|      |                |              | This interrupt is generated on channel 1 DMA block burst/single transfer completion.  
|      |                |              | 0x0 = DMA block burst/single transfer is not completed  
|      |                |              | 0x1 = DMA block burst/single transfer is completed  |
| 0    | status_blockint0 | R/W1CLR 0x0   | DMA Channel 0 Block Transfer Interrupt Bit  
|      |                |              | This interrupt is generated on channel 0 DMA block burst/single transfer completion.  
|      |                |              | 0x0 = DMA block burst/single transfer is not completed  
|      |                |              | 0x1 = DMA block burst/single transfer is completed  |

24.2.2.3 DMA Channel Transfer Completion Interrupt Mask Register (MASK_TFRINT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MASK_TFRINT</td>
<td>0x008</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
</tr>
<tr>
<td>------</td>
<td>-------------</td>
</tr>
<tr>
<td>31</td>
<td>mask_tfrint31</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>mask_tfrint30</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>mask_tfrint29</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>mask_tfrint28</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>mask_tfrint27</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>mask_tfrint26</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>mask_tfrint25</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>mask_tfrint24</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Table 196: DMA Channel Transfer Completion Interrupt Mask Register (MASK_TFRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>23</td>
<td>mask_tfr23</td>
<td>R/W 0x0</td>
<td>DMA Channel 23 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT23 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>22</td>
<td>mask_tfr22</td>
<td>R/W 0x0</td>
<td>DMA Channel 22 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT22 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>21</td>
<td>mask_tfr21</td>
<td>R/W 0x0</td>
<td>DMA Channel 21 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT21 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>20</td>
<td>mask_tfr20</td>
<td>R/W 0x0</td>
<td>DMA Channel 20 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT20 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>19</td>
<td>mask_tfr19</td>
<td>R/W 0x0</td>
<td>DMA Channel 19 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT19 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>18</td>
<td>mask_tfr18</td>
<td>R/W 0x0</td>
<td>DMA Channel 18 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT18 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>17</td>
<td>mask_tfr17</td>
<td>R/W 0x0</td>
<td>DMA Channel 17 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT17 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>16</td>
<td>mask_tfr16</td>
<td>R/W 0x0</td>
<td>DMA Channel 16 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT16 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
</tbody>
</table>
Table 196: DMA Channel Transfer Completion Interrupt Mask Register (MASK_TFRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>mask_tfr15</td>
<td>R/W 0x0</td>
<td>DMA Channel 15 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT15 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>14</td>
<td>mask_tfr14</td>
<td>R/W 0x0</td>
<td>DMA Channel 14 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT14 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>13</td>
<td>mask_tfr13</td>
<td>R/W 0x0</td>
<td>DMA Channel 13 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT13 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>12</td>
<td>mask_tfr12</td>
<td>R/W 0x0</td>
<td>DMA Channel 12 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT12 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>11</td>
<td>mask_tfr11</td>
<td>R/W 0x0</td>
<td>DMA Channel 11 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT11 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>10</td>
<td>mask_tfr10</td>
<td>R/W 0x0</td>
<td>DMA Channel 10 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT10 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>9</td>
<td>mask_tfr9</td>
<td>R/W 0x0</td>
<td>DMA Channel 9 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT9 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>8</td>
<td>mask_tfr8</td>
<td>R/W 0x0</td>
<td>DMA Channel 8 Transfer Completion Interrupt Mask Bit. This bit enables the interrupt when STATUS_TFRINT8 bit in STATUS_TFRINT is set. 0x0 = mask the corresponding transfer completion interrupt 0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/ HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>-----------</td>
<td>--------------</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td>7</td>
<td>mask_tfrint7</td>
<td>R/W 0x0</td>
<td>DMA Channel 7 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT7 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>6</td>
<td>mask_tfrint6</td>
<td>R/W 0x0</td>
<td>DMA Channel 6 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT6 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>5</td>
<td>mask_tfrint5</td>
<td>R/W 0x0</td>
<td>DMA Channel 5 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT5 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>4</td>
<td>mask_tfrint4</td>
<td>R/W 0x0</td>
<td>DMA Channel 4 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT4 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>3</td>
<td>mask_tfrint3</td>
<td>R/W 0x0</td>
<td>DMA Channel 3 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT3 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>2</td>
<td>mask_tfrint2</td>
<td>R/W 0x0</td>
<td>DMA Channel 2 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT2 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>1</td>
<td>mask_tfrint1</td>
<td>R/W 0x0</td>
<td>DMA Channel 1 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT1 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td>0</td>
<td>mask_tfrint0</td>
<td>R/W 0x0</td>
<td>DMA Channel 0 Transfer Completion Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_TFRINT0 bit in STATUS_TFRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding transfer completion interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding transfer completion interrupt</td>
</tr>
</tbody>
</table>
### 24.2.2.4 DMA Channel Transfer Completion Interrupt Register (STATUS_TFRINT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STATUS_TFRINT</td>
<td>0x00C</td>
</tr>
</tbody>
</table>

#### Table 197: DMA Channel Transfer Completion Interrupt Register (STATUS_TFRINT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31   | status_tfrint31 | R/W1CLR 0x0 | DMA Channel 31 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 31 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 30   | status_tfrint30 | R/W1CLR 0x0 | DMA Channel 30 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 30 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 29   | status_tfrint29 | R/W1CLR 0x0 | DMA Channel 29 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 29 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 28   | status_tfrint28 | R/W1CLR 0x0 | DMA Channel 28 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 28 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 27   | status_tfrint27 | R/W1CLR 0x0 | DMA Channel 27 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 27 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 26   | status_tfrint26 | R/W1CLR 0x0 | DMA Channel 26 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 26 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 25   | status_tfrint25 | R/W1CLR 0x0 | DMA Channel 25 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 25 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 24   | status_tfrint24 | R/W1CLR 0x0 | DMA Channel 24 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 24 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 23   | status_tfrint23 | R/W1CLR 0x0 | DMA Channel 23 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 23 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>22</td>
<td>status_tfrint22</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 22 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 22 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>21</td>
<td>status_tfrint21</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 21 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 21 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>20</td>
<td>status_tfrint20</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 20 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 20 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>19</td>
<td>status_tfrint19</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 19 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 19 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>18</td>
<td>status_tfrint18</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 18 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 18 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>17</td>
<td>status_tfrint17</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 17 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 17 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>16</td>
<td>status_tfrint16</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 16 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 16 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>15</td>
<td>status_tfrint15</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 15 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 15 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>14</td>
<td>status_tfrint14</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 14 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 14 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
<tr>
<td>13</td>
<td>status_tfrint13</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 13 Transfer Completion Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated on DMA channel 13 transfer completion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer is not completed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer is completed</td>
</tr>
</tbody>
</table>
## Table 197: DMA Channel Transfer Completion Interrupt Register (STATUS_TFRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 12   | status_tfrint12 | R/W1CLR 0x0 | DMA Channel 12 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 12 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 11   | status_tfrint11 | R/W1CLR 0x0 | DMA Channel 11 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 11 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 10   | status_tfrint10 | R/W1CLR 0x0 | DMA Channel 10 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 10 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 9    | status_tfrint9  | R/W1CLR 0x0 | DMA Channel 9 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 9 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 8    | status_tfrint8  | R/W1CLR 0x0 | DMA Channel 8 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 8 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 7    | status_tfrint7  | R/W1CLR 0x0 | DMA Channel 7 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 7 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 6    | status_tfrint6  | R/W1CLR 0x0 | DMA Channel 6 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 6 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 5    | status_tfrint5  | R/W1CLR 0x0 | DMA Channel 5 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 5 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 4    | status_tfrint4  | R/W1CLR 0x0 | DMA Channel 4 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 4 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
| 3    | status_tfrint3  | R/W1CLR 0x0 | DMA Channel 3 Transfer Completion Interrupt  
This interrupt is generated on DMA channel 3 transfer completion.  
0x0 = transfer is not completed  
0x1 = transfer is completed |
24.2.2.5 DMA Channel Bus Error Interrupt Mask Register (MASK_BUSERRINT)

Table 198: DMA Channel Bus Error Interrupt Mask Register (MASK_BUSERRINT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>mask_buserrint31</td>
<td>R/W 0x0</td>
<td>DMA Channel 31 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT31 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>30</td>
<td>mask_buserrint30</td>
<td>R/W 0x0</td>
<td>DMA Channel 30 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT30 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>29</td>
<td>mask_buserrint29</td>
<td>R/W 0x0</td>
<td>DMA Channel 29 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT29 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
</tbody>
</table>
### Table 198: DMA Channel Bus Error Interrupt Mask Register (MASK_BUSERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>28</td>
<td>mask_buserrint28</td>
<td>R/W 0x0</td>
<td>DMA Channel 28 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT28 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>27</td>
<td>mask_buserrint27</td>
<td>R/W 0x0</td>
<td>DMA Channel 27 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT27 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>26</td>
<td>mask_buserrint26</td>
<td>R/W 0x0</td>
<td>DMA Channel 26 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT26 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>25</td>
<td>mask_buserrint25</td>
<td>R/W 0x0</td>
<td>DMA Channel 25 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT25 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>24</td>
<td>mask_buserrint24</td>
<td>R/W 0x0</td>
<td>DMA Channel 24 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT24 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>23</td>
<td>mask_buserrint23</td>
<td>R/W 0x0</td>
<td>DMA Channel 23 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT23 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>22</td>
<td>mask_buserrint22</td>
<td>R/W 0x0</td>
<td>DMA Channel 22 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT22 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>21</td>
<td>mask_buserrint21</td>
<td>R/W 0x0</td>
<td>DMA Channel 21 Bus Error Interrupt Mask Bit This bit enables the interrupt when STATUS_BUSERRINT21 bit in STATUS_ERRINT is set. 0x0 = mask the corresponding bus error interrupt 0x1 = unmask the corresponding bus error interrupt</td>
</tr>
</tbody>
</table>
Table 198: DMA Channel Bus Error Interrupt Mask Register (MASK_BUSERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>mask_buserrint20</td>
<td>R/W 0x0</td>
<td>DMA Channel 20 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT20 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>19</td>
<td>mask_buserrint19</td>
<td>R/W 0x0</td>
<td>DMA Channel 19 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT19 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>18</td>
<td>mask_buserrint18</td>
<td>R/W 0x0</td>
<td>DMA Channel 18 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT18 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>17</td>
<td>mask_buserrint17</td>
<td>R/W 0x0</td>
<td>DMA Channel 17 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT17 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>16</td>
<td>mask_buserrint16</td>
<td>R/W 0x0</td>
<td>DMA Channel 16 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT16 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>15</td>
<td>mask_buserrint15</td>
<td>R/W 0x0</td>
<td>DMA Channel 15 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT15 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>14</td>
<td>mask_buserrint14</td>
<td>R/W 0x0</td>
<td>DMA Channel 14 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT14 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
<tr>
<td>13</td>
<td>mask_buserrint13</td>
<td>R/W 0x0</td>
<td>DMA Channel 13 Bus Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_BUSERRINT13 bit in STATUS_ERRINT is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding bus error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding bus error interrupt</td>
</tr>
</tbody>
</table>
### Table 198: DMA Channel Bus Error Interrupt Mask Register (MASK_BUSERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 12   | mask_buserrint12 | R/W 0x0      | DMA Channel 12 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT12 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
| 11   | mask_buserrint11 | R/W 0x0      | DMA Channel 11 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT11 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
| 10   | mask_buserrint10 | R/W 0x0      | DMA Channel 10 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT10 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
| 9    | mask_buserrint9  | R/W 0x0      | DMA Channel 9 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT9 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
| 8    | mask_buserrint8  | R/W 0x0      | DMA Channel 8 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT8 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
| 7    | mask_buserrint7  | R/W 0x0      | DMA Channel 7 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT7 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
| 6    | mask_buserrint6  | R/W 0x0      | DMA Channel 6 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT6 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
| 5    | mask_buserrint5  | R/W 0x0      | DMA Channel 5 Bus Error Interrupt Mask Bit  
|      |                  |              | This bit enables the interrupt when STATUS_BUSERRINT5 bit in STATUS_ERRINT is set.  
|      |                  |              | 0x0 = mask the corresponding bus error interrupt  
|      |                  |              | 0x1 = unmask the corresponding bus error interrupt |
### Table 198: DMA Channel Bus Error Interrupt Mask Register (MASK_BUSERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 4    | mask_buserrint4 | R/W 0x0     | DMA Channel 4 Bus Error Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BUSERRINT4 bit in STATUS_ERRINT is set.  
0x0 = mask the corresponding bus error interrupt  
0x1 = unmask the corresponding bus error interrupt |
| 3    | mask_buserrint3 | R/W 0x0     | DMA Channel 3 Bus Error Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BUSERRINT3 bit in STATUS_ERRINT is set.  
0x0 = mask the corresponding bus error interrupt  
0x1 = unmask the corresponding bus error interrupt |
| 2    | mask_buserrint2 | R/W 0x0     | DMA Channel 2 Bus Error Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BUSERRINT2 bit in STATUS_ERRINT is set.  
0x0 = mask the corresponding bus error interrupt  
0x1 = unmask the corresponding bus error interrupt |
| 1    | mask_buserrint1 | R/W 0x0     | DMA Channel 1 Bus Error Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BUSERRINT1 bit in STATUS_ERRINT is set.  
0x0 = mask the corresponding bus error interrupt  
0x1 = unmask the corresponding bus error interrupt |
| 0    | mask_buserrint0 | R/W 0x0     | DMA Channel 0 Bus Error Interrupt Mask Bit  
This bit enables the interrupt when STATUS_BUSERRINT0 bit in STATUS_ERRINT is set.  
0x0 = mask the corresponding bus error interrupt  
0x1 = unmask the corresponding bus error interrupt |

### 24.2.2.6 DMA Channel Bus Error Interrupt Mask Register (STATUS_BUSERRINT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STATUS_BUSERRINT</td>
<td>0x014</td>
</tr>
</tbody>
</table>

### Table 199: DMA Channel Bus Error Interrupt Mask Register (STATUS_BUSERRINT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31   | status_buserrint31 | R/W1CLR 0x0 | DMA Channel 31 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel31 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated |
<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>30</td>
<td>status_buserrint30</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 30 Bus Error Interrupt Bit This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel30 transfer. In addition, the channel is disabled. 0x0 = no bus error interrupt is generated 0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>29</td>
<td>status_buserrint29</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 29 Bus Error Interrupt Bit This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel29 transfer. In addition, the channel is disabled. 0x0 = no bus error interrupt is generated 0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>28</td>
<td>status_buserrint28</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 28 Bus Error Interrupt Bit This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel28 transfer. In addition, the channel is disabled. 0x0 = no bus error interrupt is generated 0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>27</td>
<td>status_buserrint27</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 27 Bus Error Interrupt Bit This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel27 transfer. In addition, the channel is disabled. 0x0 = no bus error interrupt is generated 0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>26</td>
<td>status_buserrint26</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 26 Bus Error Interrupt Bit This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel26 transfer. In addition, the channel is disabled. 0x0 = no bus error interrupt is generated 0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>25</td>
<td>status_buserrint25</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 25 Bus Error Interrupt Bit This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel25 transfer. In addition, the channel is disabled. 0x0 = no bus error interrupt is generated 0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>24</td>
<td>status_buserrint24</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 24 Bus Error Interrupt Bit This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel24 transfer. In addition, the channel is disabled. 0x0 = no bus error interrupt is generated 0x1 = bus error interrupt is generated</td>
</tr>
</tbody>
</table>
### Table 199: DMA Channel Bus Error Interrupt Mask Register (STATUS_BUSERINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 23   | status_buserrint23     | R/W1CLR 0x0  | DMA Channel 23 Bus Error Interrupt Bit
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel23 transfer. In addition, the channel is disabled.
0x0 = no bus error interrupt is generated
0x1 = bus error interrupt is generated |
| 22   | status_buserrint22     | R/W1CLR 0x0  | DMA Channel 22 Bus Error Interrupt Bit
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel22 transfer. In addition, the channel is disabled.
0x0 = no bus error interrupt is generated
0x1 = bus error interrupt is generated |
| 21   | status_buserrint21     | R/W1CLR 0x0  | DMA Channel 21 Bus Error Interrupt Bit
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel21 transfer. In addition, the channel is disabled.
0x0 = no bus error interrupt is generated
0x1 = bus error interrupt is generated |
| 20   | status_buserrint20     | R/W1CLR 0x0  | DMA Channel 20 Bus Error Interrupt Bit
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel20 transfer. In addition, the channel is disabled.
0x0 = no bus error interrupt is generated
0x1 = bus error interrupt is generated |
| 19   | status_buserrint19     | R/W1CLR 0x0  | DMA Channel 19 Bus Error Interrupt Bit
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel19 transfer. In addition, the channel is disabled.
0x0 = no bus error interrupt is generated
0x1 = bus error interrupt is generated |
| 18   | status_buserrint18     | R/W1CLR 0x0  | DMA Channel 18 Bus Error Interrupt Bit
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel18 transfer. In addition, the channel is disabled.
0x0 = no bus error interrupt is generated
0x1 = bus error interrupt is generated |
| 17   | status_buserrint17     | R/W1CLR 0x0  | DMA Channel 17 Bus Error Interrupt Bit
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel17 transfer. In addition, the channel is disabled.
0x0 = no bus error interrupt is generated
0x1 = bus error interrupt is generated |
Table 199: DMA Channel Bus Error Interrupt Mask Register (STATUS_BUSERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>status_buserr16</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 16 Bus Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel 16 transfer. In addition, the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no bus error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>15</td>
<td>status_buserr15</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 15 Bus Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel 15 transfer. In addition, the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no bus error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>14</td>
<td>status_buserr14</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 14 Bus Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel 14 transfer. In addition, the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no bus error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>13</td>
<td>status_buserr13</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 13 Bus Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel 13 transfer. In addition, the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no bus error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>12</td>
<td>status_buserr12</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 12 Bus Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel 12 transfer. In addition, the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no bus error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>11</td>
<td>status_buserr11</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 11 Bus Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel 11 transfer. In addition, the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no bus error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = bus error interrupt is generated</td>
</tr>
<tr>
<td>10</td>
<td>status_buserr10</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 10 Bus Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel 10 transfer. In addition, the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no bus error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = bus error interrupt is generated</td>
</tr>
</tbody>
</table>
Table 199: DMA Channel Bus Error Interrupt Mask Register (STATUS_BUSERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 9    | status_buserrint9 | R/W1CLR 0x0  | DMA Channel 9 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel9 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated                                           |
| 8    | status_buserrint8 | R/W1CLR 0x0  | DMA Channel 8 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel8 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated                                           |
| 7    | status_buserrint7 | R/W1CLR 0x0  | DMA Channel 7 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel7 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated                                           |
| 6    | status_buserrint6 | R/W1CLR 0x0  | DMA Channel 6 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel6 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated                                           |
| 5    | status_buserrint5 | R/W1CLR 0x0  | DMA Channel 5 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel5 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated                                           |
| 4    | status_buserrint4 | R/W1CLR 0x0  | DMA Channel 4 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel4 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated                                           |
| 3    | status_buserrint3 | R/W1CLR 0x0  | DMA Channel 3 Bus Error Interrupt Bit  
This interrupt is generated when an ERROR response is received from AHB slave on the HRESP bus during a DMA channel3 transfer. In addition, the channel is disabled.  
0x0 = no bus error interrupt is generated  
0x1 = bus error interrupt is generated                                           |
24.2.2.7 DMA Channel Source/target Address Alignment Error Interrupt Mask Register (MASK_ADDRERRINT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>mask_addrerrint31</td>
<td>R/W 0x0</td>
<td>DMA Channel 31 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR31 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>30</td>
<td>mask_addrerrint30</td>
<td>R/W 0x0</td>
<td>DMA Channel 30 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR30 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
</tbody>
</table>
### Table 200: DMA Channel Source/target Address Alignment Error Interrupt Mask Register (MASK_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type</th>
<th>HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>29</td>
<td>mask_addrerrint29</td>
<td>R/W</td>
<td>0x0</td>
<td>DMA Channel 29 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR29 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>28</td>
<td>mask_addrerrint28</td>
<td>R/W</td>
<td>0x0</td>
<td>DMA Channel 28 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR28 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>27</td>
<td>mask_addrerrint27</td>
<td>R/W</td>
<td>0x0</td>
<td>DMA Channel 27 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR27 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>26</td>
<td>mask_addrerrint26</td>
<td>R/W</td>
<td>0x0</td>
<td>DMA Channel 26 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR26 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>25</td>
<td>mask_addrerrint25</td>
<td>R/W</td>
<td>0x0</td>
<td>DMA Channel 25 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR25 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>24</td>
<td>mask_addrerrint24</td>
<td>R/W</td>
<td>0x0</td>
<td>DMA Channel 24 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR24 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>23</td>
<td>mask_addrerrint23</td>
<td>R/W</td>
<td>0x0</td>
<td>DMA Channel 23 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR23 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
</tbody>
</table>
### Table 200: DMA Channel Source/target Address Alignment Error Interrupt Mask Register (MASK_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>22</td>
<td>mask_addrerrint22</td>
<td>R/W 0x0</td>
<td>DMA Channel 22 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR22 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>21</td>
<td>mask_addrerrint21</td>
<td>R/W 0x0</td>
<td>DMA Channel 21 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR21 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>20</td>
<td>mask_addrerrint20</td>
<td>R/W 0x0</td>
<td>DMA Channel 20 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR20 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>19</td>
<td>mask_addrerrint19</td>
<td>R/W 0x0</td>
<td>DMA Channel 19 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR19 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>18</td>
<td>mask_addrerrint18</td>
<td>R/W 0x0</td>
<td>DMA Channel 18 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR18 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>17</td>
<td>mask_addrerrint17</td>
<td>R/W 0x0</td>
<td>DMA Channel 17 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR17 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>16</td>
<td>mask_addrerrint16</td>
<td>R/W 0x0</td>
<td>DMA Channel 16 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR16 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
</tbody>
</table>
Table 200: DMA Channel Source/target Address Alignment Error Interrupt Mask Register (MASK_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>mask_addrerrint15</td>
<td>R/W 0x0</td>
<td>DMA Channel 15 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR15 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>14</td>
<td>mask_addrerrint14</td>
<td>R/W 0x0</td>
<td>DMA Channel 14 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR14 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>13</td>
<td>mask_addrerrint13</td>
<td>R/W 0x0</td>
<td>DMA Channel 13 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR13 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>12</td>
<td>mask_addrerrint12</td>
<td>R/W 0x0</td>
<td>DMA Channel 12 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR12 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>11</td>
<td>mask_addrerrint11</td>
<td>R/W 0x0</td>
<td>DMA Channel 11 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR11 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>10</td>
<td>mask_addrerrint10</td>
<td>R/W 0x0</td>
<td>DMA Channel 10 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR10 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>9</td>
<td>mask_addrerrint9</td>
<td>R/W 0x0</td>
<td>DMA Channel 9 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR9 bit in</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
</tbody>
</table>
### Table 200: DMA Channel Source/target Address Alignment Error Interrupt Mask Register (MASK_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>mask_addrerr8</td>
<td>R/W 0x0</td>
<td>DMA Channel 8 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR8 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>7</td>
<td>mask_addrerr7</td>
<td>R/W 0x0</td>
<td>DMA Channel 7 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR7 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>6</td>
<td>mask_addrerr6</td>
<td>R/W 0x0</td>
<td>DMA Channel 6 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR6 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>5</td>
<td>mask_addrerr5</td>
<td>R/W 0x0</td>
<td>DMA Channel 5 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR5 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>4</td>
<td>mask_addrerr4</td>
<td>R/W 0x0</td>
<td>DMA Channel 4 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR4 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>3</td>
<td>mask_addrerr3</td>
<td>R/W 0x0</td>
<td>DMA Channel 3 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR3 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>2</td>
<td>mask_addrerr2</td>
<td>R/W 0x0</td>
<td>DMA Channel 2 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR2 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
</tbody>
</table>
Table 200: DMA Channel Source/target Address Alignment Error Interrupt Mask Register (MASK_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>mask_addrerrint1</td>
<td>R/W 0x0</td>
<td>DMA Channel 1 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR1 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
<tr>
<td>0</td>
<td>mask_addrerrint0</td>
<td>R/W 0x0</td>
<td>DMA Channel 0 Source/target Address Alignment Error Interrupt Mask Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit enables the interrupt when STATUS_ADDRERR0 bit in STATUS_ADDRERR is set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = mask the corresponding address error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unmask the corresponding address error interrupt</td>
</tr>
</tbody>
</table>

Table 201: DMA Channel Source/target Address Alignment Error Interrupt Register (STATUS_ADDRERRINT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STATUS_ADDRERRINT</td>
<td>0x01C</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>status_addrerrint31</td>
<td>R/W 1CLR 0x0</td>
<td>DMA Channel 31 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 31 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>30</td>
<td>status_addrerrint30</td>
<td>R/W 1CLR 0x0</td>
<td>DMA Channel 30 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 30 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>29</td>
<td>status_addrerrint29</td>
<td>R/W 1CLR 0x0</td>
<td>DMA Channel 29 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 29 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
</tbody>
</table>
### Table 201: DMA Channel Source/target Address Alignment Error Interrupt Register (STATUS_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>28</td>
<td>status_addrerr28</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 28 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 28 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>27</td>
<td>status_addrerr27</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 27 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 27 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>26</td>
<td>status_addrerr26</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 26 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 26 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>25</td>
<td>status_addrerr25</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 25 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 25 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>24</td>
<td>status_addrerr24</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 24 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 24 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>23</td>
<td>status_addrerr23</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 23 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 23 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>22</td>
<td>status_addrerr22</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 22 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 22 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>21</td>
<td>status_addrerr21</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 21 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 21 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
</tbody>
</table>
### Table 201: DMA Channel Source/target Address Alignment Error Interrupt Register (STATUS_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>status_addrerrint20</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 20 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 20 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>19</td>
<td>status_addrerrint19</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 19 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 19 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>18</td>
<td>status_addrerrint18</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 18 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 18 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>17</td>
<td>status_addrerrint17</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 17 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 17 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>16</td>
<td>status_addrerrint16</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 16 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 16 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>15</td>
<td>status_addrerrint15</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 15 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 15 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>14</td>
<td>status_addrerrint14</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 14 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 14 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>13</td>
<td>status_addrerrint13</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 13 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 13 source or target address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
</tbody>
</table>
### Table 201: DMA Channel Source/target Address Alignment Error Interrupt Register (STATUS_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12</td>
<td>status_addrerrint12</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 12 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 12 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>11</td>
<td>status_addrerrint11</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 11 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 11 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>10</td>
<td>status_addrerrint10</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 10 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 10 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>9</td>
<td>status_addrerrint9</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 9 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 9 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>8</td>
<td>status_addrerrint8</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 8 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 8 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>7</td>
<td>status_addrerrint7</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 7 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 7 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>6</td>
<td>status_addrerrint6</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 6 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 6 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>5</td>
<td>status_addrerrint5</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 5 Source/target Address Alignment Error Interrupt Bit This interrupt is generated when channel 5 source or target address is not aligned to corresponding cntl.width. 0x0 = no address error interrupt is generated 0x1 = address error interrupt is generated</td>
</tr>
</tbody>
</table>
### Table 201: DMA Channel Source/target Address Alignment Error Interrupt Register (STATUS_ADDRERRINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>status_addrerr4</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 4 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 4 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>3</td>
<td>status_addrerr3</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 3 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 3 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>2</td>
<td>status_addrerr2</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 2 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 2 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>1</td>
<td>status_addrerr1</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 1 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 1 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
<tr>
<td>0</td>
<td>status_addrerr0</td>
<td>R/W1CLR 0x0</td>
<td>DMA Channel 0 Source/target Address Alignment Error Interrupt Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This interrupt is generated when channel 0 source or target address is not aligned to corresponding cntl.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no address error interrupt is generated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = address error interrupt is generated</td>
</tr>
</tbody>
</table>

### 24.2.2.9 DMA CHANNEL INTERRUPT REGISTER (STATUS_CHLINT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STATUS_CHLINT</td>
<td>0x020</td>
</tr>
</tbody>
</table>

### Table 202: DMA CHANNEL INTERRUPT REGISTER (STATUS_CHLINT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>status_chlint31</td>
<td>R 0x0</td>
<td>DMA Channel 31 Interrupt OR of the content of the respective unmapped interrupt of channel 31.</td>
</tr>
<tr>
<td>30</td>
<td>status_chlint30</td>
<td>R 0x0</td>
<td>DMA Channel 30 Interrupt OR of the content of the respective unmapped interrupt of channel 30.</td>
</tr>
</tbody>
</table>
Table 202: DMA CHANNEL INTERRUPT REGISTER (STATUS_CHLINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>29</td>
<td>status_chlint29</td>
<td>R 0x0</td>
<td>DMA Channel 29 Interrupt OR of the content of the respective unmapped interrupt of channel 29.</td>
</tr>
<tr>
<td>28</td>
<td>status_chlint28</td>
<td>R 0x0</td>
<td>DMA Channel 28 Interrupt OR of the content of the respective unmapped interrupt of channel 28.</td>
</tr>
<tr>
<td>27</td>
<td>status_chlint27</td>
<td>R 0x0</td>
<td>DMA Channel 27 Interrupt OR of the content of the respective unmapped interrupt of channel 27.</td>
</tr>
<tr>
<td>26</td>
<td>status_chlint26</td>
<td>R 0x0</td>
<td>DMA Channel 26 Interrupt OR of the content of the respective unmapped interrupt of channel 26.</td>
</tr>
<tr>
<td>25</td>
<td>status_chlint25</td>
<td>R 0x0</td>
<td>DMA Channel 25 Interrupt OR of the content of the respective unmapped interrupt of channel 25.</td>
</tr>
<tr>
<td>24</td>
<td>status_chlint24</td>
<td>R 0x0</td>
<td>DMA Channel 24 Interrupt OR of the content of the respective unmapped interrupt of channel 24.</td>
</tr>
<tr>
<td>23</td>
<td>status_chlint23</td>
<td>R 0x0</td>
<td>DMA Channel 23 Interrupt OR of the content of the respective unmapped interrupt of channel 23.</td>
</tr>
<tr>
<td>22</td>
<td>status_chlint22</td>
<td>R 0x0</td>
<td>DMA Channel 22 Interrupt OR of the content of the respective unmapped interrupt of channel 22.</td>
</tr>
<tr>
<td>21</td>
<td>status_chlint21</td>
<td>R 0x0</td>
<td>DMA Channel 21 Interrupt OR of the content of the respective unmapped interrupt of channel 21.</td>
</tr>
<tr>
<td>20</td>
<td>status_chlint20</td>
<td>R 0x0</td>
<td>DMA Channel 20 Interrupt OR of the content of the respective unmapped interrupt of channel 20.</td>
</tr>
<tr>
<td>19</td>
<td>status_chlint19</td>
<td>R 0x0</td>
<td>DMA Channel 19 Interrupt OR of the content of the respective unmapped interrupt of channel 19.</td>
</tr>
<tr>
<td>18</td>
<td>status_chlint18</td>
<td>R 0x0</td>
<td>DMA Channel 18 Interrupt OR of the content of the respective unmapped interrupt of channel 18.</td>
</tr>
<tr>
<td>17</td>
<td>status_chlint17</td>
<td>R 0x0</td>
<td>DMA Channel 17 Interrupt OR of the content of the respective unmapped interrupt of channel 17.</td>
</tr>
<tr>
<td>16</td>
<td>status_chlint16</td>
<td>R 0x0</td>
<td>DMA Channel 16 Interrupt OR of the content of the respective unmapped interrupt of channel 16.</td>
</tr>
</tbody>
</table>
### Table 202: DMA CHANNEL INTERRUPT REGISTER (STATUS_CHLINT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>status_chlint15</td>
<td>R 0x0</td>
<td>DMA Channel 15 Interrupt OR of the content of the respective unmapped interrupt of channel 15.</td>
</tr>
<tr>
<td>14</td>
<td>status_chlint14</td>
<td>R 0x0</td>
<td>DMA Channel 14 Interrupt OR of the content of the respective unmapped interrupt of channel 14.</td>
</tr>
<tr>
<td>13</td>
<td>status_chlint13</td>
<td>R 0x0</td>
<td>DMA Channel 13 Interrupt OR of the content of the respective unmapped interrupt of channel 13.</td>
</tr>
<tr>
<td>12</td>
<td>status_chlint12</td>
<td>R 0x0</td>
<td>DMA Channel 12 Interrupt OR of the content of the respective unmapped interrupt of channel 12.</td>
</tr>
<tr>
<td>11</td>
<td>status_chlint11</td>
<td>R 0x0</td>
<td>DMA Channel 11 Interrupt OR of the content of the respective unmapped interrupt of channel 11.</td>
</tr>
<tr>
<td>10</td>
<td>status_chlint10</td>
<td>R 0x0</td>
<td>DMA Channel 10 Interrupt OR of the content of the respective unmapped interrupt of channel 10.</td>
</tr>
<tr>
<td>9</td>
<td>status_chlint9</td>
<td>R 0x0</td>
<td>DMA Channel 9 Interrupt OR of the content of the respective unmapped interrupt of channel 9.</td>
</tr>
<tr>
<td>8</td>
<td>status_chlint8</td>
<td>R 0x0</td>
<td>DMA Channel 8 Interrupt OR of the content of the respective unmapped interrupt of channel 8.</td>
</tr>
<tr>
<td>7</td>
<td>status_chlint7</td>
<td>R 0x0</td>
<td>DMA Channel 7 Interrupt OR of the content of the respective unmapped interrupt of channel 7.</td>
</tr>
<tr>
<td>6</td>
<td>status_chlint6</td>
<td>R 0x0</td>
<td>DMA Channel 6 Interrupt OR of the content of the respective unmapped interrupt of channel 6.</td>
</tr>
<tr>
<td>5</td>
<td>status_chlint5</td>
<td>R 0x0</td>
<td>DMA Channel 5 Interrupt OR of the content of the respective unmapped interrupt of channel 5.</td>
</tr>
<tr>
<td>4</td>
<td>status_chlint4</td>
<td>R 0x0</td>
<td>DMA Channel 4 Interrupt OR of the content of the respective unmapped interrupt of channel 4.</td>
</tr>
<tr>
<td>3</td>
<td>status_chlint3</td>
<td>R 0x0</td>
<td>DMA Channel 3 Interrupt OR of the content of the respective unmapped interrupt of channel 3.</td>
</tr>
<tr>
<td>2</td>
<td>status_chlint2</td>
<td>R 0x0</td>
<td>DMA Channel 2 Interrupt OR of the content of the respective unmapped interrupt of channel 2.</td>
</tr>
<tr>
<td>1</td>
<td>status_chlint1</td>
<td>R 0x0</td>
<td>DMA Channel 1 Interrupt OR of the content of the respective unmapped interrupt of channel 1.</td>
</tr>
<tr>
<td>0</td>
<td>status_chlint0</td>
<td>R 0x0</td>
<td>DMA Channel 0 Interrupt OR of the content of the respective unmapped interrupt of channel 0.</td>
</tr>
</tbody>
</table>
### 24.2.2.10 Protection Control Signals Register (HPROT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPROT</td>
<td>0x080</td>
</tr>
</tbody>
</table>

#### Table 203: Protection Control Signals Register (HPROT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:0</td>
<td>hprot</td>
<td>R/W 0x3</td>
<td>Protection Control Signals</td>
</tr>
</tbody>
</table>

### 24.2.2.11 DMA Source Address Register (SADR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>SADR0</td>
<td>0x100</td>
<td>32</td>
</tr>
</tbody>
</table>

#### Table 204: DMA Source Address Register (SADR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>srcaddr</td>
<td>R/W 0x0</td>
<td>SOURCE ADDRESS</td>
</tr>
<tr>
<td>1:0</td>
<td>srcaddr0</td>
<td>R/W 0x0</td>
<td>SRCADDR0 SRCADDR[1:0] should align to the cmd.width, that is SRCADDR[1:0] should be 2'b00 when the CMDx.width is configured as word, SRCADDR[0] should be 1'b0 when CMDx.width is configured as half-word, if the address is not aligned to the width, the error interrupt will be generated.</td>
</tr>
</tbody>
</table>

### 24.2.2.12 DMA TARGET ADDRESS Register (TADR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>TADR0</td>
<td>0x104</td>
<td>32</td>
</tr>
</tbody>
</table>

#### Table 205: DMA TARGET ADDRESS Register (TADR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>trgaddr</td>
<td>R/W 0x0</td>
<td>TARGET ADDRESS</td>
</tr>
</tbody>
</table>
Table 205: DMA TARGET ADDRESS Register (TADR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1:0</td>
<td>trgaddr0</td>
<td>R/W 0x0</td>
<td>TRGADDR0 should align to the cmd.width, that is TRGADDR[1:0] should be 2'b00 when the CMDx.width is configured as word, TRGADDR[0] should be 1'b0 when CMDx.width is configured as half-word, if the address is not aligned to the width, the error interrupt will be generated.</td>
</tr>
</tbody>
</table>

24.2.2.13 DMA CONTROL Register A (CTRLA)

Table 206: DMA CONTROL Register A (CTRLA)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>30</td>
<td>incsrcaddr</td>
<td>R/W 0x0</td>
<td>Source Address Increment. If the source address is an internal peripheral FIFO address or external I/O address, the address is not incremented on each successive access. In these cases, DCMDx.INCSRCADDR must be cleared. 0x0 = do not increment source address 0x1 = stop the running channel</td>
</tr>
<tr>
<td>29</td>
<td>inctraddr</td>
<td>R/W 0x0</td>
<td>Target Address Increment. If the target address is an internal peripheral FIFO address or external I/O address, the address is not incremented on each successive access. In these cases, DCMDx.INCTRADDR must be cleared. 0x0 = do not increment target address 0x1 = increment target address</td>
</tr>
<tr>
<td>28:19</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>18:17</td>
<td>tran_type</td>
<td>R/W 0x0</td>
<td>Source to Target Transfer Type. TRAN TYPE, indicate the source and target type. 0x0 = M2M 0x1 = M2P 0x2 = P2M 0x3 = reserved</td>
</tr>
</tbody>
</table>
### DMA CONTROL Register A (CTRLA) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16:15</td>
<td>tran_size</td>
<td>R/W 0x0</td>
<td>Size</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Maximum burst transaction length, number of data items, each of cmd.width.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 8</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 16</td>
</tr>
<tr>
<td>14:13</td>
<td>width</td>
<td>R/W 0x0</td>
<td>Width</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Width of the on-chip peripheral when the source or target is on-chip peripheral, width of the memory when the transfer is M2M type.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = reserved for on-chip peripheral-related transactions (1 byte)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 1 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = half-word (2 bytes)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = word (4 bytes)</td>
</tr>
<tr>
<td>12:0</td>
<td>len</td>
<td>R/W 0x0</td>
<td>Length of the Transfer in Bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The maximum transfer length is (8K-1) bytes. If the transfer is memory-to-memory type, the length of the transfer may be any value up to a maximum of (8K-1) bytes. If the transfer involves any of the on-chip peripherals, the length must be an inter multiple of the peripheral sample width DCMDx.WIDTH.</td>
</tr>
</tbody>
</table>

#### 24.2.2.14 DMA CONTROL Register B (CTRLB)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRLB0</td>
<td>0x10C</td>
<td>32</td>
</tr>
</tbody>
</table>

### DMA CONTROL Register B (CTRLB)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5:0</td>
<td>pernum</td>
<td>R/W 0x0</td>
<td>Peripheral Number</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Indicates the valid peripheral request number. Do not map the same peripheral requests to 2 or more active channel since it produces unpredictable results.</td>
</tr>
</tbody>
</table>
24.2.2.15 DMA CHANNEL ENABLE Register (CHL_EN)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>CHL_EN0</td>
<td>0x110</td>
<td>32</td>
</tr>
</tbody>
</table>

Table 208: DMA CHANNEL ENABLE Register (CHL_EN)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>chl_en</td>
<td>R/W 0x0</td>
<td>Enable/Disable the Channel. This bit allows software to start the channel. To stop an enabled channel, see the chl_stop bit. This bit is reset as soon as it is cleared and when the channel stops normally. After the channel stops normally, STATUS_TFRINTR is set. 0x0 = disable the channel 0x1 = enable the channel</td>
</tr>
<tr>
<td>30:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

24.2.2.16 DMA CHANNEL STOP Register (CHL_STOP)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>CHL_STOP0</td>
<td>0x114</td>
<td>32</td>
</tr>
</tbody>
</table>

Table 209: DMA CHANNEL STOP Register (CHL_STOP)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>chl_stop</td>
<td>R/W 0x0</td>
<td>Stop the Running Channel. This bit allows software to stop the channel when the channel is enabled and has not finished all the transfer yet. When the channel is already in disable state, the stop bit is meaningless and the write can be successful. 0x0 = no impact on the channel 0x1 = stop the running channel</td>
</tr>
<tr>
<td>30:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

24.2.2.17 DMA ACK DELAY CYCLE for Single Transfer in M2P Transfer Type Register (ACK_DELAY)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACK_DELAY</td>
<td>0x800</td>
</tr>
</tbody>
</table>
24.2.2.18 DMA ERROR INFORMATION REGISTER 0 (ERR_INFO0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>err_addr</td>
<td>R 0x0</td>
<td>ADDRESS INFORMATION RELATED ERROR</td>
</tr>
</tbody>
</table>

24.2.2.19 DMA ERROR INFORMATION REGISTER 1 (ERR_INFO1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:27</td>
<td>err_chlnum</td>
<td>R 0x0</td>
<td>Channel Id Information Related Error</td>
</tr>
<tr>
<td>26:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

24.2.2.20 DMA DIAGNOSE INFORMATION REGISTER 0 (DIAGNOSE_INFO0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO0</td>
<td>0x908</td>
</tr>
</tbody>
</table>

Table 210: DMA ACK DELAY CYCLE for Single Transfer in M2P Transfer Type Register (ACK_DELAY)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9:0</td>
<td>ack_delay_num</td>
<td>R/W 0xC</td>
<td>DMA ACK Delay Cycle for Single Write Transaction to Peripheral.</td>
</tr>
</tbody>
</table>
Table 213: DMA DIAGNOSE INFORMATION REGISTER 0 (DIAGNOSE_INFO0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>diagnose_addr</td>
<td>R 0x0</td>
<td>Address Information Related Diagnose</td>
</tr>
</tbody>
</table>

24.2.2.21 DMA DIAGNOSE INFORMATION REGISTER 1 (DIAGNOSE_INFO1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO1</td>
<td>0x90C</td>
</tr>
</tbody>
</table>

Table 214: DMA DIAGNOSE INFORMATION REGISTER 1 (DIAGNOSE_INFO1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>diagnose_req_chl_data</td>
<td>R 0x0</td>
<td>Indicate Whether There is a Valid Request</td>
</tr>
<tr>
<td>30:18</td>
<td>diagnose_rest_len</td>
<td>R 0x0</td>
<td>Indicate the Remaining Data Length of the Selected Channel</td>
</tr>
<tr>
<td>17:5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4:0</td>
<td>diagnose_req_chl_data_chlnum</td>
<td>R 0x0</td>
<td>Indicate Which Channel is in Service</td>
</tr>
</tbody>
</table>

24.2.2.22 DMA DIAGNOSE INFORMATION REGISTER 2 (DIAGNOSE_INFO2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO2</td>
<td>0x910</td>
</tr>
</tbody>
</table>

Table 215: DMA DIAGNOSE INFORMATION REGISTER 2 (DIAGNOSE_INFO2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:28</td>
<td>diagnose_chl_state</td>
<td>R 0x0</td>
<td>Indicate the Channel State</td>
</tr>
<tr>
<td>27:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.2.2.23 DMA DIAGNOSE INFORMATION REGISTER 3 (DIAGNOSE_INFO3)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO3</td>
<td>0x914</td>
</tr>
</tbody>
</table>

**Table 216: DMA DIAGNOSE INFORMATION REGISTER 3 (DIAGNOSE_INFO3)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>diagnose_src_addr</td>
<td>R 0x0</td>
<td>Indicate the Source Address of the Selected Channel</td>
</tr>
<tr>
<td>1:0</td>
<td>diagnose_src_addr0</td>
<td>R 0x0</td>
<td>Indicate The Source Address 0 of the Selected Channel</td>
</tr>
</tbody>
</table>

### 24.2.2.24 DMA DIAGNOSE INFORMATION REGISTER 4 (DIAGNOSE_INFO4)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO4</td>
<td>0x918</td>
</tr>
</tbody>
</table>

**Table 217: DMA DIAGNOSE INFORMATION REGISTER 4 (DIAGNOSE_INFO4)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>diagnose_trg_addr</td>
<td>R 0x0</td>
<td>Indicate the Target Address of the Selected Channel</td>
</tr>
<tr>
<td>1:0</td>
<td>diagnose_trg_addr0</td>
<td>R 0x0</td>
<td>Indicate the Target Address 0 of the Selected Channel</td>
</tr>
</tbody>
</table>

### 24.2.2.25 DMA DIAGNOSE INFORMATION REGISTER 5 (DIAGNOSE_INFO5)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO5</td>
<td>0x91C</td>
</tr>
</tbody>
</table>

**Table 218: DMA DIAGNOSE INFORMATION REGISTER 5 (DIAGNOSE_INFO5)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>diagnose_chl_en</td>
<td>R 0x0</td>
<td>Indicate the Channel Enable State of the Selected Channel</td>
</tr>
<tr>
<td>30</td>
<td>diagnose_incrsrcaddr</td>
<td>R 0x0</td>
<td>Indicate Whether to Increase the Src Address of The Selected Channel</td>
</tr>
</tbody>
</table>
### Table 218: DMA DIAGNOSE INFORMATION REGISTER 5 (DIAGNOSE_INFO5) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>29</td>
<td>diagnose_incrtrgaddr</td>
<td>R 0x0</td>
<td>Indicate Whether to Increase the Trg Address of The Selected Channel</td>
</tr>
<tr>
<td>28:16</td>
<td>diagnose_ctrl_len</td>
<td>R 0x0</td>
<td>Indicate the Length Information of the Selected Channel</td>
</tr>
<tr>
<td>15:14</td>
<td>diagnose_ctrl_transize</td>
<td>R 0x0</td>
<td>Indicate the Transfer Size Information of the Selected Channel</td>
</tr>
<tr>
<td>13:12</td>
<td>diagnose_ctrl_trantype</td>
<td>R 0x0</td>
<td>Indicate the Transfer Type Information of the Selected Channel</td>
</tr>
<tr>
<td>11:10</td>
<td>diagnose_ctrl_width</td>
<td>R 0x0</td>
<td>Indicate the Width Information of the Selected Channel</td>
</tr>
<tr>
<td>9:0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

### 24.2.2.26 DMA DIAGNOSE INFORMATION REGISTER 6 (DIAGNOSE_INFO6)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO6</td>
<td>0x920</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>diagnose_mas_read</td>
<td>R 0x0</td>
<td>Indicate Some Output Info From Main Datapath</td>
</tr>
<tr>
<td>30</td>
<td>diagnose_mas_write</td>
<td>R 0x0</td>
<td>Indicate Some Output Info From Main Datapath</td>
</tr>
<tr>
<td>29:28</td>
<td>diagnose_ahb_size</td>
<td>R 0x0</td>
<td>Indicate Some Output Info From Main Datapath</td>
</tr>
<tr>
<td>27:26</td>
<td>diagnose_ahb_burst</td>
<td>R 0x0</td>
<td>Indicate Some Output Info From Main Datapath</td>
</tr>
<tr>
<td>25:19</td>
<td>diagnose_slicecnt</td>
<td>R 0x0</td>
<td>Indicate Some Output Info From Main Datapath</td>
</tr>
<tr>
<td>18</td>
<td>diagnose_split_word</td>
<td>R 0x0</td>
<td>Indicate Some Output Info From Main Datapath</td>
</tr>
<tr>
<td>17</td>
<td>diagnose_split_halfword</td>
<td>R 0x0</td>
<td>Indicate Some Output Info From Main Datapath</td>
</tr>
<tr>
<td>16:0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.2.2.27 DMA DIAGNOSE INFORMATION REGISTER 7 (DIAGNOSE_INFO7)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIAGNOSE_INFO7</td>
<td>0x924</td>
</tr>
</tbody>
</table>

Table 220: DMA DIAGNOSE INFORMATION REGISTER 7 (DIAGNOSE_INFO7)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:29</td>
<td>diagnose_ahb_burst</td>
<td>R 0x0</td>
<td>Indicate Some AHB Master Info</td>
</tr>
<tr>
<td>28:27</td>
<td>diagnose_ahb_trans</td>
<td>R 0x0</td>
<td>Indicate Some AHB Master Info</td>
</tr>
<tr>
<td>26:24</td>
<td>diagnose_ahb_size</td>
<td>R 0x0</td>
<td>Indicate Some AHB Master Info</td>
</tr>
<tr>
<td>23</td>
<td>diagnose_ahb_hready</td>
<td>R 0x0</td>
<td>Indicate Some AHB Master Info</td>
</tr>
<tr>
<td>22</td>
<td>diagnose_ahb_hresp</td>
<td>R 0x0</td>
<td>Indicate Some AHB Master Info</td>
</tr>
<tr>
<td>21:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
## 24.3 USBC Address Block

### 24.3.1 USBC Register Map

**Table 221: USBC Register Map**

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x000</td>
<td>ID</td>
<td>0xE401_3A05</td>
<td>ID Register</td>
<td>Page: 360</td>
</tr>
<tr>
<td>0x004</td>
<td>HWGENERAL</td>
<td>0x0000_0000</td>
<td>HW General Register</td>
<td>Page: 361</td>
</tr>
<tr>
<td>0x008</td>
<td>HWHOST</td>
<td>0x0000_0000</td>
<td>HW Host Register</td>
<td>Page: 361</td>
</tr>
<tr>
<td>0x00C</td>
<td>HWDEVICE</td>
<td>0x0000_0002</td>
<td>HW Device Register</td>
<td>Page: 362</td>
</tr>
<tr>
<td>0x010</td>
<td>HWTXBUF</td>
<td>0x0000_0000</td>
<td>HW TXBUF Register</td>
<td>Page: 362</td>
</tr>
<tr>
<td>0x014</td>
<td>HWRXBUF</td>
<td>0x0000_0000</td>
<td>HW RXBUF Register</td>
<td>Page: 363</td>
</tr>
<tr>
<td>0x018</td>
<td>HWTXBUF0</td>
<td>0x0000_7777</td>
<td>HW TXBUF0 Register</td>
<td>Page: 363</td>
</tr>
<tr>
<td>0x01C</td>
<td>HWTXBUF1</td>
<td>0x0000_7777</td>
<td>HW TXBUF1 Register</td>
<td>Page: 363</td>
</tr>
<tr>
<td>0x080</td>
<td>GPTIMER0LD</td>
<td>0x0000_0000</td>
<td>GPTIMER0LD Register</td>
<td>Page: 364</td>
</tr>
<tr>
<td>0x084</td>
<td>GPTIMER0CTRL</td>
<td>0x0000_0000</td>
<td>GPTIMER0CTRL</td>
<td>Page: 364</td>
</tr>
<tr>
<td>0x088</td>
<td>GPTTIMER1LD</td>
<td>0x0000_0000</td>
<td>GPTIMER1LD Register</td>
<td>Page: 364</td>
</tr>
<tr>
<td>0x08C</td>
<td>GPTIMER1CTRL</td>
<td>0x0000_0000</td>
<td>GP Timer1 Control Register</td>
<td>Page: 365</td>
</tr>
<tr>
<td>0x090</td>
<td>SBUSCFG</td>
<td>0x0000_0000</td>
<td>SBUS Config Register</td>
<td>Page: 365</td>
</tr>
<tr>
<td>0x100</td>
<td>CAPLENGTH</td>
<td>0x0100_0040</td>
<td>Cap Length Register</td>
<td>Page: 366</td>
</tr>
<tr>
<td>0x104</td>
<td>HCSPARAMS</td>
<td>0x0001_0000</td>
<td>HCS Params Register</td>
<td>Page: 366</td>
</tr>
<tr>
<td>0x108</td>
<td>HCPPARAMS</td>
<td>0x0000_0006</td>
<td>HCC Params Register</td>
<td>Page: 367</td>
</tr>
<tr>
<td>0x120</td>
<td>DCIVERSION</td>
<td>0x0000_0001</td>
<td>DCI Version Register</td>
<td>Page: 367</td>
</tr>
<tr>
<td>0x124</td>
<td>DCPPARAMS</td>
<td>0x8000_0000</td>
<td>DCC Params Register</td>
<td>Page: 368</td>
</tr>
<tr>
<td>0x128</td>
<td>DevLPMCSR</td>
<td>0x0001_F000</td>
<td>DevLPMCSR Register</td>
<td>Page: 368</td>
</tr>
<tr>
<td>0x140</td>
<td>USBCMD</td>
<td>0x0008_0B00</td>
<td>USB Command Register</td>
<td>Page: 370</td>
</tr>
<tr>
<td>0x144</td>
<td>USBSTS</td>
<td>0x0000_1000</td>
<td>USB STS Register</td>
<td>Page: 371</td>
</tr>
<tr>
<td>0x148</td>
<td>USBINTR</td>
<td>0x0000_0000</td>
<td>USB Interrupt Register</td>
<td>Page: 372</td>
</tr>
<tr>
<td>0x14C</td>
<td>FRINDEX</td>
<td>0x0000_0000</td>
<td>FR Index Register</td>
<td>Page: 374</td>
</tr>
<tr>
<td>0x154</td>
<td>PERIODICLISTBASE</td>
<td>0x0000_0000</td>
<td>Periodic List Base Register</td>
<td>Page: 374</td>
</tr>
<tr>
<td>0x158</td>
<td>ASYNCLISTADDR</td>
<td>0x0000_0000</td>
<td>Async List Address Register</td>
<td>Page: 375</td>
</tr>
<tr>
<td>0x15C</td>
<td>TTCTRL</td>
<td>0x0000_0000</td>
<td>TT Control Register</td>
<td>Page: 375</td>
</tr>
<tr>
<td>0x160</td>
<td>BURSTSIZE</td>
<td>0x0000_0000</td>
<td>Burst Size Register</td>
<td>Page: 376</td>
</tr>
</tbody>
</table>
### Table 221: USBC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x164</td>
<td>TXFILLTUNING</td>
<td>0x0002_0000</td>
<td>TX Fill Tuning Register</td>
<td>Page: 376</td>
</tr>
<tr>
<td>0x168</td>
<td>TXTTFILLTUNING</td>
<td>0x0000_0000</td>
<td>TX TT Fill Tuning Register</td>
<td>Page: 377</td>
</tr>
<tr>
<td>0x16C</td>
<td>IC_USB</td>
<td>0x0000_0000</td>
<td>IC USB Register</td>
<td>Page: 377</td>
</tr>
<tr>
<td>0x170</td>
<td>ULPI_VIEWPORT</td>
<td>0x0000_0000</td>
<td>ULPI Viewport Register</td>
<td>Page: 378</td>
</tr>
<tr>
<td>0x178</td>
<td>ENDPTNAK</td>
<td>0x0000_0000</td>
<td>Endpoint NAK Register</td>
<td>Page: 379</td>
</tr>
<tr>
<td>0x17C</td>
<td>ENDPTNAKEN</td>
<td>0x0000_0000</td>
<td>Endpoint NAKEN Register</td>
<td>Page: 379</td>
</tr>
<tr>
<td>0x184</td>
<td>PORTSC1</td>
<td>0xC00_0000</td>
<td>PORTSC1 Register</td>
<td>Page: 380</td>
</tr>
<tr>
<td>0x188</td>
<td>PORTSC2</td>
<td>0xC00_0000</td>
<td>PORTSC2 Register</td>
<td>Page: 381</td>
</tr>
<tr>
<td>0x18C</td>
<td>PORTSC3</td>
<td>0xC00_0000</td>
<td>PORTSC3 Register</td>
<td>Page: 383</td>
</tr>
<tr>
<td>0x190</td>
<td>PORTSC4</td>
<td>0xC00_0000</td>
<td>PORTSC4 Register</td>
<td>Page: 384</td>
</tr>
<tr>
<td>0x194</td>
<td>PORTSC5</td>
<td>0xC00_0000</td>
<td>PORTSC5 Register</td>
<td>Page: 386</td>
</tr>
<tr>
<td>0x198</td>
<td>PORTSC6</td>
<td>0xC00_0000</td>
<td>PORTSC6 Register</td>
<td>Page: 387</td>
</tr>
<tr>
<td>0x19C</td>
<td>PORTSC7</td>
<td>0xC00_0000</td>
<td>PORTSC7 Register</td>
<td>Page: 389</td>
</tr>
<tr>
<td>0x1A0</td>
<td>PORTSC8</td>
<td>0xC00_0000</td>
<td>PORTSC8 Register</td>
<td>Page: 390</td>
</tr>
<tr>
<td>0x1A4</td>
<td>OTGSC</td>
<td>0x0000_0020</td>
<td>OTGSC Register</td>
<td>Page: 392</td>
</tr>
<tr>
<td>0x1A8</td>
<td>USBMODE</td>
<td>0x0000_0002</td>
<td>USB Mode Register</td>
<td>Page: 394</td>
</tr>
<tr>
<td>0x1AC</td>
<td>ENDPTSETUPSTAT</td>
<td>0x0000_0000</td>
<td>Endpoint Setup Stat Register</td>
<td>Page: 394</td>
</tr>
<tr>
<td>0x1B0</td>
<td>ENDPTPRIME</td>
<td>0x0000_0000</td>
<td>Endpoint Prime Register</td>
<td>Page: 395</td>
</tr>
<tr>
<td>0x1B4</td>
<td>ENDPTFLUSH</td>
<td>0x0000_0000</td>
<td>Endpoint Flush Register</td>
<td>Page: 395</td>
</tr>
<tr>
<td>0x1B8</td>
<td>ENDPTSTAT</td>
<td>0x0000_0000</td>
<td>Endpoint Stat Register</td>
<td>Page: 395</td>
</tr>
<tr>
<td>0x1BC</td>
<td>ENDPTCOMPLETE</td>
<td>0x0000_0000</td>
<td>Endpoint Complete Register</td>
<td>Page: 396</td>
</tr>
<tr>
<td>0x1C0</td>
<td>ENDPTCTRL0</td>
<td>0x0081_0080</td>
<td>Endpoint Control 0 Register</td>
<td>Page: 396</td>
</tr>
<tr>
<td>0x1C4</td>
<td>ENDPTCTRL1</td>
<td>0x0000_0000</td>
<td>Endpoint Control 1 Register</td>
<td>Page: 397</td>
</tr>
<tr>
<td>0x1C8</td>
<td>ENDPTCTRL2</td>
<td>0x0000_0000</td>
<td>Endpoint Control 2 Register</td>
<td>Page: 398</td>
</tr>
<tr>
<td>0x1CC</td>
<td>ENDPTCTRL3</td>
<td>0x0000_0000</td>
<td>Endpoint Control 3 Register</td>
<td>Page: 399</td>
</tr>
<tr>
<td>0x1D0</td>
<td>ENDPTCTRL4</td>
<td>0x0000_0000</td>
<td>Endpoint Control 4 Register</td>
<td>Page: 400</td>
</tr>
<tr>
<td>0x1D4</td>
<td>ENDPTCTRL5</td>
<td>0x0000_0000</td>
<td>Endpoint Control 5 Register</td>
<td>Page: 401</td>
</tr>
<tr>
<td>0x1D8</td>
<td>ENDPTCTRL6</td>
<td>0x0000_0000</td>
<td>Endpoint Control 6 Register</td>
<td>Page: 402</td>
</tr>
<tr>
<td>0x1DC</td>
<td>ENDPTCTRL7</td>
<td>0x0000_0000</td>
<td>Endpoint Control 7 Register</td>
<td>Page: 404</td>
</tr>
<tr>
<td>0x1E0</td>
<td>ENDPTCTRL8</td>
<td>0x0000_0000</td>
<td>Endpoint Control 8 Register</td>
<td>Page: 405</td>
</tr>
<tr>
<td>0x1E4</td>
<td>ENDPTCTRL9</td>
<td>0x0000_0000</td>
<td>Endpoint Control 9 Register</td>
<td>Page: 406</td>
</tr>
</tbody>
</table>
### Table 221: USBC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x1E8</td>
<td>ENDPTCTRL10</td>
<td>0x0000_0000</td>
<td>Endpoint Control 10 Register</td>
<td>Page: 407</td>
</tr>
<tr>
<td>0x1EC</td>
<td>ENDPTCTRL11</td>
<td>0x0000_0000</td>
<td>Endpoint Control 11 Register</td>
<td>Page: 408</td>
</tr>
<tr>
<td>0x1F0</td>
<td>ENDPTCTRL12</td>
<td>0x0000_0000</td>
<td>Endpoint Control 12 Register</td>
<td>Page: 409</td>
</tr>
<tr>
<td>0x1F4</td>
<td>ENDPTCTRL13</td>
<td>0x0000_0000</td>
<td>Endpoint Control 13 Register</td>
<td>Page: 410</td>
</tr>
<tr>
<td>0x1F8</td>
<td>ENDPTCTRL14</td>
<td>0x0000_0000</td>
<td>Endpoint Control 14 Register</td>
<td>Page: 411</td>
</tr>
<tr>
<td>0x1FC</td>
<td>ENDPTCTRL15</td>
<td>0x0000_0000</td>
<td>Endpoint Control 15 Register</td>
<td>Page: 412</td>
</tr>
<tr>
<td>0x200</td>
<td>PHY_ID</td>
<td>0x0000_9411</td>
<td>PHY ID Register</td>
<td>Page: 413</td>
</tr>
<tr>
<td>0x204</td>
<td>PLL_Control_0</td>
<td>0x0000_5A78</td>
<td>PLL Control 0 Register</td>
<td>Page: 413</td>
</tr>
<tr>
<td>0x208</td>
<td>PLL_Control_1</td>
<td>0x0000_0231</td>
<td>PLL Control 1 Register</td>
<td>Page: 413</td>
</tr>
<tr>
<td>0x20C</td>
<td>Reserved_Addr3</td>
<td>0x0000_0000</td>
<td>Reserved_Addr3 Register</td>
<td>Page: 414</td>
</tr>
<tr>
<td>0x210</td>
<td>Tx_Channel_Contrl_0</td>
<td>0x0000_0488</td>
<td>TX Channel Control 0 Register</td>
<td>Page: 415</td>
</tr>
<tr>
<td>0x214</td>
<td>Tx_Channel_Contrl_1</td>
<td>0x0000_05B0</td>
<td>TX Channel Control 1 Register</td>
<td>Page: 415</td>
</tr>
<tr>
<td>0x218</td>
<td>Tx_Channel_Contrl_2</td>
<td>0x0000_02FF</td>
<td>TX Channel Control 2 Register</td>
<td>Page: 416</td>
</tr>
<tr>
<td>0x21C</td>
<td>Reserved_Addr7</td>
<td>0x0000_0000</td>
<td>Reserved_Addr7 Register</td>
<td>Page: 417</td>
</tr>
<tr>
<td>0x220</td>
<td>Rx_Channel_Contrl_0</td>
<td>0x0000_AA71</td>
<td>RX Channel Control 0 Register</td>
<td>Page: 417</td>
</tr>
<tr>
<td>0x224</td>
<td>Rx_Channel_Contrl_1</td>
<td>0x0000_3892</td>
<td>RX Channel Control 1 Register</td>
<td>Page: 418</td>
</tr>
<tr>
<td>0x228</td>
<td>Rx_Channel_Contrl_2</td>
<td>0x0000_0125</td>
<td>RX Channel Control 2 Register</td>
<td>Page: 418</td>
</tr>
<tr>
<td>0x230</td>
<td>Ana_Contrl_0</td>
<td>0x0000_0110</td>
<td>ANA Control 0 Register</td>
<td>Page: 419</td>
</tr>
<tr>
<td>0x234</td>
<td>Ana_Contrl_1</td>
<td>0x0000_1680</td>
<td>ANA Control 1 Register</td>
<td>Page: 420</td>
</tr>
<tr>
<td>0x238</td>
<td>Reserved_Addr_C</td>
<td>0x0000_0000</td>
<td>Reserved_Addr_C Register</td>
<td>Page: 420</td>
</tr>
<tr>
<td>0x23C</td>
<td>Digital_Control_0</td>
<td>0x0000_2586</td>
<td>Digital Control 0 Register</td>
<td>Page: 421</td>
</tr>
<tr>
<td>0x240</td>
<td>Digital_Control_1</td>
<td>0x0000_E400</td>
<td>Digital Control 1 Register</td>
<td>Page: 422</td>
</tr>
<tr>
<td>0x244</td>
<td>Digital_Control_2</td>
<td>0x0000_0F13</td>
<td>Digital Control 2 Register</td>
<td>Page: 422</td>
</tr>
<tr>
<td>0x248</td>
<td>Reserved_Addr_12H</td>
<td>0x0000_0000</td>
<td>Reserved_Addr_12H Register</td>
<td>Page: 423</td>
</tr>
<tr>
<td>0x24C</td>
<td>Test_Contrl_and_Status_0</td>
<td>0x0000_0000</td>
<td>Test Control and Status 0 Register</td>
<td>Page: 424</td>
</tr>
<tr>
<td>0x250</td>
<td>Test_Contrl_and_Status_1</td>
<td>0x0000_0060</td>
<td>Test Control and Status 1 Register</td>
<td>Page: 424</td>
</tr>
<tr>
<td>0x254</td>
<td>Reserved_Addr_15H</td>
<td>0x0000_0000</td>
<td>Reserved_Addr_15H Register</td>
<td>Page: 425</td>
</tr>
<tr>
<td>0x258</td>
<td>PHY_REG_CHGDTC_CONTRL</td>
<td>0x0000_0000</td>
<td>PHY REG CHGDTC Control Register</td>
<td>Page: 425</td>
</tr>
<tr>
<td>0x25C</td>
<td>PHY_REG_OTG_CONTROL</td>
<td>0x0000_0000</td>
<td>PHY REG OTG Control Register</td>
<td>Page: 426</td>
</tr>
<tr>
<td>0x260</td>
<td>usb2_phy_mon0</td>
<td>0x0000_0000</td>
<td>USB2 PHY Monitor 0 Register</td>
<td>Page: 427</td>
</tr>
<tr>
<td>0x264</td>
<td>PHY_REG_CHGDTC_CONTRL_1</td>
<td>0x0000_0000</td>
<td>PHY REG CHGDTC Control 1 Register</td>
<td>Page: 427</td>
</tr>
</tbody>
</table>
Table 221: USBC Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x268</td>
<td>Reserved_Addr_1aH</td>
<td>0x0000_0000</td>
<td>Reserved_Addr_1AH Register</td>
<td>Page: 428</td>
</tr>
<tr>
<td>0x26C</td>
<td>Reserved_Addr_1bH</td>
<td>0x0000_0000</td>
<td>Reserved_Addr_1BH Register</td>
<td>Page: 428</td>
</tr>
<tr>
<td>0x270</td>
<td>Reserved_Addr_1cH</td>
<td>0x0000_0000</td>
<td>Reserved_Addr_1CH Register</td>
<td>Page: 429</td>
</tr>
<tr>
<td>0x274</td>
<td>Reserved_Addr_1dH</td>
<td>0x0000_0000</td>
<td>Reserved_Addr_1DH Register</td>
<td>Page: 429</td>
</tr>
<tr>
<td>0x278</td>
<td>Internal_CID</td>
<td>0x0000_9411</td>
<td>Internal CID Register</td>
<td>Page: 429</td>
</tr>
<tr>
<td>0x27C</td>
<td>usb2_icid_reg1</td>
<td>0x0000_0080</td>
<td>USB2 ICID Register 1</td>
<td>Page: 430</td>
</tr>
</tbody>
</table>

24.3.2 USBC Registers

24.3.2.1 ID Register (ID)

Table 222: ID Register (ID)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:29</td>
<td>civersion</td>
<td>R 0x7</td>
<td>CIVERSION</td>
</tr>
<tr>
<td>28:25</td>
<td>version</td>
<td>R 0x2</td>
<td>VERSION</td>
</tr>
<tr>
<td>24:21</td>
<td>revision</td>
<td>R 0x0</td>
<td>REVISION</td>
</tr>
<tr>
<td>20:16</td>
<td>tag</td>
<td>R 0x1</td>
<td>TAG</td>
</tr>
<tr>
<td>15:14</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>13:8</td>
<td>nid</td>
<td>R 0x3A</td>
<td>NID</td>
</tr>
<tr>
<td>7:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5:0</td>
<td>id</td>
<td>R 0x5</td>
<td>ID</td>
</tr>
</tbody>
</table>
### 24.3.2.2 HW General Register (HWGENERAL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HWGENERAL</td>
<td>0x004</td>
</tr>
</tbody>
</table>

**Table 223: HW General Register (HWGENERAL)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>reserved_12</td>
<td>R 0x0</td>
<td>Reserved_12</td>
</tr>
<tr>
<td>11:10</td>
<td>sm</td>
<td>R 0x0</td>
<td>SM</td>
</tr>
<tr>
<td>9:6</td>
<td>phym</td>
<td>R 0x0</td>
<td>PHYM</td>
</tr>
<tr>
<td>5:4</td>
<td>phyw</td>
<td>R 0x0</td>
<td>PHYW</td>
</tr>
<tr>
<td>3</td>
<td>bwt</td>
<td>R 0x0</td>
<td>BWT</td>
</tr>
<tr>
<td>2:1</td>
<td>clkc</td>
<td>R 0x0</td>
<td>CLKC</td>
</tr>
<tr>
<td>0</td>
<td>rt</td>
<td>R 0x0</td>
<td>RT</td>
</tr>
</tbody>
</table>

### 24.3.2.3 HW Host Register (HWHOST)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HWHOST</td>
<td>0x008</td>
</tr>
</tbody>
</table>

**Table 224: HW Host Register (HWHOST)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>ttper</td>
<td>R 0x0</td>
<td>TTPER</td>
</tr>
<tr>
<td>23:16</td>
<td>ttasy</td>
<td>R 0x0</td>
<td>TTASY</td>
</tr>
<tr>
<td>15:4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:1</td>
<td>nport</td>
<td>R 0x0</td>
<td>NPORT</td>
</tr>
<tr>
<td>0</td>
<td>hc</td>
<td>R 0x0</td>
<td>HC</td>
</tr>
</tbody>
</table>
24.3.2.4  HW Device Register (HWDEVICE)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HWDEVICE</td>
<td>0x00C</td>
</tr>
</tbody>
</table>

Table 225: HW Device Register (HWDEVICE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>reserved_6</td>
<td>R 0x0</td>
<td>Reserved_6</td>
</tr>
<tr>
<td>5:1</td>
<td>devep</td>
<td>R 0x1</td>
<td>DEVEP</td>
</tr>
<tr>
<td>0</td>
<td>dc</td>
<td>R 0x0</td>
<td>DC</td>
</tr>
</tbody>
</table>

24.3.2.5  HW TXBUF Register (HWTXBUF)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HWTXBUF</td>
<td>0x010</td>
</tr>
</tbody>
</table>

Table 226: HW TXBUF Register (HWTXBUF)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>30:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23:16</td>
<td>txchanadd</td>
<td>R 0x0</td>
<td>TXCHANADD</td>
</tr>
<tr>
<td>15:8</td>
<td>txadd</td>
<td>R 0x0</td>
<td>TXADD</td>
</tr>
<tr>
<td>7:0</td>
<td>txburst</td>
<td>R 0x0</td>
<td>TXBURST</td>
</tr>
</tbody>
</table>

24.3.2.6  HW RXBUF Register (HWRXBUF)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HWRXBUF</td>
<td>0x014</td>
</tr>
</tbody>
</table>
### 24.3.2.7 HW TXBUF0 Register (HWTXBUF0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HWTXBUF0</td>
<td>0x018</td>
</tr>
</tbody>
</table>

### Table 228: HW TXBUF0 Register (HWTXBUF0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>txburst</td>
<td>R/W 0x7777</td>
<td>TX Burst</td>
</tr>
</tbody>
</table>

### 24.3.2.8 HW TXBUF1 Register (HWTXBUF1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HWTXBUF1</td>
<td>0x01C</td>
</tr>
</tbody>
</table>

### Table 229: HW TXBUF1 Register (HWTXBUF1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>txburst</td>
<td>R/W 0x7777</td>
<td>TX Burst</td>
</tr>
</tbody>
</table>

### 24.3.2.9 GPTIMER0LD Register (GPTIMER0LD)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPTIMER0LD Register</td>
<td>0x080</td>
</tr>
</tbody>
</table>
## 24.3.2.10 GPTIMER0CTRL (GPTIMER0CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPTIMER0CTRL</td>
<td>0x084</td>
</tr>
</tbody>
</table>

### Table 231: GPTIMER0CTRL (GPTIMER0CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>gpotrue</td>
<td>R/W 0x0</td>
<td>GPTRUN</td>
</tr>
<tr>
<td>30</td>
<td>gpotrue</td>
<td>R 0x0</td>
<td>GPTTRST</td>
</tr>
<tr>
<td>29:25</td>
<td>reserved_25</td>
<td>R 0x0</td>
<td>Reserved_25</td>
</tr>
<tr>
<td>24</td>
<td>gptmode</td>
<td>R/W 0x0</td>
<td>GPTMODE</td>
</tr>
<tr>
<td>23:0</td>
<td>gptcnt</td>
<td>R 0x0</td>
<td>GPTCINT</td>
</tr>
</tbody>
</table>

## 24.3.2.11 GPTTIMERT1LD Register (GPTTIMERT1LD)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPTTIMERT1LD</td>
<td>0x088</td>
</tr>
</tbody>
</table>

### Table 232: GPTTIMERT1LD Register (GPTTIMERT1LD)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R/W 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23:0</td>
<td>gptld</td>
<td>R/W 0x0</td>
<td>GPTLD</td>
</tr>
</tbody>
</table>
24.3.2.12 GP Timer1 Control Register (GPTIMER1CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPTIMER1CTRL</td>
<td>0x08C</td>
</tr>
</tbody>
</table>

Table 233: GP Timer1 Control Register (GPTIMER1CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>gptrun</td>
<td>R/W 0x0</td>
<td>GPTRUN</td>
</tr>
<tr>
<td>30</td>
<td>gprrst</td>
<td>R 0x0</td>
<td>GPTRST</td>
</tr>
<tr>
<td>29:25</td>
<td>reserved_25</td>
<td>R 0x0</td>
<td>Reserved_25</td>
</tr>
<tr>
<td>24</td>
<td>gptmode</td>
<td>R/W 0x0</td>
<td>GPTMODE</td>
</tr>
<tr>
<td>23:0</td>
<td>gptcnt</td>
<td>R 0x0</td>
<td>GPTCNT</td>
</tr>
</tbody>
</table>

24.3.2.13 SBUS Config Register (SBUSCFG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SBUSCFG</td>
<td>0x090</td>
</tr>
</tbody>
</table>

Table 234: SBUS Config Register (SBUSCFG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>reserved_3</td>
<td>R 0x0</td>
<td>Reserved_3</td>
</tr>
<tr>
<td>2:0</td>
<td>ahbbbrst</td>
<td>R/W 0x0</td>
<td>AHB BRST</td>
</tr>
</tbody>
</table>

24.3.2.14 Cap Length Regiser (CAPLENGTH)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CAPLENGTH</td>
<td>0x100</td>
</tr>
</tbody>
</table>
### Table 235: Cap Length Register (CAPLENGTH)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>hciVersion</td>
<td>R 0x100</td>
<td>HCU Version</td>
</tr>
<tr>
<td>15:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:0</td>
<td>caplength</td>
<td>R 0x40</td>
<td>Cap Lengh</td>
</tr>
</tbody>
</table>

### Table 236: HCS Params Register (HCSPARAMS)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HCSPARAMS</td>
<td>0x104</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:28</td>
<td>reserved_28</td>
<td>R 0x0</td>
<td>Reserved_28</td>
</tr>
<tr>
<td>27:24</td>
<td>n_tt</td>
<td>R 0x0</td>
<td>N_TT</td>
</tr>
<tr>
<td>23:20</td>
<td>n_ptt</td>
<td>R 0x0</td>
<td>N_PTT</td>
</tr>
<tr>
<td>19:17</td>
<td>reserved_17</td>
<td>R 0x0</td>
<td>Reserved_17</td>
</tr>
<tr>
<td>16</td>
<td>n_tt</td>
<td>R 0x1</td>
<td>N_TT</td>
</tr>
<tr>
<td>15:12</td>
<td>n_ptt</td>
<td>R 0x0</td>
<td>N_PTT</td>
</tr>
<tr>
<td>11:8</td>
<td>n_pcc</td>
<td>R 0x0</td>
<td>N_PCC</td>
</tr>
<tr>
<td>7:5</td>
<td>reserved_5</td>
<td>R 0x0</td>
<td>Reserved_5</td>
</tr>
<tr>
<td>4</td>
<td>ppc</td>
<td>R 0x0</td>
<td>PPC</td>
</tr>
<tr>
<td>3:0</td>
<td>n_ports</td>
<td>R 0x0</td>
<td>N_PORTS</td>
</tr>
</tbody>
</table>
24.3.2.16  HCC Params Register (HCCPARAMS)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HCCPARAMS Register</td>
<td>0x108</td>
</tr>
</tbody>
</table>

**Table 237: HCC Params Register (HCCPARAMS)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>reserved_16</td>
<td>R 0x0</td>
<td>Reserved_16</td>
</tr>
<tr>
<td>15:8</td>
<td>eecp</td>
<td>R 0x0</td>
<td>EECP</td>
</tr>
<tr>
<td>7:4</td>
<td>ist</td>
<td>R 0x0</td>
<td>IST</td>
</tr>
<tr>
<td>3</td>
<td>reserved_3</td>
<td>R 0x0</td>
<td>Reserved_3</td>
</tr>
<tr>
<td>2</td>
<td>asp</td>
<td>R 0x1</td>
<td>ASP</td>
</tr>
<tr>
<td>1</td>
<td>pfl</td>
<td>R 0x1</td>
<td>PFL</td>
</tr>
<tr>
<td>0</td>
<td>adc</td>
<td>R 0x0</td>
<td>ADC</td>
</tr>
</tbody>
</table>

24.3.2.17  DCI Version Register (DCIVERSION)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DCIVERSION</td>
<td>0x120</td>
</tr>
</tbody>
</table>

**Table 238: DCI Version Register (DCIVERSION)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>dciversion</td>
<td>R 0x1</td>
<td>DCI Version</td>
</tr>
</tbody>
</table>
24.3.2.18 DCC Params Register (DCCPARAMS)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DCCPARAMS Register</td>
<td>0x124</td>
</tr>
</tbody>
</table>

Table 239: DCC Params Register (DCCPARAMS)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>lpm_en</td>
<td>R 0x1</td>
<td>LPM_EN</td>
</tr>
<tr>
<td>30:9</td>
<td>reserved_9</td>
<td>R 0x0</td>
<td>Reserved_9</td>
</tr>
<tr>
<td>8</td>
<td>hc</td>
<td>R 0x0</td>
<td>HC</td>
</tr>
<tr>
<td>7:5</td>
<td>dc</td>
<td>R 0x0</td>
<td>DC</td>
</tr>
<tr>
<td>6:5</td>
<td>reserved_5</td>
<td>R 0x0</td>
<td>Reserved_5</td>
</tr>
<tr>
<td>4:0</td>
<td>den</td>
<td>R 0x0</td>
<td>DEN</td>
</tr>
</tbody>
</table>

24.3.2.19 DevLPMCSR Register (DevLPMCSR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DevLPMCSR</td>
<td>0x128</td>
</tr>
</tbody>
</table>

Table 240: DevLPMCSR Register (DevLPMCSR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>lpm_rsp</td>
<td>R 0x0</td>
<td>LPM_RSP Register</td>
</tr>
<tr>
<td>29</td>
<td>lpm_phcd_only</td>
<td>R/W 0x0</td>
<td>LPM_PHCD_only</td>
</tr>
<tr>
<td>28</td>
<td>brmtwake</td>
<td>R 0x0</td>
<td>BRMTWAKE</td>
</tr>
<tr>
<td>27:24</td>
<td>linkstate</td>
<td>R 0x0</td>
<td>LINKSTATE</td>
</tr>
<tr>
<td>23:20</td>
<td>hird</td>
<td>R 0x0</td>
<td>HIRD</td>
</tr>
<tr>
<td>19:18</td>
<td>reserved_18</td>
<td>R 0x0</td>
<td>Reserved_18</td>
</tr>
</tbody>
</table>
Table 240: DevLPMCSR Register (DevLPMCSR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17</td>
<td>lpm_any_ep</td>
<td>R/W 0x0</td>
<td>LPM_ANY_EP</td>
</tr>
<tr>
<td>16</td>
<td>hst_rsm_en</td>
<td>R/W 0x1</td>
<td>HST_RSM_EN</td>
</tr>
<tr>
<td>15</td>
<td>lpm_on</td>
<td>R/W 0x1</td>
<td>LPM_ON</td>
</tr>
<tr>
<td>14</td>
<td>always_log</td>
<td>R/W 0x1</td>
<td>ALWAYS_LOG</td>
</tr>
<tr>
<td>13</td>
<td>min_slp_en</td>
<td>R/W 0x1</td>
<td>MIN_SLP_EN</td>
</tr>
<tr>
<td>12</td>
<td>stall_ok</td>
<td>R/W 0x1</td>
<td>STALL_OK</td>
</tr>
<tr>
<td>11</td>
<td>ack_ok</td>
<td>R/W 0x0</td>
<td>ACK_OK</td>
</tr>
<tr>
<td>10</td>
<td>ie_l1state</td>
<td>R/W 0x0</td>
<td>IE_L1STATE</td>
</tr>
<tr>
<td>9</td>
<td>l1state</td>
<td>R/W 0x0</td>
<td>L1STATE</td>
</tr>
<tr>
<td>8</td>
<td>rwake_en</td>
<td>R/W 0x0</td>
<td>RWAKE_EN</td>
</tr>
<tr>
<td>7</td>
<td>ie_lpmerr</td>
<td>R/W 0x0</td>
<td>IE_LPMERR</td>
</tr>
<tr>
<td>6</td>
<td>ie_lpmack</td>
<td>R/W 0x0</td>
<td>IE_LPMACK</td>
</tr>
<tr>
<td>5</td>
<td>ie_lpmpkt</td>
<td>R/W 0x0</td>
<td>IE_LPMPKT</td>
</tr>
<tr>
<td>4</td>
<td>ie_l1rsm</td>
<td>R/W 0x0</td>
<td>IE_L1RSM</td>
</tr>
<tr>
<td>3</td>
<td>int_lpmerr</td>
<td>R/W 0x0</td>
<td>INT_LPMERR</td>
</tr>
<tr>
<td>2</td>
<td>int_lpmack</td>
<td>R/W 0x0</td>
<td>INT_LPMACK</td>
</tr>
<tr>
<td>1</td>
<td>int_lpmpkt</td>
<td>R/W 0x0</td>
<td>INT_LPMPKT</td>
</tr>
<tr>
<td>0</td>
<td>int_l1rsm</td>
<td>R/W 0x0</td>
<td>INT_L1RSM</td>
</tr>
</tbody>
</table>
### 24.3.2.20 USB Command Register (USBCMD)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>USBCMD</td>
<td>0x140</td>
</tr>
</tbody>
</table>

#### Table 241: USB Command Register (USBCMD)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23:16</td>
<td>itc</td>
<td>R/W 0x8</td>
<td>ITC</td>
</tr>
<tr>
<td>15</td>
<td>fs2</td>
<td>R/W 0x0</td>
<td>HOST Only</td>
</tr>
<tr>
<td>14</td>
<td>atdtw</td>
<td>R/W 0x0</td>
<td>ATDTW</td>
</tr>
<tr>
<td>13</td>
<td>sutw</td>
<td>R/W 0x0</td>
<td>SUTW</td>
</tr>
<tr>
<td>12</td>
<td>reserved_12</td>
<td>R 0x0</td>
<td>Reserved_12</td>
</tr>
<tr>
<td>11</td>
<td>aspe</td>
<td>R/W 0x1</td>
<td>ASPE</td>
</tr>
<tr>
<td>10</td>
<td>reserved_10</td>
<td>R 0x0</td>
<td>Reserved_10</td>
</tr>
<tr>
<td>9</td>
<td>asp1</td>
<td>R/W 0x1</td>
<td>ASP1</td>
</tr>
<tr>
<td>8</td>
<td>asp0</td>
<td>R/W 0x1</td>
<td>ASP0</td>
</tr>
<tr>
<td>7</td>
<td>lr</td>
<td>R 0x0</td>
<td>LR</td>
</tr>
<tr>
<td>6</td>
<td>iaa</td>
<td>R/W 0x0</td>
<td>HOST Only</td>
</tr>
<tr>
<td>5</td>
<td>ase</td>
<td>R/W 0x0</td>
<td>HOST Only</td>
</tr>
<tr>
<td>4</td>
<td>pse</td>
<td>R/W 0x0</td>
<td>HOST Only</td>
</tr>
<tr>
<td>3</td>
<td>fs1</td>
<td>R/W 0x0</td>
<td>HOST Only</td>
</tr>
<tr>
<td>2</td>
<td>fs0</td>
<td>R/W 0x0</td>
<td>HOST Only</td>
</tr>
<tr>
<td>1</td>
<td>rst</td>
<td>R/W 0x0</td>
<td>RST</td>
</tr>
</tbody>
</table>
## 24.3.2.21 USB STS Register (USBSTS)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>rs</td>
<td>R/W 0x0</td>
<td>RS</td>
</tr>
</tbody>
</table>

### Table 242: USB STS Register (USBSTS)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:26</td>
<td>reserved_26</td>
<td>R 0x0</td>
<td>Reserved_26</td>
</tr>
<tr>
<td>25</td>
<td>ti1</td>
<td>R/W 0x0</td>
<td>TI1 (rwc)</td>
</tr>
<tr>
<td>24</td>
<td>ti0</td>
<td>R/W 0x0</td>
<td>TI0 (rwc)</td>
</tr>
<tr>
<td>23:20</td>
<td>reserved_20</td>
<td>R/W 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19</td>
<td>upi</td>
<td>R/W 0x0</td>
<td>UPI (rwc)</td>
</tr>
<tr>
<td>18</td>
<td>uai</td>
<td>R/W 0x0</td>
<td>UAI (rwc)</td>
</tr>
<tr>
<td>17</td>
<td>reserved_17</td>
<td>R 0x0</td>
<td>Reserved_17</td>
</tr>
<tr>
<td>16</td>
<td>naki</td>
<td>R 0x0</td>
<td>NAKI</td>
</tr>
<tr>
<td>15</td>
<td>as</td>
<td>R 0x0</td>
<td>AS</td>
</tr>
<tr>
<td>14</td>
<td>ps</td>
<td>R 0x0</td>
<td>PS</td>
</tr>
<tr>
<td>13</td>
<td>rcl</td>
<td>R 0x0</td>
<td>RCL</td>
</tr>
<tr>
<td>12</td>
<td>hch</td>
<td>R 0x1</td>
<td>HCH</td>
</tr>
<tr>
<td>11</td>
<td>reserved_11</td>
<td>R 0x0</td>
<td>Reserved_11</td>
</tr>
</tbody>
</table>
Table 242: USB STS Register (USBSTS) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>ulpii</td>
<td>R/W 0x0</td>
<td>ULPiI (rwc)</td>
</tr>
<tr>
<td>9</td>
<td>reserved_9</td>
<td>R 0x0</td>
<td>Reserved_9</td>
</tr>
<tr>
<td>8</td>
<td>sli</td>
<td>R/W 0x0</td>
<td>SLI (rwc)</td>
</tr>
<tr>
<td>7</td>
<td>sri</td>
<td>R/W 0x0</td>
<td>SRI (rwc)</td>
</tr>
<tr>
<td>6</td>
<td>uri</td>
<td>R/W 0x0</td>
<td>URI (rwc)</td>
</tr>
<tr>
<td>5</td>
<td>aai</td>
<td>R/W 0x0</td>
<td>AAI (rwc)</td>
</tr>
<tr>
<td>4</td>
<td>sei</td>
<td>R/W 0x0</td>
<td>SEI (rwc)</td>
</tr>
<tr>
<td>3</td>
<td>fri</td>
<td>R/W 0x0</td>
<td>FRI (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pci</td>
<td>R/W 0x0</td>
<td>PCI (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>uei</td>
<td>R/W 0x0</td>
<td>UEI (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ui</td>
<td>R/W 0x0</td>
<td>UI (rwc)</td>
</tr>
</tbody>
</table>

24.3.2.22 USB Interrupt Register (USBINTR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>USBINTR</td>
<td>0x148</td>
</tr>
</tbody>
</table>

Table 243: USB Interrupt Register (USBINTR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:26</td>
<td>reserved_26</td>
<td>R 0x0</td>
<td>Reserved_26</td>
</tr>
<tr>
<td>25</td>
<td>tie1</td>
<td>R/W 0x0</td>
<td>TIE1</td>
</tr>
<tr>
<td>24</td>
<td>tie0</td>
<td>R/W 0x0</td>
<td>TIE0</td>
</tr>
</tbody>
</table>
Table 243: USB Interrupt Register (USBINTR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>23:20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19</td>
<td>upe</td>
<td>R/W 0x0</td>
<td>UPE (not Used in Device mode)</td>
</tr>
<tr>
<td>18</td>
<td>uae</td>
<td>R/W 0x0</td>
<td>UAE (not Used in Device mode)</td>
</tr>
<tr>
<td>17</td>
<td>reserved_17</td>
<td>R 0x0</td>
<td>Reserved_17</td>
</tr>
<tr>
<td>16</td>
<td>nake</td>
<td>R 0x0</td>
<td>NAKE</td>
</tr>
<tr>
<td>15</td>
<td>reserved_15</td>
<td>R 0x0</td>
<td>Not Define in DUT, AS</td>
</tr>
<tr>
<td>14</td>
<td>reserved_14</td>
<td>R 0x0</td>
<td>Not Define in DUT, PS</td>
</tr>
<tr>
<td>13</td>
<td>reserved_13</td>
<td>R 0x0</td>
<td>Not Define in DUT, RCL</td>
</tr>
<tr>
<td>12</td>
<td>reserved_12</td>
<td>R/W 0x0</td>
<td>Reserved_12</td>
</tr>
<tr>
<td>11</td>
<td>reserved_11</td>
<td>R/W 0x0</td>
<td>Reserved_11</td>
</tr>
<tr>
<td>10</td>
<td>ulpe</td>
<td>R/W 0x0</td>
<td>ULPE Only used VUSB_HS_PHY_ULPI =1.</td>
</tr>
<tr>
<td>9</td>
<td>reserved_9</td>
<td>R/W 0x0</td>
<td>Reserved_9</td>
</tr>
<tr>
<td>8</td>
<td>sle</td>
<td>R/W 0x0</td>
<td>SLE</td>
</tr>
<tr>
<td>7</td>
<td>sre</td>
<td>R/W 0x0</td>
<td>SRE</td>
</tr>
<tr>
<td>6</td>
<td>ure</td>
<td>R/W 0x0</td>
<td>URE</td>
</tr>
<tr>
<td>5</td>
<td>aae</td>
<td>R/W 0x0</td>
<td>AAE (HOST only)</td>
</tr>
<tr>
<td>4</td>
<td>see</td>
<td>R/W 0x0</td>
<td>SEE</td>
</tr>
<tr>
<td>3</td>
<td>fre</td>
<td>R/W 0x0</td>
<td>FRE (HOST only)</td>
</tr>
<tr>
<td>2</td>
<td>pce</td>
<td>R/W 0x0</td>
<td>PCE</td>
</tr>
</tbody>
</table>
### Table 243: USB Interrupt Register (USBINTR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>uee</td>
<td>R/W 0x0</td>
<td>UEE (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ue</td>
<td>R/W 0x0</td>
<td>UE</td>
</tr>
</tbody>
</table>

### 24.3.2.23 FR Index Register (FRINDEX)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FRINDEX</td>
<td>0x14C</td>
</tr>
</tbody>
</table>

#### Table 244: FR Index Register (FRINDEX)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:14</td>
<td>reserved_14</td>
<td>R 0x0</td>
<td>Reserved_14</td>
</tr>
<tr>
<td>13:0</td>
<td>frindex</td>
<td>R/W 0x0</td>
<td>FRINDEX</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Device RO; Host R/W.</td>
</tr>
</tbody>
</table>

### 24.3.2.24 Periodic List Base Register (PERIODICLISTBASE)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PERIODICLISTBASE</td>
<td>0x154</td>
</tr>
</tbody>
</table>

#### Table 245: Periodic List Base Register (PERIODICLISTBASE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:25</td>
<td>usbadr</td>
<td>R/W 0x0</td>
<td>USBADR</td>
</tr>
<tr>
<td>24</td>
<td>usbadra</td>
<td>R/W 0x0</td>
<td>USBADRA</td>
</tr>
<tr>
<td>23:0</td>
<td>reserved_0</td>
<td>R 0x0</td>
<td>Reserved_0</td>
</tr>
</tbody>
</table>
24.3.2.25 Async List Address Register (ASYNCLISTADDR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ASYNCLISTADDR</td>
<td>0x158</td>
</tr>
</tbody>
</table>

Table 246: Async List Address Register (ASYNCLISTADDR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>epbase</td>
<td>R/W 0x0</td>
<td>EPBASE</td>
</tr>
<tr>
<td>10:0</td>
<td>reserved_0</td>
<td>R 0x0</td>
<td>Reserved_0</td>
</tr>
</tbody>
</table>

24.3.2.26 TT Control Register (TTCTRL Register)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TTCTRL Register</td>
<td>0x15C</td>
</tr>
</tbody>
</table>

Table 247: TT Control Register (TTCTRL Register)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>reserved_31</td>
<td>R 0x0</td>
<td>Reserved_31</td>
</tr>
<tr>
<td>30:24</td>
<td>ttha</td>
<td>R/W 0x0</td>
<td>TTHA</td>
</tr>
<tr>
<td>23:2</td>
<td>reserved_2</td>
<td>R 0x0</td>
<td>Reserved_2</td>
</tr>
<tr>
<td>1</td>
<td>ttac</td>
<td>R/W 0x0</td>
<td>TTAC</td>
</tr>
<tr>
<td>0</td>
<td>ttas</td>
<td>R 0x0</td>
<td>TTAS</td>
</tr>
</tbody>
</table>

24.3.2.27 Burst Size Register (BURSTSIZE)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BURSTSIZE</td>
<td>0x160</td>
</tr>
</tbody>
</table>
### 24.3.2.28 TX Fill Tuning Register (TXFILLTUNING)

**Table 249: TX Fill Tuning Register (TXFILLTUNING)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:22</td>
<td>reserved_22</td>
<td>R 0x0</td>
<td>Reserved_22</td>
</tr>
<tr>
<td>21:16</td>
<td>txfifothres</td>
<td>R/W 0x2</td>
<td>TX FIFO Threshold Only use in HOST &amp; MPH mode.</td>
</tr>
<tr>
<td>15:13</td>
<td>reserved_13</td>
<td>R 0x0</td>
<td>Reserved_13</td>
</tr>
<tr>
<td>12:8</td>
<td>txschhealth</td>
<td>R/W 0x0</td>
<td>TXSCHHEALTH Only use in HOST &amp; MPH mode, rwc.</td>
</tr>
<tr>
<td>7</td>
<td>reserved_7</td>
<td>R 0x0</td>
<td>Reserved_7</td>
</tr>
<tr>
<td>6:0</td>
<td>txschoh</td>
<td>R/W 0x0</td>
<td>TXSCHOH Only use in HOST &amp; MPH mode.</td>
</tr>
</tbody>
</table>

### 24.3.2.29 TX TT Fill Tuning Register (TXTTFILLTUNING)

**Table 248: Burst Size Register (BURSTSIZE)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>reserved_16</td>
<td>R 0x0</td>
<td>Reserved_16</td>
</tr>
<tr>
<td>15:8</td>
<td>txpburst</td>
<td>R/W 0x0</td>
<td>TXP Burst</td>
</tr>
<tr>
<td>7:0</td>
<td>rxpburst</td>
<td>R/W 0x0</td>
<td>RXP Burst</td>
</tr>
</tbody>
</table>

**Instance Name Offset**

| TXFILLTUNING | 0x164 |

<table>
<thead>
<tr>
<th>Instance Name Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TXTTFILLTUNING 0x168</td>
</tr>
</tbody>
</table>
### Table 250: TX TT Fill Tuning Register (TXTTFILLTUNING)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:13</td>
<td>reserved_13</td>
<td>R</td>
<td>Reserved_13</td>
</tr>
<tr>
<td>12:8</td>
<td>txttschhealtj</td>
<td>R/W</td>
<td>TXTTSCHHEALTJ Only use in HOST &amp; MPH mode, rwc.</td>
</tr>
<tr>
<td>7:5</td>
<td>reserved_5</td>
<td>R</td>
<td>Reserved_5</td>
</tr>
<tr>
<td>4:0</td>
<td>txttschoh</td>
<td>R/W</td>
<td>TXTTSCHOH Only use in HOST &amp; MPH mode.</td>
</tr>
</tbody>
</table>

### 24.3.2.30 IC USB Register (IC_USB)

#### Instance Name Offset
<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_USB</td>
<td>0x16C</td>
</tr>
</tbody>
</table>

#### Table 251: IC USB Register (IC_USB)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>ic8</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>30:28</td>
<td>ic_vdd8</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>27</td>
<td>ic7</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>26:24</td>
<td>ic_vdd7</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>23</td>
<td>ic6</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>22:20</td>
<td>ic_vdd6</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>19</td>
<td>ic5</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>18:16</td>
<td>ic_vdd5</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>15</td>
<td>ic4</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>14:12</td>
<td>ic_vdd4</td>
<td>R/W</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
</tbody>
</table>
### Table 251: IC USB Register (IC_USB) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>ic3</td>
<td>R/W 0x0</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>10:8</td>
<td>ic_vdd3</td>
<td>R/W 0x0</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>7</td>
<td>ic2</td>
<td>R/W 0x0</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>6:4</td>
<td>ic_vdd2</td>
<td>R/W 0x0</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>3</td>
<td>ic1</td>
<td>R/W 0x0</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
<tr>
<td>2:0</td>
<td>ic_vdd1</td>
<td>R/W 0x0</td>
<td>Available in MPH &amp; VUSB_HS_PHY_IC_USB =1</td>
</tr>
</tbody>
</table>

### 24.3.2.31 ULPI Viewport Register (ULPI_VIEWPORT)

#### Instance Name Offset

| ULPI_VIEWPORT   | 0x170 |

#### Table 252: ULPI Viewport Register (ULPI_VIEWPORT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>ulpiwu</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
<tr>
<td>30</td>
<td>ulpirun</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
<tr>
<td>29</td>
<td>ulpirw</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
<tr>
<td>28</td>
<td>reserved_28</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
<tr>
<td>27</td>
<td>ulpiss</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
<tr>
<td>26:24</td>
<td>ulpiport</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
<tr>
<td>23:16</td>
<td>ulpiaddr</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
<tr>
<td>15:8</td>
<td>ulpidatrd</td>
<td>R 0x0</td>
<td>Not Available</td>
</tr>
</tbody>
</table>
24.3.2.32 Endpoint NAK Register (ENDPTNAK)

Table 253: Endpoint NAK Register (ENDPTNAK)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>eptn</td>
<td>R/W 0x0</td>
<td>EPTN (rwc)</td>
</tr>
<tr>
<td>15:0</td>
<td>eprn</td>
<td>R/W 0x0</td>
<td>EPRN (rwc)</td>
</tr>
</tbody>
</table>

24.3.2.33 Endpoint NAKEN (ENDPTNAKEN)

Table 254: Endpoint NAKEN Register (ENDPTNAKEN)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>eptne</td>
<td>R/W 0x0</td>
<td>EPTNE</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Only 3 PHY max.</td>
</tr>
<tr>
<td>15:0</td>
<td>eprne</td>
<td>R/W 0x0</td>
<td>EPRNE</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Only 3 PHY max.</td>
</tr>
</tbody>
</table>

24.3.2.34 PORTSC1 Register (PORTSC1)

Table 255: PORTSC1 Register (PORTSC1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:0</td>
<td>ulpidatwr</td>
<td>R/W 0x0</td>
<td>Not Available</td>
</tr>
</tbody>
</table>

Table 252: ULPI Viewport Register (ULPI_VIEWPORT) (Continued)
## Table 255: PORTSC1 Register (PORTSC1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R/ 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcn</td>
<td>R/W 0x0</td>
<td>WKCN</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
<tr>
<td>7</td>
<td>susp</td>
<td>R/W 0x0</td>
<td>SUSP</td>
</tr>
<tr>
<td>6</td>
<td>fpr</td>
<td>R/W 0x0</td>
<td>FPR</td>
</tr>
</tbody>
</table>
### Table 255: PORTSC1 Register (PORTSC1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>occ</td>
<td>R/W 0x0</td>
<td>OCC</td>
</tr>
<tr>
<td>4</td>
<td>oca</td>
<td>R 0x0</td>
<td>OCA</td>
</tr>
<tr>
<td>3</td>
<td>pec</td>
<td>R 0x0</td>
<td>PEC (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>PE (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>csc</td>
<td>R 0x0</td>
<td>CSC (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ccs</td>
<td>R 0x0</td>
<td>CCS</td>
</tr>
</tbody>
</table>

### 24.3.2.35 PORTSC2 Register (PORTSC2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PORTSC2</td>
<td>0x188</td>
</tr>
</tbody>
</table>

### Table 256: PORTSC2 Register (PORTSC2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
</tbody>
</table>
Table 256: PORTSC2 Register (PORTSC2) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcн</td>
<td>R/W 0x0</td>
<td>WKCН</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
<tr>
<td>7</td>
<td>susp</td>
<td>R/W 0x0</td>
<td>SUSP</td>
</tr>
<tr>
<td>6</td>
<td>fpr</td>
<td>R/W 0x0</td>
<td>FPR</td>
</tr>
<tr>
<td>5</td>
<td>occ</td>
<td>R/W 0x0</td>
<td>OCC</td>
</tr>
<tr>
<td>4</td>
<td>oca</td>
<td>R 0x0</td>
<td>OCA</td>
</tr>
<tr>
<td>3</td>
<td>pec</td>
<td>R 0x0</td>
<td>PEC (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>PE (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>csc</td>
<td>R 0x0</td>
<td>CSC (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ccs</td>
<td>R 0x0</td>
<td>CCS</td>
</tr>
</tbody>
</table>
24.3.2.36 PORTSC3 Register (PORTSC3)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PORTSC3</td>
<td>0x18C</td>
</tr>
</tbody>
</table>

Table 257: PORTSC3 Register (PORTSC3)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcn</td>
<td>R/W 0x0</td>
<td>WKCN</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
</tbody>
</table>
Table 257: PORTSC3 Register (PORTSC3) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>susp</td>
<td>R/W 0x0</td>
<td>SUSP</td>
</tr>
<tr>
<td>6</td>
<td>fpr</td>
<td>R/W 0x0</td>
<td>FPR</td>
</tr>
<tr>
<td>5</td>
<td>occ</td>
<td>R/W 0x0</td>
<td>OCC</td>
</tr>
<tr>
<td>4</td>
<td>oca</td>
<td>R 0x0</td>
<td>OCA</td>
</tr>
<tr>
<td>3</td>
<td>pec</td>
<td>R 0x0</td>
<td>PEC (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>PE (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>csc</td>
<td>R 0x0</td>
<td>CSC (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ccs</td>
<td>R 0x0</td>
<td>CCS</td>
</tr>
</tbody>
</table>

24.3.2.37 PORTSC4 Register (PORTSC4)

Table 258: PORTSC4 Register (PORTSC4)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
</tbody>
</table>
## Table 258: PORTSC4 Register (PORTSC4) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcn</td>
<td>R/W 0x0</td>
<td>WKCN</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
<tr>
<td>7</td>
<td>susp</td>
<td>R/W 0x0</td>
<td>SUSP</td>
</tr>
<tr>
<td>6</td>
<td>fpr</td>
<td>R/W 0x0</td>
<td>FPR</td>
</tr>
<tr>
<td>5</td>
<td>occ</td>
<td>R/W 0x0</td>
<td>OCC</td>
</tr>
<tr>
<td>4</td>
<td>oca</td>
<td>R 0x0</td>
<td>OCA</td>
</tr>
<tr>
<td>3</td>
<td>pec</td>
<td>R 0x0</td>
<td>PEC (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>PE (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>csc</td>
<td>R 0x0</td>
<td>CSC (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ccs</td>
<td>R 0x0</td>
<td>CCS</td>
</tr>
</tbody>
</table>
## 24.3.2.38 PORTSC5 Register (PORTSC5)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PORTSC5</td>
<td>0x194</td>
</tr>
</tbody>
</table>

### Table 259: PORTSC5 Register (PORTSC5)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcn</td>
<td>R/W 0x0</td>
<td>WKCN</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
</tbody>
</table>
Table 259: PORTSC5 Register (PORTSC5) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>susp</td>
<td>R/W 0x0</td>
<td>SUSP</td>
</tr>
<tr>
<td>6</td>
<td>fpr</td>
<td>R/W 0x0</td>
<td>FPR</td>
</tr>
<tr>
<td>5</td>
<td>occ</td>
<td>R/W 0x0</td>
<td>OCC</td>
</tr>
<tr>
<td>4</td>
<td>oca</td>
<td>R 0x0</td>
<td>OCA</td>
</tr>
<tr>
<td>3</td>
<td>pec</td>
<td>R 0x0</td>
<td>PEC (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>PE (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>csc</td>
<td>R 0x0</td>
<td>CSC (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ccs</td>
<td>R 0x0</td>
<td>CCS</td>
</tr>
</tbody>
</table>

24.3.2.39 PORTSC6 Register (PORTSC6)

Table 260: PORTSC6 Register (PORTSC6)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/ HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>-------</td>
<td>--------------</td>
<td>-------------</td>
</tr>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcn</td>
<td>R/W 0x0</td>
<td>WKCN</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
<tr>
<td>7</td>
<td>susp</td>
<td>R/W 0x0</td>
<td>SUSP</td>
</tr>
<tr>
<td>6</td>
<td>fpr</td>
<td>R/W 0x0</td>
<td>FPR</td>
</tr>
<tr>
<td>5</td>
<td>occ</td>
<td>R/W 0x0</td>
<td>OCC</td>
</tr>
<tr>
<td>4</td>
<td>oca</td>
<td>R 0x0</td>
<td>OCA</td>
</tr>
<tr>
<td>3</td>
<td>pec</td>
<td>R 0x0</td>
<td>PEC (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>PE (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>csc</td>
<td>R 0x0</td>
<td>CSC (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ccs</td>
<td>R 0x0</td>
<td>CCS</td>
</tr>
</tbody>
</table>
### 24.3.2.40 PORTSC7 Register (PORTSC7)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PORTSC7</td>
<td>0x19C</td>
</tr>
</tbody>
</table>

#### Table 261: PORTSC7 Register (PORTSC7)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcn</td>
<td>R/W 0x0</td>
<td>WKCN</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
</tbody>
</table>
### 24.3.2.41 PORTSC8 Register (PORTSC8)

**Instance Name**
- PORTSC8

**Offset**
- 0x1A0

#### Table 262: PORTSC8 Register (PORTSC8)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>pts</td>
<td>R/W 0x0</td>
<td>PTS</td>
</tr>
<tr>
<td>29</td>
<td>sts</td>
<td>R/W 0x0</td>
<td>STS</td>
</tr>
<tr>
<td>28</td>
<td>ptw</td>
<td>R/W 0x0</td>
<td>PTW</td>
</tr>
<tr>
<td>27:26</td>
<td>pspd</td>
<td>R 0x3</td>
<td>PSPD</td>
</tr>
<tr>
<td>25</td>
<td>pts2</td>
<td>R/W 0x0</td>
<td>PTS2</td>
</tr>
<tr>
<td>24</td>
<td>pfsc</td>
<td>R/W 0x0</td>
<td>PFSC</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/ HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>-------</td>
<td>--------------</td>
<td>-------------</td>
</tr>
<tr>
<td>23</td>
<td>phcd</td>
<td>R/W 0x0</td>
<td>PHCD</td>
</tr>
<tr>
<td>22</td>
<td>wkoc</td>
<td>R/W 0x0</td>
<td>WKOC</td>
</tr>
<tr>
<td>21</td>
<td>wkds</td>
<td>R/W 0x0</td>
<td>WKDS</td>
</tr>
<tr>
<td>20</td>
<td>wkcn</td>
<td>R/W 0x0</td>
<td>WKCN</td>
</tr>
<tr>
<td>19:16</td>
<td>ptc</td>
<td>R/W 0x0</td>
<td>PTC</td>
</tr>
<tr>
<td>15:14</td>
<td>pic</td>
<td>R/W 0x0</td>
<td>PIC</td>
</tr>
<tr>
<td>13</td>
<td>po</td>
<td>R 0x0</td>
<td>PO</td>
</tr>
<tr>
<td>12</td>
<td>pp</td>
<td>R/W 0x0</td>
<td>PP</td>
</tr>
<tr>
<td>11:10</td>
<td>ls</td>
<td>R 0x0</td>
<td>LS</td>
</tr>
<tr>
<td>9</td>
<td>hsp</td>
<td>R 0x0</td>
<td>HSP</td>
</tr>
<tr>
<td>8</td>
<td>pr</td>
<td>R/W 0x0</td>
<td>PR</td>
</tr>
<tr>
<td>7</td>
<td>susp</td>
<td>R/W 0x0</td>
<td>SUSP</td>
</tr>
<tr>
<td>6</td>
<td>fpr</td>
<td>R/W 0x0</td>
<td>FPR</td>
</tr>
<tr>
<td>5</td>
<td>occ</td>
<td>R/W 0x0</td>
<td>OCC</td>
</tr>
<tr>
<td>4</td>
<td>oca</td>
<td>R 0x0</td>
<td>OCA</td>
</tr>
<tr>
<td>3</td>
<td>pec</td>
<td>R 0x0</td>
<td>PEC (rwc)</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>PE (rwc)</td>
</tr>
<tr>
<td>1</td>
<td>csc</td>
<td>R 0x0</td>
<td>CSC (rwc)</td>
</tr>
<tr>
<td>0</td>
<td>ccs</td>
<td>R 0x0</td>
<td>CCS</td>
</tr>
</tbody>
</table>
### OTGSC Register (OTGSC)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>OTGSC</td>
<td>0x1A4</td>
<td></td>
</tr>
</tbody>
</table>

**Table 263: OTGSC Register (OTGSC)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>reserved_31</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>30</td>
<td>dpie</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>29</td>
<td>otgsc_1mse</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>28</td>
<td>bseie</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>27</td>
<td>bsvie</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>26</td>
<td>asvie</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>25</td>
<td>avvie</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>24</td>
<td>idie</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>23</td>
<td>reserved_23</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>22</td>
<td>dpis</td>
<td>R 0x0</td>
<td>DPIIS (rwc)</td>
</tr>
<tr>
<td>21</td>
<td>otgsc_1mss</td>
<td>R 0x0</td>
<td>OTGSC_1msS (rwc)</td>
</tr>
<tr>
<td>20</td>
<td>bseis</td>
<td>R 0x0</td>
<td>BSEIS (rwc)</td>
</tr>
<tr>
<td>19</td>
<td>bsvis</td>
<td>R 0x0</td>
<td>BSVIS (rwc)</td>
</tr>
<tr>
<td>18</td>
<td>asvis</td>
<td>R 0x0</td>
<td>ASVIS (rwc)</td>
</tr>
<tr>
<td>17</td>
<td>avvis</td>
<td>R 0x0</td>
<td>AVVIS (rwc)</td>
</tr>
<tr>
<td>16</td>
<td>idis</td>
<td>R 0x0</td>
<td>IDIS (rwc)</td>
</tr>
<tr>
<td>15</td>
<td>reserved_15</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>-----------</td>
<td>-------------</td>
<td>-------------------</td>
</tr>
<tr>
<td>14</td>
<td>dps</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>13</td>
<td>otgsc_1mst</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>12</td>
<td>bse</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>11</td>
<td>bsv</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>10</td>
<td>asv</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>9</td>
<td>avv</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>8</td>
<td>id</td>
<td>R 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>7</td>
<td>haba</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>6</td>
<td>hadp</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>5</td>
<td>idpu</td>
<td>R/W 0x1</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>4</td>
<td>dp</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>3</td>
<td>ot</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>2</td>
<td>haar</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>1</td>
<td>vc</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
<tr>
<td>0</td>
<td>vd</td>
<td>R/W 0x0</td>
<td>OTG Not Enable</td>
</tr>
</tbody>
</table>

### 24.3.2.43 USB Mode Register (USBMODE)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>USBMODE</td>
<td>0x1A8</td>
</tr>
</tbody>
</table>
### Table 264: USB Mode Register (USBMODE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>reserved_16</td>
<td>R 0x0</td>
<td>Reserved_16</td>
</tr>
<tr>
<td>15</td>
<td>srt</td>
<td>R/W 0x0</td>
<td>SRT</td>
</tr>
<tr>
<td>14:6</td>
<td>reserved_6</td>
<td>R 0x0</td>
<td>Reserved_6</td>
</tr>
<tr>
<td>5</td>
<td>vbps</td>
<td>R/W 0x0</td>
<td>VBPS Only used in Host.</td>
</tr>
<tr>
<td>4</td>
<td>sdis</td>
<td>R/W 0x0</td>
<td>SDIS</td>
</tr>
<tr>
<td>3</td>
<td>slom</td>
<td>R/W 0x0</td>
<td>SLOM</td>
</tr>
<tr>
<td>2</td>
<td>es</td>
<td>R/W 0x0</td>
<td>ES</td>
</tr>
<tr>
<td>1:0</td>
<td>cm</td>
<td>R/W 0x2</td>
<td>Fix Device Mode</td>
</tr>
</tbody>
</table>

### 24.3.2.44 Endpoint Setup Stat Register (ENDPTSETUPSTAT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTSETUPSTAT</td>
<td>0x1AC</td>
</tr>
</tbody>
</table>

### Table 265: Endpoint Setup Stat Register (ENDPTSETUPSTAT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>reserved_16</td>
<td>R 0x0</td>
<td>Reserved_16</td>
</tr>
<tr>
<td>15:0</td>
<td>endptsetupstat</td>
<td>R 0x0</td>
<td>Endpoint Setup Stat (nwc)</td>
</tr>
</tbody>
</table>

### 24.3.2.45 Endpoint Prime Register (ENDPTPRIME)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTPRIME</td>
<td>0x1B0</td>
</tr>
</tbody>
</table>
Table 266: Endpoint Prime Register (ENDPTPRIME)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>petb</td>
<td>R</td>
<td>PETB (rws)</td>
</tr>
<tr>
<td>15:0</td>
<td>perb</td>
<td>R</td>
<td>PERB (rws)</td>
</tr>
</tbody>
</table>

24.3.2.46 Endpoint Flush Register (ENDPTFLUSH)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTFLUSH</td>
<td>0x1B4</td>
</tr>
</tbody>
</table>

Table 267: Endpoint Flush Register (ENDPTFLUSH)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>fetb</td>
<td>R</td>
<td>FETB (rws)</td>
</tr>
<tr>
<td>15:0</td>
<td>ferb</td>
<td>R</td>
<td>FERB (rws)</td>
</tr>
</tbody>
</table>

24.3.2.47 Endpoint Stat Register (ENDPTSTAT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTSTAT</td>
<td>0x1B8</td>
</tr>
</tbody>
</table>

Table 268: Endpoint Stat Register (ENDPTSTAT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>etbr</td>
<td>R</td>
<td>ETBR</td>
</tr>
<tr>
<td>15:0</td>
<td>erbr</td>
<td>R</td>
<td>ERBR</td>
</tr>
</tbody>
</table>
### 24.3.2.48 Endpoint Complete Register (ENDPTCOMPLETE)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCOMPLETE</td>
<td>0x1BC</td>
</tr>
</tbody>
</table>

**Table 269: Endpoint Complete Register (ENDPTCOMPLETE)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>etce</td>
<td>R 0x0</td>
<td>ETCE (rwc)</td>
</tr>
<tr>
<td>15:0</td>
<td>erce</td>
<td>R 0x0</td>
<td>ERCE (rwc)</td>
</tr>
</tbody>
</table>

### 24.3.2.49 Endpoint Control 0 Register (ENDPTCTRL0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL0</td>
<td>0x1C0</td>
</tr>
</tbody>
</table>

**Table 270: Endpoint Control 0 Register (ENDPTCTRL0)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R 0x1</td>
<td>TXE</td>
</tr>
<tr>
<td>22:20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>reserved_17</td>
<td>R 0x0</td>
<td>Reserved_17</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x1</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R 0x1</td>
<td>RXE</td>
</tr>
<tr>
<td>6:4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R 0x0</td>
<td>RXT</td>
</tr>
</tbody>
</table>
### Endpoint Control 1 Register (ENDPTCTRL1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxx</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
</tbody>
</table>
### Table 271: Endpoint Control 1 Register (ENDPTCTRL1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

### 24.3.2.51 Endpoint Control 2 Register (ENDPTCTRL2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL2</td>
<td>0x1C8</td>
</tr>
</tbody>
</table>

### Table 272: Endpoint Control 2 Register (ENDPTCTRL2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
</tbody>
</table>
### Endpoint Control 3 Register (ENDPTCTRL3)

#### Table 273: Endpoint Control 3 Register (ENDPTCTRL3)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
</tbody>
</table>
Table 273: Endpoint Control 3 Register (ENDPTCTRL3) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

24.3.2.53 Endpoint Control 4 Register (ENDPTCTRL4)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL4</td>
<td>0x1D0</td>
</tr>
</tbody>
</table>

Table 274: Endpoint Control 4 Register (ENDPTCTRL4)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
</tbody>
</table>
Table 274: Endpoint Control 4 Register (ENDPTCTRL4) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

24.3.2.54  Endpoint Control 5 Register (ENDPTCTRL5)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL5</td>
<td>0x1D4</td>
</tr>
</tbody>
</table>

Table 275: Endpoint Control 5 Register (ENDPTCTRL5)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
</tbody>
</table>
### Table 275: Endpoint Control 5 Register (ENDPTCTRL5) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

### 24.3.2.55 Endpoint Control 6 Register (ENDPTCTRL6)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL6</td>
<td>0x1D8</td>
</tr>
</tbody>
</table>

### Table 276: Endpoint Control 6 Register (ENDPTCTRL6)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
</tbody>
</table>
### Endpoint Control 7 Register (ENDPTCTRL7)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL7</td>
<td>0x1DC</td>
</tr>
</tbody>
</table>

---

**Table 276: Endpoint Control 6 Register (ENDPTCTRL6) (Continued)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>
Table 277: Endpoint Control 7 Register (ENDPTCTRL7)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

### 24.3.2.57 Endpoint Control 8 Register (ENDPTCTRL8)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL8</td>
<td>0x1E0</td>
</tr>
</tbody>
</table>
### Table 278: Endpoint Control 8 Register (ENDPTCTRL8)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

### 24.3.2.58  Endpoint Control 9 Register (ENDPTCTRL9)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL9</td>
<td>0x1E4</td>
</tr>
</tbody>
</table>
### Table 279: Endpoint Control 9 Register (ENDPTCTRL9)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

### 24.3.2.59 Endpoint Control 10 Register (ENDPTCTRL10)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL10</td>
<td>0x1E8</td>
</tr>
</tbody>
</table>
### Table 280: Endpoint Control 10 Register (ENDPTCTRL10)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

#### 24.3.2.60 Endpoint Control 11 Register (ENDPTCTRL11)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL11</td>
<td>0x1EC</td>
</tr>
</tbody>
</table>
Table 281: Endpoint Control 11 Register (ENDPTCTRL11)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

24.3.2.61 Endpoint Control 12 Register (ENDPTCTRL12)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL12</td>
<td>0x1F0</td>
</tr>
</tbody>
</table>
## Table 282: Endpoint Control 12 Register (ENDPTCTRL12)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

### 24.3.2.62 Endpoint Control 13 Register (ENDPTCTRL13)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL13</td>
<td>0x1F4</td>
</tr>
</tbody>
</table>
## Table 283: Endpoint Control 13 Register (ENDPTCTRL13)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

### 24.3.2.63 Endpoint Control 14 Register (ENDPTCTRL14)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL14</td>
<td>0x1F8</td>
</tr>
</tbody>
</table>
### Table 284: Endpoint Control 14 Register (ENDPTCTRL14)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R 0x0</td>
<td>Reserved_24</td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W 0x0</td>
<td>TXE</td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R 0x0</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W 0x0</td>
<td>TXI</td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R 0x0</td>
<td>Reserved_20</td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W 0x0</td>
<td>TXT</td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W 0x0</td>
<td>TXD</td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W 0x0</td>
<td>TXS</td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R 0x0</td>
<td>Reserved_8</td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W 0x0</td>
<td>RXE</td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R 0x0</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W 0x0</td>
<td>RXI</td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R 0x0</td>
<td>Reserved_4</td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W 0x0</td>
<td>RXT</td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W 0x0</td>
<td>RXD</td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W 0x0</td>
<td>RXS</td>
</tr>
</tbody>
</table>

#### 24.3.2.64 Endpoint Control 15 Register (ENDPTCTRL15)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENDPTCTRL15</td>
<td>0x1FC</td>
</tr>
</tbody>
</table>
## Table 285: Endpoint Control 15 Register (ENDPTCTRL15)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>reserved_24</td>
<td>R</td>
<td>Reserved_24</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>txe</td>
<td>R/W</td>
<td>TXE</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>txr</td>
<td>R</td>
<td>TXR (ws)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>txi</td>
<td>R/W</td>
<td>TXI</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>reserved_20</td>
<td>R</td>
<td>Reserved_20</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>19:18</td>
<td>txt</td>
<td>R/W</td>
<td>TXT</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>txd</td>
<td>R/W</td>
<td>TXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>txs</td>
<td>R/W</td>
<td>TXS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>15:8</td>
<td>reserved_8</td>
<td>R</td>
<td>Reserved_8</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>rxe</td>
<td>R/W</td>
<td>RXE</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>rxr</td>
<td>R</td>
<td>RXR (ws)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>rxi</td>
<td>R/W</td>
<td>RXI</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>reserved_4</td>
<td>R</td>
<td>Reserved_4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>3:2</td>
<td>rxt</td>
<td>R/W</td>
<td>RXT</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>rxd</td>
<td>R/W</td>
<td>RXD</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>rxs</td>
<td>R/W</td>
<td>RXS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td></td>
</tr>
</tbody>
</table>

### 24.3.2.65 PHY ID Register (PHY_ID)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PHY_ID</td>
<td>0x200</td>
</tr>
</tbody>
</table>
Table 286: PHY ID Register (PHY_ID)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:8</td>
<td>cid1</td>
<td>R 0x94</td>
<td>CID1</td>
</tr>
<tr>
<td>7:0</td>
<td>cid0</td>
<td>R 0x11</td>
<td>CID0</td>
</tr>
</tbody>
</table>

24.3.2.66 PLL Control 0 Register (PLL_Control_0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PLL_Control_0</td>
<td>0x204</td>
</tr>
</tbody>
</table>

Table 287: PLL Control 0 Register (PLL_Control_0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:14</td>
<td>pllvdd18</td>
<td>R/W 0x1</td>
<td>PLLVDD18</td>
</tr>
<tr>
<td>13:9</td>
<td>rediv</td>
<td>R/W 0xD</td>
<td>REFDIV</td>
</tr>
<tr>
<td>8:0</td>
<td>fbdiv</td>
<td>R/W 0x78</td>
<td>FBDIV</td>
</tr>
</tbody>
</table>

24.3.2.67 PLL Control 1 Register (PLL_Control_1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PLL_Control_1</td>
<td>0x208</td>
</tr>
</tbody>
</table>

Table 288: PLL Control 1 Register (PLL_Control_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>pll_ready</td>
<td>R 0x0</td>
<td>PLL_READY</td>
</tr>
</tbody>
</table>
24.3.2.68  Reserved_Addr3 Register (Reserved_Addr3)

### Table 289: Reserved_Addr3 Register (Reserved_Addr3)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R 0x0</td>
<td>Reserved_Bit_15_0</td>
</tr>
</tbody>
</table>
### 24.3.2.69 TX Channel Control 0 Register (Tx_Channel_Contrl_0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tx_Channel_Contrl_0</td>
<td>0x210</td>
</tr>
</tbody>
</table>

#### Table 290: TX Channel Control 0 Register (Tx_Channel_Contrl_0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>nd</td>
<td>R</td>
<td>ND</td>
</tr>
<tr>
<td>14</td>
<td>txdata_block_en</td>
<td>R/W</td>
<td>TXDATA_BLOCK_EN</td>
</tr>
<tr>
<td>13</td>
<td>rcal_start</td>
<td>R/W</td>
<td>RCAL_START</td>
</tr>
<tr>
<td>12</td>
<td>ext_hs_rcal_en</td>
<td>R/W</td>
<td>EXT_HS_RCAL_EN</td>
</tr>
<tr>
<td>11</td>
<td>ext_fs_rcal_en</td>
<td>R/W</td>
<td>EXT_FS_RCAL_EN</td>
</tr>
<tr>
<td>10:8</td>
<td>impcal_vth</td>
<td>R/W</td>
<td>IMPCAL_VTH</td>
</tr>
<tr>
<td>7:4</td>
<td>ext_hs_rcal</td>
<td>R/W</td>
<td>EXT_HS_RCAL</td>
</tr>
<tr>
<td>3:0</td>
<td>ext_fs_rcal</td>
<td>R/W</td>
<td>EXT_FS_RCAL</td>
</tr>
</tbody>
</table>

### 24.3.2.70 TX Channel Control 1 Register (Tx_Channel_Contrl_1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tx_Channel_Contrl_1</td>
<td>0x214</td>
</tr>
</tbody>
</table>

#### Table 291: TX Channel Control 1 Register (Tx_Channel_Contrl_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:12</td>
<td>nd</td>
<td>R</td>
<td>ND</td>
</tr>
<tr>
<td>11:10</td>
<td>txvdd15</td>
<td>R/W</td>
<td>TXVDD15</td>
</tr>
</tbody>
</table>
Table 291: TX Channel Control 1 Register (Tx_Channel_Contrl_1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>9:8</td>
<td>txvdd12</td>
<td>R/W 0x1</td>
<td>TXVDD12</td>
</tr>
<tr>
<td>7</td>
<td>lowvdd_en</td>
<td>R/W 0x1</td>
<td>LOWVDD_EN</td>
</tr>
<tr>
<td>6:4</td>
<td>amp</td>
<td>R/W 0x3</td>
<td>AMP</td>
</tr>
<tr>
<td>3:0</td>
<td>ck60_phsel</td>
<td>R/W 0x0</td>
<td>CK60_PHSEL</td>
</tr>
</tbody>
</table>

24.3.2.71  TX Channel Control 2 Register (Tx_Channel_Contrl_2)

Table 292: TX Channel Control 2 Register (Tx_Channel_Contrl_2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:12</td>
<td>nd</td>
<td>R 0x0</td>
<td>ND</td>
</tr>
<tr>
<td>11:10</td>
<td>drv_slewratio</td>
<td>R/W 0x0</td>
<td>DRV_SLEWRATE</td>
</tr>
<tr>
<td>9:8</td>
<td>imp_cal_dly</td>
<td>R/W 0x2</td>
<td>IMP_CAL_DLY</td>
</tr>
<tr>
<td>7:4</td>
<td>fsdrv_en</td>
<td>R/W 0xF</td>
<td>FSDRV_EN</td>
</tr>
<tr>
<td>3:0</td>
<td>hsd drv_en</td>
<td>R/W 0xF</td>
<td>HSDRV_EN</td>
</tr>
</tbody>
</table>

24.3.2.72  Reserved_Addr7 Register (Reserved_Addr7)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved_Addr7</td>
<td>0x21C</td>
</tr>
</tbody>
</table>
### Table 293: Reserved_Addr7 Register (Reserved_Addr7)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R</td>
<td>Reserved_Bit_15_0</td>
</tr>
</tbody>
</table>

### 24.3.2.73 RX Channel Control 0 Register (Rx_Channel_Contrl_0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rx_Channel_Contrl_0</td>
<td>0x220</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>phase_freeze_dly</td>
<td>R/W</td>
<td>PHASE_FREEZE_DLY</td>
</tr>
<tr>
<td>14</td>
<td>usq_length</td>
<td>R/W</td>
<td>USQ_LENGTH</td>
</tr>
<tr>
<td>13:12</td>
<td>acq_length</td>
<td>R/W</td>
<td>ACQ_LENGTH</td>
</tr>
<tr>
<td>11:10</td>
<td>sq_length</td>
<td>R/W</td>
<td>SQ_LENGTH</td>
</tr>
<tr>
<td>9:8</td>
<td>discon_thresh</td>
<td>R/W</td>
<td>DISCON_THRESH</td>
</tr>
<tr>
<td>7:4</td>
<td>sq_thresh</td>
<td>R/W</td>
<td>SQ_THRESH</td>
</tr>
<tr>
<td>3:2</td>
<td>lpf_coef</td>
<td>R/W</td>
<td>LPF_COEF</td>
</tr>
<tr>
<td>1:0</td>
<td>intpi</td>
<td>R/W</td>
<td>INTPI</td>
</tr>
</tbody>
</table>

### 24.3.2.74 RX Channel Control 1 Register (Rx_Channel_Contrl_1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rx_Channel_Contrl_1</td>
<td>0x224</td>
</tr>
</tbody>
</table>
Table 295: RX Channel Control 1 Register (Rx_Channel_Contrl_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:14</td>
<td>nd</td>
<td>R 0x0</td>
<td>ND</td>
</tr>
<tr>
<td>13</td>
<td>early_vos_on_en</td>
<td>R/W 0x1</td>
<td>EARLY_VOS_ON_EN</td>
</tr>
<tr>
<td>12</td>
<td>rxdata_block_en</td>
<td>R/W 0x1</td>
<td>RXDATA_BLOCK_EN</td>
</tr>
<tr>
<td>11</td>
<td>edge_det_en</td>
<td>R/W 0x1</td>
<td>EDGE_DET_EN</td>
</tr>
<tr>
<td>10:8</td>
<td>cap_sel</td>
<td>R/W 0x0</td>
<td>CAP_SEL</td>
</tr>
<tr>
<td>7:6</td>
<td>rxdata_block_length</td>
<td>R/W 0x2</td>
<td>RXDATA_BLOCK_LENGTH</td>
</tr>
<tr>
<td>5:4</td>
<td>edge_det_sel</td>
<td>R/W 0x1</td>
<td>EDGE_DET_SEL</td>
</tr>
<tr>
<td>3</td>
<td>cdr_coef_sel</td>
<td>R/W 0x0</td>
<td>CDR_COEF_SEL</td>
</tr>
<tr>
<td>2</td>
<td>cdr_fastlock_en</td>
<td>R/W 0x0</td>
<td>CDR_FASTLOCK_EN</td>
</tr>
<tr>
<td>1:0</td>
<td>s2to3_dly_sel</td>
<td>R/W 0x2</td>
<td>S2TO3_DLY_SEL</td>
</tr>
</tbody>
</table>

24.3.2.75 RX Channel Control 2 Register (Rx_Channel_Contrl_2)

Table 296: RX Channel Control 2 Register (Rx_Channel_Contrl_2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:9</td>
<td>nd</td>
<td>R 0x0</td>
<td>ND</td>
</tr>
<tr>
<td>8</td>
<td>usq_filter</td>
<td>R/W 0x1</td>
<td>USQ_FILTER</td>
</tr>
</tbody>
</table>
### 24.3.2.76 ANA Control 0 Register (Ana_Contrl_0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Ana_Contrl_0</td>
<td>0x230</td>
</tr>
</tbody>
</table>

#### Table 297: ANA Control 0 Register (Ana_Contrl_0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:10</td>
<td>nd</td>
<td>R 0x0</td>
<td>ND</td>
</tr>
<tr>
<td>9:8</td>
<td>bg_vsel</td>
<td>R/W 0x1</td>
<td>BG_VSEL</td>
</tr>
<tr>
<td>7:6</td>
<td>dig_sel</td>
<td>R/W 0x0</td>
<td>DIG_SEL</td>
</tr>
<tr>
<td>5:4</td>
<td>topvdd18</td>
<td>R/W 0x1</td>
<td>TOPVDD18</td>
</tr>
<tr>
<td>3</td>
<td>vdd_usb2Dig_top_sel</td>
<td>R/W 0x0</td>
<td>VDD_USB2_DIG_TOP_SEL</td>
</tr>
<tr>
<td>2:0</td>
<td>iptat_sel</td>
<td>R/W 0x0</td>
<td>IPTAT_SEL</td>
</tr>
</tbody>
</table>
24.3.2.77   ANA Control 1 Register (Ana_Contrl_1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Ana_Contrl_1</td>
<td>0x234</td>
</tr>
</tbody>
</table>

Table 298: ANA Control 1 Register (Ana_Contrl_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>nd</td>
<td>R</td>
<td>ND</td>
</tr>
<tr>
<td>14</td>
<td>pu_ana</td>
<td>R/W</td>
<td>PU_ANA</td>
</tr>
<tr>
<td>13</td>
<td>ana_contrl_by_pin</td>
<td>R/W</td>
<td>ANA_CONTrL_BY_PIN</td>
</tr>
<tr>
<td>12</td>
<td>sel_lpfr</td>
<td>R/W</td>
<td>SEL_LPFR</td>
</tr>
<tr>
<td>11</td>
<td>v2i_ext</td>
<td>R/W</td>
<td>V2I_EXT</td>
</tr>
<tr>
<td>10:8</td>
<td>v2i</td>
<td>R/W</td>
<td>V2I</td>
</tr>
<tr>
<td>7</td>
<td>r_rotate_sel</td>
<td>R/W</td>
<td>R_ROTATE_SEL</td>
</tr>
<tr>
<td>6</td>
<td>stress_test_mode</td>
<td>R/W</td>
<td>STRESS_TEST_MODE</td>
</tr>
<tr>
<td>5:0</td>
<td>testmon_ana</td>
<td>R/W</td>
<td>TESTMON_ANA</td>
</tr>
</tbody>
</table>

24.3.2.78   Reserved_Addr_C Register (Reserved_Addr_C)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved_Addr_C</td>
<td>0x238</td>
</tr>
</tbody>
</table>

Table 299: Reserved_Addr_C Register (Reserved_Addr_C)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R/W</td>
<td>Reserved_Bit_15_0</td>
</tr>
</tbody>
</table>
24.3.2.79  Digital Control 0 Register (Digital_Control_0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Digital_Control_0</td>
<td>0x23C</td>
</tr>
</tbody>
</table>

Table 300: Digital Control 0 Register (Digital_Control_0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>fifo_uf</td>
<td>R 0x0</td>
<td>FIFO_UF</td>
</tr>
<tr>
<td>14</td>
<td>fifo_ov</td>
<td>R 0x0</td>
<td>FIFO_OV</td>
</tr>
<tr>
<td>13</td>
<td>fs_eop_mode</td>
<td>R/W 0x1</td>
<td>FS_EOP_MODE</td>
</tr>
<tr>
<td>12</td>
<td>host_discon_sel1</td>
<td>R/W 0x0</td>
<td>HOST_DISCON_SEL1</td>
</tr>
<tr>
<td>11</td>
<td>host_discon_sel0</td>
<td>R/W 0x0</td>
<td>HOST_DISCON_SEL0</td>
</tr>
<tr>
<td>10</td>
<td>force_end_en</td>
<td>R/W 0x1</td>
<td>FORCE_END_EN</td>
</tr>
<tr>
<td>9</td>
<td>early_tx_en</td>
<td>R/W 0x0</td>
<td>EARLY_TX_EN</td>
</tr>
<tr>
<td>8</td>
<td>syncdet_window_en</td>
<td>R/W 0x1</td>
<td>SYNCDET_WINDOW_EN</td>
</tr>
<tr>
<td>7</td>
<td>clk_suspend_en</td>
<td>R/W 0x1</td>
<td>CLK_SUSPEND_EN</td>
</tr>
<tr>
<td>6</td>
<td>hs_dribble_en</td>
<td>R/W 0x0</td>
<td>HS_DRIBBLE_EN</td>
</tr>
<tr>
<td>5:4</td>
<td>sync_num</td>
<td>R/W 0x0</td>
<td>SYNC_NUM</td>
</tr>
<tr>
<td>3:0</td>
<td>fifo_fill_num</td>
<td>R/W 0x6</td>
<td>FIFO_FILL_NUM</td>
</tr>
</tbody>
</table>

24.3.2.80  Digital Control 1 Register (Digital_Control_1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Digital_Control_1</td>
<td>0x240</td>
</tr>
</tbody>
</table>
Table 301: Digital Control 1 Register (Digital_Control_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>fs_rx_error_mode2</td>
<td>R/W 0x1</td>
<td>FS_RX_ERROR_MODE2</td>
</tr>
<tr>
<td>14</td>
<td>fs_rx_error_mode1</td>
<td>R/W 0x1</td>
<td>FS_RX_ERROR_MODE1</td>
</tr>
<tr>
<td>13</td>
<td>fs_rx_error_mode</td>
<td>R/W 0x1</td>
<td>FS_RX_ERROR_MODE</td>
</tr>
<tr>
<td>12</td>
<td>clk_out_sel</td>
<td>R/W 0x0</td>
<td>CLK_OUT_SEL</td>
</tr>
<tr>
<td>11</td>
<td>ext_tx_clk_sel</td>
<td>R/W 0x0</td>
<td>EXT_TX_CLK_SEL</td>
</tr>
<tr>
<td>10</td>
<td>arc_dpdm_mode</td>
<td>R/W 0x1</td>
<td>ARC_DPDM_MODE</td>
</tr>
<tr>
<td>9</td>
<td>dp_pulldown</td>
<td>R/W 0x0</td>
<td>DP_PULLDOWN</td>
</tr>
<tr>
<td>8</td>
<td>dm_pulldown</td>
<td>R/W 0x0</td>
<td>DM_PULLDOWN</td>
</tr>
<tr>
<td>7</td>
<td>sync_ignore_sq</td>
<td>R/W 0x0</td>
<td>SYNC_IGNORE_SQ</td>
</tr>
<tr>
<td>6</td>
<td>sq_rst_rx</td>
<td>R/W 0x0</td>
<td>SQ_RST_RX</td>
</tr>
<tr>
<td>5:0</td>
<td>mon_sel</td>
<td>R/W 0x0</td>
<td>MON_SEL</td>
</tr>
</tbody>
</table>

24.3.2.81 Digital Control 2 Register (Digital_Control_2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Digital_Control_2</td>
<td>0x244</td>
</tr>
</tbody>
</table>

Table 302: Digital Control 2 Register (Digital_Control_2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:13</td>
<td>nd_15_13</td>
<td>R 0x0</td>
<td>ND_15_13</td>
</tr>
</tbody>
</table>
### Table 302: Digital Control 2 Register (Digital_Control_2) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12:8</td>
<td>pad_strength</td>
<td>R/W 0xF</td>
<td>PAD_STRENGTH</td>
</tr>
<tr>
<td>7:6</td>
<td>nd</td>
<td>R 0x0</td>
<td>ND</td>
</tr>
<tr>
<td>5</td>
<td>long_eop</td>
<td>R/W 0x0</td>
<td>LONG_EOP</td>
</tr>
<tr>
<td>4</td>
<td>novbus_dpdms00</td>
<td>R/W 0x1</td>
<td>novbus_dpdms00</td>
</tr>
<tr>
<td>3</td>
<td>disable_el16</td>
<td>R/W 0x0</td>
<td>DISABLE_EL16</td>
</tr>
<tr>
<td>2</td>
<td>align_fs_outen</td>
<td>R/W 0x0</td>
<td>ALIGN_FS_OUTEN</td>
</tr>
<tr>
<td>1</td>
<td>hs_hdl_sync</td>
<td>R/W 0x1</td>
<td>HS_HDL_SYNC</td>
</tr>
<tr>
<td>0</td>
<td>fs_hdl_opmd</td>
<td>R/W 0x1</td>
<td>FS_HDL_OPMD</td>
</tr>
</tbody>
</table>

#### 24.3.2.82  Reserved_Addr_12H Register (Reserved_Addr_12H)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved_Addr_12H</td>
<td>0x248</td>
</tr>
</tbody>
</table>

**Table 303: Reserved_Addr_12H Register (Reserved_Addr_12H)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R 0x0</td>
<td>Reserved_BIT_15_0</td>
</tr>
</tbody>
</table>

#### 24.3.2.83  Test Control and Status 0 Register (Test_Contrl_and_Status_0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Test_Contrl_and_Status_0</td>
<td>0x24C</td>
</tr>
</tbody>
</table>
### Table 304: Test Control and Status 0 Register (Test_Contrl_and_Status_0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>test_dig_lpbk</td>
<td>R/W 0x0</td>
<td>TEST_DIG_LPBK</td>
</tr>
<tr>
<td>14</td>
<td>test_analpbk</td>
<td>R/W 0x0</td>
<td>TEST_ANA_LPBK</td>
</tr>
<tr>
<td>13:12</td>
<td>test_length[1:0]</td>
<td>R/W 0x0</td>
<td>TEST_LENGTH[1:0]</td>
</tr>
<tr>
<td>11</td>
<td>test_bypass</td>
<td>R/W 0x0</td>
<td>TEST_BYPASS</td>
</tr>
<tr>
<td>10:8</td>
<td>test_mode[2:0]</td>
<td>R/W 0x0</td>
<td>TEST_MODE[2:0]</td>
</tr>
<tr>
<td>7:0</td>
<td>test_tx_pattern</td>
<td>R/W 0x0</td>
<td>TEST_TX_PATTERN</td>
</tr>
</tbody>
</table>

### 24.3.2.84 Test Control and Status 1 Register (Test_Contrl_and_Status_1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Test_Contrl_and_Status_1</td>
<td>0x250</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>test_done</td>
<td>R 0x0</td>
<td>TEST_DONE</td>
</tr>
<tr>
<td>14</td>
<td>test_flag</td>
<td>R 0x0</td>
<td>TEST_FLAG</td>
</tr>
<tr>
<td>13</td>
<td>test_en</td>
<td>R/W 0x0</td>
<td>TEST_EN</td>
</tr>
<tr>
<td>12</td>
<td>test_reset</td>
<td>R/W 0x0</td>
<td>TEST_RESET</td>
</tr>
<tr>
<td>11</td>
<td>nd</td>
<td>R/W 0x0</td>
<td>ND</td>
</tr>
<tr>
<td>10:8</td>
<td>test_skip[2:0]</td>
<td>R/W 0x0</td>
<td>TEST_SKIP[2:0]</td>
</tr>
</tbody>
</table>
Table 305: Test Control and Status 1 Register (Test,_Ctrl_and_Status_1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>test_utmi_sel</td>
<td>R/W 0x0</td>
<td>TEST_UTMI_SEL</td>
</tr>
<tr>
<td>6</td>
<td>test_suspendm</td>
<td>R/W 0x1</td>
<td>TEST_SUSPENDM</td>
</tr>
<tr>
<td>5</td>
<td>test_tx_bitstuff_en</td>
<td>R/W 0x1</td>
<td>TEST_TX_BITSTUFF_EN</td>
</tr>
<tr>
<td>4</td>
<td>test_term_select</td>
<td>R/W 0x0</td>
<td>TEST_TERM_SELECT</td>
</tr>
<tr>
<td>3:2</td>
<td>test_op_mode</td>
<td>R/W 0x0</td>
<td>TEST_OP_MODE</td>
</tr>
<tr>
<td>1:0</td>
<td>test_xcvr_select</td>
<td>R/W 0x0</td>
<td>TEST_XCVR_SELECT</td>
</tr>
</tbody>
</table>

24.3.2.85  Reserved_Addr_15H Register (Reserved_Addr_15H)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved_Addr_15H</td>
<td>0x254</td>
</tr>
</tbody>
</table>

Table 306: Reserved_Addr_15H Register (Reserved_Addr_15H)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVĐ --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R 0x0</td>
<td>Reserved_Bit_15_0</td>
</tr>
</tbody>
</table>

24.3.2.86  PHY REG CHGDTC Control Register (PHY_REG_CHGDTC_CONTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PHY_REG_CHGDTC_CONTRL</td>
<td>0x258</td>
</tr>
</tbody>
</table>

Table 307: PHY REG CHGDTC Control Register (PHY_REG_CHGDTC_CONTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVĐ --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.3.2.87 PHY REG OTG Control Register (PHY_REG_OTG_CONTROL)

#### Instance Name

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PHY_REG_OTG_CONTROL</td>
<td>0x25C</td>
</tr>
</tbody>
</table>

#### Table 308: PHY REG OTG Control Register (PHY_REG_OTG_CONTROL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:5</td>
<td>nd</td>
<td>R</td>
<td>ND</td>
</tr>
<tr>
<td>4</td>
<td>otg_control_by_pin</td>
<td>R/W</td>
<td>OTG_CONTROL_BY_PIN</td>
</tr>
<tr>
<td>3</td>
<td>pu_otg</td>
<td>R/W</td>
<td>PU_OTG</td>
</tr>
<tr>
<td>2:0</td>
<td>testmon_otg[2:0]</td>
<td>R/W</td>
<td>TESTMON_OTG[2:0]</td>
</tr>
</tbody>
</table>

### 24.3.2.88 USB2 PHY Monitor 0 Register (usb2_phy_mon0)

#### Instance Name

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>usb2_phy_mon0</td>
<td>0x260</td>
</tr>
</tbody>
</table>
### Table 309: USB2 PHY Monitor 0 Register (usb2_phy_mon0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>phy_mon</td>
<td>R/W 0x0</td>
<td>PHY_MON</td>
</tr>
</tbody>
</table>

### 24.3.2.89 PHY REG CHGDTC Control 1 Register (PHY_REG_CHGDTC_CONTRL_1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PHY_REG_CHGDTC_CONTRL_1</td>
<td>0x264</td>
</tr>
</tbody>
</table>

### Table 310: PHY REG CHGDTC Control 1 Register (PHY_REG_CHGDTC_CONTRL_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>dp_dm_swap_ctrl</td>
<td>R/W 0x0</td>
<td>DP_DM_SWAP_CTRL</td>
</tr>
<tr>
<td>14</td>
<td>reserved_14</td>
<td>R 0x0</td>
<td>reserved_14</td>
</tr>
<tr>
<td>13:12</td>
<td>pllvc12</td>
<td>R/W 0x0</td>
<td>PLLVDD12</td>
</tr>
<tr>
<td>11:10</td>
<td>vsrc_charge</td>
<td>R/W 0x0</td>
<td>VSRC_CHARGE</td>
</tr>
<tr>
<td>9:8</td>
<td>vdat_charge</td>
<td>R/W 0x0</td>
<td>VDAT_CHARGE</td>
</tr>
<tr>
<td>7</td>
<td>enable_switch_dp</td>
<td>R/W 0x0</td>
<td>ENABLE_SWITCH_DP</td>
</tr>
<tr>
<td>6</td>
<td>enable_switch_dm</td>
<td>R/W 0x0</td>
<td>ENABLE_SWITCH_DM</td>
</tr>
<tr>
<td>5</td>
<td>cdp_dm_auto_switch</td>
<td>R/W 0x0</td>
<td>CDP_DM_AUTO_SWITCH</td>
</tr>
<tr>
<td>4</td>
<td>pd_en</td>
<td>R/W 0x0</td>
<td>PD_EN</td>
</tr>
<tr>
<td>3</td>
<td>dcp_en</td>
<td>R/W 0x0</td>
<td>DCP_EN</td>
</tr>
</tbody>
</table>
### 24.3.2.90  Reserved_Addr_1AH Register (Reserved_Addr_1aH)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R 0x0</td>
<td>Reserved_Bit_15_0</td>
</tr>
</tbody>
</table>

#### Table 310: PHY REG CHGDTC Control 1 Register (PHY_REG_CHGDTC_CONTRL_1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>cdp_en</td>
<td>R/W 0x0</td>
<td>CDP_EN</td>
</tr>
<tr>
<td>1:0</td>
<td>reserved_0</td>
<td>R 0x0</td>
<td>Reserved_0</td>
</tr>
</tbody>
</table>

### 24.3.2.91  Reserved_Addr_1BH Register (Reserved_Addr_1bH)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R 0x0</td>
<td>Reserved_Bit_15_0</td>
</tr>
</tbody>
</table>
24.3.2.92  Reserved.Addr_1CH Register (Reserved.Addr_1cH)

Table 313: Reserved.Addr_1CH Register (Reserved.Addr_1cH)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R 0x0</td>
<td>Reserved.Bit_15_0</td>
</tr>
</tbody>
</table>

24.3.2.93  Reserved.Addr_1DH Register (Reserved.Addr_1dH)

Table 314: Reserved.Addr_1DH Register (Reserved.Addr_1dH)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>reserved_bit_15_0</td>
<td>R 0x0</td>
<td>Reserved.Bit_15_0</td>
</tr>
</tbody>
</table>

24.3.2.94  Internal CID Register (Internal_CID)

Table 315: Internal CID Register (Internal_CID)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:8</td>
<td>icid0</td>
<td>R 0x94</td>
<td>ICID0</td>
</tr>
</tbody>
</table>
Table 315: Internal CID Register (Internal_CID) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:0</td>
<td>icid1</td>
<td>R 0x11</td>
<td>ICID1</td>
</tr>
</tbody>
</table>

24.3.2.95 USB2 ICID Register 1 (usb2_icid_reg1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>usb2_icid_reg1</td>
<td>0x27C</td>
</tr>
</tbody>
</table>

Table 316: USB2 ICID Register 1 (usb2_icid_reg1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:8</td>
<td>icid2</td>
<td>R 0x0</td>
<td>ICID2</td>
</tr>
<tr>
<td>7</td>
<td>phy_otg</td>
<td>R 0x1</td>
<td>PHY_OTG</td>
</tr>
<tr>
<td>6</td>
<td>phy_chg_dtc</td>
<td>R 0x0</td>
<td>PHY_CHG_DTC</td>
</tr>
<tr>
<td>5</td>
<td>phy_hsic</td>
<td>R 0x0</td>
<td>PHY_HSIC</td>
</tr>
<tr>
<td>4</td>
<td>phy_ulpi</td>
<td>R 0x0</td>
<td>PHY_ULPI</td>
</tr>
<tr>
<td>3</td>
<td>dig_regulator</td>
<td>R 0x0</td>
<td>DIG_REGULATOR</td>
</tr>
<tr>
<td>2:1</td>
<td>nd</td>
<td>R 0x0</td>
<td>ND</td>
</tr>
<tr>
<td>0</td>
<td>phy_multiport</td>
<td>R 0x0</td>
<td>PHY_MULTIPORT</td>
</tr>
</tbody>
</table>
24.4  Flash Controller Address Block

24.4.1  Flash Controller Register Map

Table 317: Flash Controller Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>FCCR</td>
<td>0x2000_0205</td>
<td>Flash Controller Configuration Register</td>
<td>Page: 431</td>
</tr>
<tr>
<td>0x04</td>
<td>FCTR</td>
<td>0x0000_0005</td>
<td>Flash Controller Timing Register</td>
<td>Page: 432</td>
</tr>
<tr>
<td>0x08</td>
<td>FCSR</td>
<td>0x0000_0000</td>
<td>Flash Controller Status Register</td>
<td>Page: 433</td>
</tr>
<tr>
<td>0x0C</td>
<td>FCACR</td>
<td>0x0000_0000</td>
<td>Flash Controller Auxiliary Configuration Register</td>
<td>Page: 434</td>
</tr>
<tr>
<td>0x10</td>
<td>FCHCR</td>
<td>0x0000_0000</td>
<td>Flash Controller Hit Count Register</td>
<td>Page: 434</td>
</tr>
<tr>
<td>0x14</td>
<td>FCMCR</td>
<td>0x0000_0000</td>
<td>Flash Controller Miss Count Register</td>
<td>Page: 435</td>
</tr>
<tr>
<td>0x18</td>
<td>FAOFFR</td>
<td>0x0000_0000</td>
<td>Flash Address Offset Register</td>
<td>Page: 435</td>
</tr>
<tr>
<td>0x1C</td>
<td>FADDMAT</td>
<td>0x0000_0000</td>
<td>Flash Address Match Register</td>
<td>Page: 435</td>
</tr>
<tr>
<td>0x20</td>
<td>FWAITR</td>
<td>0x0000_0000</td>
<td>Flash Wait Register</td>
<td>Page: 436</td>
</tr>
<tr>
<td>0x24</td>
<td>FCCR2</td>
<td>0x0000_0000</td>
<td>Flash Controller Configuration Register2</td>
<td>Page: 436</td>
</tr>
<tr>
<td>0x28</td>
<td>FINSTR</td>
<td>0x0000_0000</td>
<td>Flash Instruction Register</td>
<td>Page: 438</td>
</tr>
<tr>
<td>0x2C</td>
<td>FRMR</td>
<td>0x0000_0000</td>
<td>Flash Read Mode Register</td>
<td>Page: 438</td>
</tr>
</tbody>
</table>

24.4.2  Flash Controller Registers

24.4.2.1  Flash Controller Configuration Register (FCCR)

Table 318: Flash Controller Configuration Register (FCCR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31   | flashc_pad_en    | R/W 0x0      | Flashc Pad Enable
Controls the mux between AHB Flashc & APB QSPI.
0x0 = APB QSPI connects to the Flash device
0x1 = Flashc connects to the Flash device |
| 30   | cache_en         | R/W 0x0      | Flash Cache Enable                                                          |
| 29   | cache_line_flush | R/W 0x1      | Cache Line Flush                                                            |
### Flash Controller Configuration Register (FCCR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>28</td>
<td>sram_mode_en</td>
<td>R/W 0x0</td>
<td>SRAM Mode Enable</td>
</tr>
<tr>
<td>27:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>clk_pha</td>
<td>R/W 0x0</td>
<td>Serial Interface Clock Phase</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Selects the serial interface clock phase.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = data is captured on the rising edge of the serial clock when CLK_POL=0 and on the falling edge when CLK_POL=1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = data is captured on the falling edge of the serial clock when CLK_POL=0 and on the rising edge when CLK_POL=1</td>
</tr>
<tr>
<td>14</td>
<td>clk_pol</td>
<td>R/W 0x0</td>
<td>Serial Interface Clock Polarity</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Selects the Serial Interface Clock as HIGH or LOW when inactive.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = serial interface clock is LOW when inactive</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = serial interface clock is HIGH when inactive</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>12:8</td>
<td>clk_prescale</td>
<td>R/W 0x2</td>
<td>Serial Interface Clock Prescaler (from Base SPI clock)</td>
</tr>
<tr>
<td>7:4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:0</td>
<td>cmd_type</td>
<td>R/W 0x5</td>
<td>Serial Flash Command Typeclocks (based on This Command Type Field for Winbond devices)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The Flash Controller will automatically build the necessary Instruction, followed by Address, followed by dummy.</td>
</tr>
</tbody>
</table>

### 24.4.2.2 Flash Controller Timing Register (FCTR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCTR</td>
<td>0x04</td>
</tr>
</tbody>
</table>

### Flash Controller Timing Register (FCTR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.4.2.3 Flash Controller Status Register (FCSR)

Table 319: Flash Controller Timing Register (FCTR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>clk_capt_edge</td>
<td>R/W 0x1</td>
<td>Serial Interface Capture Clock Edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Capture serial interface input data on either the rising or falling edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>of the serial interface clock. This bit is used to allow more time to</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>capture the input data.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 =</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 0, capture</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>input data on rising edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 1, capture</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>input data on falling edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 1 and CLK_PHA (R04 [7]) = 0, capture</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>input data on falling edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 1 and CLK_PHA (R04 [7]) = 1, capture</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>input data on rising edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 =</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 0, capture</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>input data on falling edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 1, capture</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>input data on rising edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>When CLK_PHA (R04 [7]) = 1, this bit must be set to 0.</td>
</tr>
<tr>
<td>3:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

Table 320: Flash Controller Status Register (FCSR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCSR</td>
<td>0x08</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>cont_rd_md_exit_done</td>
<td>R/W1CLR 0x0</td>
<td>Continuous Read Mode Exit Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Software needs to check this bit after issuing Continuous Read Mode Exit command (CMD_TYPE = 4’hC OR 4’hD). This is a sticky bit, and software</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>needs to write one to clear.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = continuous read mode exit not complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = continuous read mode exit complete</td>
</tr>
</tbody>
</table>
24.4.2.4 Flash Controller Auxiliary Configuration Register (FCACR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCACR</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

Table 321: Flash Controller Auxiliary Configuration Register (FCACR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3</td>
<td>offset_en</td>
<td>R/W 0x0</td>
<td>Address Offset Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = all Flash memory accesses do not use address offset register</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = using address offset defined in FAOFFR is enabled for all</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Flash memory accesses</td>
</tr>
<tr>
<td>2</td>
<td>addr_match_en</td>
<td>R/W 0x0</td>
<td>Address Match Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable counting of misses to a specific address</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable counting of misses to a specific address defined in FADDMAT</td>
</tr>
<tr>
<td>1</td>
<td>miss_cnt_en</td>
<td>R/W 0x0</td>
<td>Miss Count Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable the counting of misses</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable the counting of number of misses to the cache</td>
</tr>
<tr>
<td>0</td>
<td>hit_cnt_en</td>
<td>R/W 0x0</td>
<td>Miss Count Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable the counting of hits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable the counting of number of hits to the cache</td>
</tr>
</tbody>
</table>

24.4.2.5 Flash Controller Hit Count Register (FCHCR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCHCR</td>
<td>0x10</td>
</tr>
</tbody>
</table>

Table 322: Flash Controller Hit Count Register (FCHCR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>hit_count</td>
<td>R/W CLR 0x0</td>
<td>Hit Counter</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>When FCACR.HIT_CNT_EN=1 this counter tracks the number of hits that have</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>occurred to the Flash Cache. Software can read this register to understand</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>the hits. This register is cleared when software does a write to this</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>register.</td>
</tr>
</tbody>
</table>
24.4.2.6 Flash Controller Miss Count Register (FCMCR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCMCR</td>
<td>0x14</td>
</tr>
</tbody>
</table>

Table 323: Flash Controller Miss Count Register (FCMCR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0   | miss_count | R/WCLR 0x0   | Hit Counter
When FCACR.MISS_CNT_EN=1 this counter tracks the number of hits that have occurred to the Flash Cache. If FCACR.ADDR_MATCH_EN=1 AND FCACR.MISS_CNT_EN=1 then misses to the specific address configured into FADDMAT register is captured into this counter. Software can read this register to understand the misses. This register is cleared when software does a write to this register.

24.4.2.7 Flash Address Offset Register (FAOFFR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FAOFFR</td>
<td>0x18</td>
</tr>
</tbody>
</table>

Table 324: Flash Address Offset Register (FAOFFR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0   | offset_val | R/W 0x0     | Flash Address Offset Value
When FCACR.OFFSET_EN=1 then this register specifies the address offset from Flash base address that is used for all Flash memory accesses.

24.4.2.8 Flash Address Match Register (FADDMAT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FADDMAT</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

Table 325: Flash Address Match Register (FADDMAT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0   | addr  | R/W 0x0      | Flash Memory Address to Compare and Match
When FCACR.ADDR_MATCH_EN=1 and FCACR.MISS_CNT_EN=1 then all misses to the address in this register are captured into the FCMCR.
24.4.2.9 Flash Wait Register (FWAITR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FWAITR</td>
<td>0x20</td>
</tr>
</tbody>
</table>

Table 326: Flash Wait Register (FWAITR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>zwait</td>
<td>R/W 0x1</td>
<td>Zero Wait. Enable the 2 bus cycles read for a cache-hit. Otherwise, 3 bus cycles are needed. This feature is not supported when FlashC is running faster than 100 MHz.</td>
</tr>
</tbody>
</table>

24.4.2.10 Flash Controller Configuration Register2 (FCCR2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCCR2</td>
<td>0x24</td>
</tr>
</tbody>
</table>

Table 327: Flash Controller Configuration Register2 (FCCR2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>use_cfg_ovrd</td>
<td>R/W 0x0</td>
<td>Use Configuration Override. This bit, when set by software, overrides the built-in hardware Flash transfer generation defined through FCCR.CMD_TYPE. Software has control over Instruction, Address, and other configuration. Software needs to program all the necessary fields in FCCR2 to successfully complete a transfer to Flash. 0x0 = use FCCR.CMD_TYPE to determine/build Flash command/transfer 0x1 = use configuration FCCR2 to determine/build Flash command/transfer</td>
</tr>
<tr>
<td>30:29</td>
<td>data_pin</td>
<td>R/W 0x0</td>
<td>Data Transfer Pins. Number of pins used to transfer data. 0x0 = use 1 pin for data 0x1 = use 2 pins for data 0x2 = use 4 pins for data 0x3 = reserved</td>
</tr>
<tr>
<td>28</td>
<td>addr_pin</td>
<td>R/W 0x0</td>
<td>Address Transfer Pins. Number of pins used to transfer the Flash address. 0x0 = use one pin 0x1 = use number of pins as indicated by DATA_PIN field in this register</td>
</tr>
</tbody>
</table>
Table 327: Flash Controller Configurationb Register2 (FCCR2) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>27</td>
<td>byte_len</td>
<td>R/W 0x0</td>
<td>Byte Length Number of bytes in each serial transfer. 0x0 = 1 byte 0x1 = 4 bytes</td>
</tr>
<tr>
<td>26:14</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>13:12</td>
<td>dummy_cnt</td>
<td>R/W 0x0</td>
<td>Dummy Count Defines the number of dummy bytes that need to be sent to Flash. The data shifted out is always 0. 0x0 = 0 bytes 0x1 = 1 byte 0x2 = 2 bytes 0x3 = reserved</td>
</tr>
<tr>
<td>11:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9:8</td>
<td>rm_cnt</td>
<td>R/W 0x0</td>
<td>Read Mode Count Number of Read Mode bytes (as defined in FRMR) that are sent out to Flash. 0x0 = 0 bytes 0x1 = 1 byte 0x2 = 2 bytes 0x3 = reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6:4</td>
<td>addr_cnt</td>
<td>R/W 0x0</td>
<td>Address Count Number of bytes of address that is sent to Flash. 0x0 = 0 bytes 0x1 = 1 byte 0x2 = 2 bytes 0x3 = 3 bytes 0x4 = 4 bytes 0x5 to 0x7 = reserved</td>
</tr>
<tr>
<td>3:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1:0</td>
<td>instr_cnt</td>
<td>R/W 0x0</td>
<td>Instruction Count Number of bytes of Instruction (defined in FINSTR) to send to Flash. 0x0 = 0 bytes 0x1 = 1 byte 0x2 = 2 bytes 0x3 = reserved</td>
</tr>
</tbody>
</table>
24.4.2.11  Flash Instruction Register (FINSTR)

Table 328: Flash Instruction Register (FINSTR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 15:0   | instr  | R/W 0x0      | Flash Instruction  
The contents of this register define the instruction Op code that gets sent to the Flash device.  
When FCCR2.INSTR_CNT=0, this register content is not sent out.  
When FCCR2.INSTR_CNT=1, bits [7:0] of this register are sent out.  
When FCCR.INSTR_CNT=2, bits [15:8] of this register are sent out first followed by bits [7:0]. |

24.4.2.12  Flash Read Mode Register (FRMR)

Table 329: Flash Read Mode Register (FRMR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 15:0   | rdmode  | R/W 0x0      | Flash Read Mode  
The contents of this register determine the Read Mode information that gets sent to the Flash device after Address cycle.  
When FCCR2.RM_CNT=0, this register content is not sent out.  
When FCCR2.RM_CNT=1, bits [7:0] of this register are sent out.  
When FCCR.RM_CNT=2, bits [15:8] of this register are sent out first followed by bits [7:0]. |
# 24.5 AES Address Block

## 24.5.1 AES Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>ctrl1</td>
<td>0x0000_4010</td>
<td>AES Control Register 1</td>
<td>Page: 440</td>
</tr>
<tr>
<td>0x04</td>
<td>ctrl2</td>
<td>0x0000_0000</td>
<td>AES Control Register 2</td>
<td>Page: 442</td>
</tr>
<tr>
<td>0x08</td>
<td>status</td>
<td>0x0000_0081</td>
<td>AES Status Register</td>
<td>Page: 442</td>
</tr>
<tr>
<td>0x0C</td>
<td>astr_len</td>
<td>0x0000_0000</td>
<td>AES Astr Length Register</td>
<td>Page: 444</td>
</tr>
<tr>
<td>0x10</td>
<td>mstr_len</td>
<td>0x0000_0000</td>
<td>AES Mstr Length Register</td>
<td>Page: 444</td>
</tr>
<tr>
<td>0x14</td>
<td>str_in</td>
<td>0x0000_0000</td>
<td>AES Stream Input Register</td>
<td>Page: 444</td>
</tr>
<tr>
<td>0x18</td>
<td>iv0</td>
<td>0x0000_0000</td>
<td>AES Input Vector Register 0</td>
<td>Page: 445</td>
</tr>
<tr>
<td>0x1C</td>
<td>iv1</td>
<td>0x0000_0000</td>
<td>AES Input Vector Register 1</td>
<td>Page: 445</td>
</tr>
<tr>
<td>0x20</td>
<td>iv2</td>
<td>0x0000_0000</td>
<td>AES Input Vector Register 2</td>
<td>Page: 445</td>
</tr>
<tr>
<td>0x24</td>
<td>iv3</td>
<td>0x0000_0000</td>
<td>AES Input Vector Register 3</td>
<td>Page: 445</td>
</tr>
<tr>
<td>0x28</td>
<td>key0</td>
<td>0x0000_0000</td>
<td>AES Key 0 Register</td>
<td>Page: 446</td>
</tr>
<tr>
<td>0x2C</td>
<td>key1</td>
<td>0x0000_0000</td>
<td>AES Key 1 Register</td>
<td>Page: 446</td>
</tr>
<tr>
<td>0x30</td>
<td>key2</td>
<td>0x0000_0000</td>
<td>AES Key 2 Register</td>
<td>Page: 446</td>
</tr>
<tr>
<td>0x34</td>
<td>key3</td>
<td>0x0000_0000</td>
<td>AES Key 3 Register</td>
<td>Page: 447</td>
</tr>
<tr>
<td>0x38</td>
<td>key4</td>
<td>0x0000_0000</td>
<td>AES Key 4 Register</td>
<td>Page: 447</td>
</tr>
<tr>
<td>0x3C</td>
<td>key5</td>
<td>0x0000_0000</td>
<td>AES Key 5 Register</td>
<td>Page: 447</td>
</tr>
<tr>
<td>0x40</td>
<td>key6</td>
<td>0x0000_0000</td>
<td>AES Key 6 Register</td>
<td>Page: 447</td>
</tr>
<tr>
<td>0x44</td>
<td>key7</td>
<td>0x0000_0000</td>
<td>AES Key 7 Register</td>
<td>Page: 448</td>
</tr>
<tr>
<td>0x48</td>
<td>str_out</td>
<td>0x0000_0000</td>
<td>AES Stream Output Port Register</td>
<td>Page: 448</td>
</tr>
<tr>
<td>0x4C</td>
<td>ov0</td>
<td>0x0000_0000</td>
<td>AES Output Vector 0 Register</td>
<td>Page: 448</td>
</tr>
<tr>
<td>0x50</td>
<td>ov1</td>
<td>0x0000_0000</td>
<td>AES Output Vector 1 Register</td>
<td>Page: 449</td>
</tr>
<tr>
<td>0x54</td>
<td>ov2</td>
<td>0x0000_0000</td>
<td>AES Output Vector 2 Register</td>
<td>Page: 449</td>
</tr>
<tr>
<td>0x58</td>
<td>ov3</td>
<td>0x0000_0000</td>
<td>AES Output Vector 3 Register</td>
<td>Page: 449</td>
</tr>
<tr>
<td>0x5C</td>
<td>isr</td>
<td>0x0000_0000</td>
<td>AES Interrupt Status Register</td>
<td>Page: 449</td>
</tr>
<tr>
<td>0x60</td>
<td>imr</td>
<td>0x0000_0007</td>
<td>AES Interrupt Mask Register</td>
<td>Page: 450</td>
</tr>
</tbody>
</table>
Table 330: AES Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x64</td>
<td>isr</td>
<td>0x0000_0000</td>
<td>AES Interrupt Raw Status Register</td>
<td>Page: 451</td>
</tr>
<tr>
<td>0x68</td>
<td>icr</td>
<td>0x0000_0000</td>
<td>AES Interrupt Clear Register</td>
<td>Page: 451</td>
</tr>
<tr>
<td>0x8C</td>
<td>rev_id</td>
<td>0x0000_0012</td>
<td>AES Revision Register</td>
<td>Page: 452</td>
</tr>
</tbody>
</table>

24.5.2 AES Registers

24.5.2.1 AES Control Register 1 (ctrl1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ctrl1</td>
<td>0x00</td>
</tr>
</tbody>
</table>

Table 331: AES Control Register 1 (ctrl1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:27</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>26</td>
<td>cts_mode</td>
<td>R/W 0x0</td>
<td>Cipher Stealing Mode of CBC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = NXP mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = NIST-CS2 mode</td>
</tr>
<tr>
<td>25:19</td>
<td>ctr_mod</td>
<td>R/W 0x0</td>
<td>CTR Mode’s Counter Modular</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>modular = 2^128: [7'h0-7'hF]</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>modular = 2^ctr_mod: others</td>
</tr>
<tr>
<td>18:16</td>
<td>mode</td>
<td>R/W 0x0</td>
<td>AES Running Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = ECB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = CBC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = CTR</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = RESERVED</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = RESERVED</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = CCM*</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = MMO</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = BYPASS</td>
</tr>
<tr>
<td>15</td>
<td>decrypt</td>
<td>R/W 0x0</td>
<td>Decrypt Operation (ignored in MMO and BYPASS mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = encryption</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = decryption</td>
</tr>
<tr>
<td>14</td>
<td>out_mic</td>
<td>R/W 0x1</td>
<td>Append MIC/HASH at the End of Output Stream in CCM* Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>decryption/MMO mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = not append MIC/HASH at the end of output stream in CCM* mode decryption or MMO mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = append MIC/HASH at the end of output stream in CCM* mode decryption or MMO mode</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/ HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>------------</td>
<td>--------------</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td>13:12</td>
<td>mic_len</td>
<td>R/W 0x0</td>
<td>Length of MIC Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 0 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 4 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 8 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 16 bytes</td>
</tr>
<tr>
<td>11:10</td>
<td>key_size</td>
<td>R/W 0x0</td>
<td>Key Size Parameter</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 16 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 32 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 24 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = reserved</td>
</tr>
<tr>
<td>9</td>
<td>dma_en</td>
<td>R/W 0x0</td>
<td>Enable DMA</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable DMA</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable DMA</td>
</tr>
<tr>
<td>8</td>
<td>io_src</td>
<td>R/W 0x0</td>
<td>AES Data Input Source</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = i/O through register</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = i/O through DMA</td>
</tr>
<tr>
<td>7</td>
<td>pri1</td>
<td>R/W 0x0</td>
<td>AES Priority on Hardware (BH-MAC) Side</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = low priority</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = high priority</td>
</tr>
<tr>
<td>6</td>
<td>pri0</td>
<td>R/W 0x0</td>
<td>AES Priority on MCU (software) Side</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = low priority</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = high priority</td>
</tr>
<tr>
<td>5</td>
<td>out_hdr</td>
<td>R/W 0x0</td>
<td>Output B0 and l(a) in CCM* Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not output B0 and l(a) at the beginning of output stream</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = output B0 and l(a) at the beginning of output stream</td>
</tr>
<tr>
<td>4</td>
<td>out_msg</td>
<td>R/W 0x1</td>
<td>Output Stream to Output FIFO</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = block output stream from output FIFO</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = forward output stream to output FIFO</td>
</tr>
<tr>
<td>3</td>
<td>of_clr</td>
<td>R/W 0x0</td>
<td>Clear Output FIFO</td>
</tr>
<tr>
<td>2</td>
<td>if_clr</td>
<td>R/W 0x0</td>
<td>Clear Input FIFO</td>
</tr>
<tr>
<td>1</td>
<td>lock0</td>
<td>R/W 0x0</td>
<td>Lock AES on MCU Side</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write 0 to release AES</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write 1 to lock AES on behalf of MCU</td>
</tr>
<tr>
<td>0</td>
<td>start</td>
<td>R/W 0x0</td>
<td>Start AES</td>
</tr>
</tbody>
</table>
24.5.2.2 AES Control Register 2 (ctrl2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ctrl2</td>
<td>0x04</td>
</tr>
</tbody>
</table>

Table 332: AES Control Register 2 (ctrl2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 1      | auto_reset_en | R/W 0x0 | Enable Automatic Reset After Lock Successfully  
|        |          |              | 0x0 = no automatic reset  
|        |          |              | 0x1 = automatic reset after lock successfully                               |
| 0      | aes_reset | R/W 0x0     | Reset AES  
|        |          |              | 0x0 = un-reset AES  
|        |          |              | 0x1 = reset AES                                                            |

24.5.2.3 AES Status Register (status)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>status</td>
<td>0x08</td>
</tr>
</tbody>
</table>

Table 333: AES Status Register (status)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:21</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 20     | rsvd_vld | R 0x0        | RSVD Valid  
|        |          |              | 0x0 = rsvd0 and rsvd1 not valid  
|        |          |              | 0x1 = rsvd0 and rsvd1 are valid                                             |
| 19:17  | of_depth | R 0x0        | Output FIFO Depth                                                           |
| 16:14  | if_depth | R 0x0        | Input FIFO Depth                                                            |
### Table 333: AES Status Register (status) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13:11</td>
<td>status</td>
<td>R 0x0</td>
<td>AES Operation Error Status &lt;br&gt; aesw_status[2]: MIC Mismatch during CCM* Decryption &lt;br&gt; aesw_status[1]: Data is not multiple of 16 bytes in ECB mode or Data is more than 2^13-1 bytes in MMO mode &lt;br&gt; aesw_status[0]: Input stream size less than 16 byte in ECB, CBC and CTR mode &lt;br&gt; 0x0 = no operation error &lt;br&gt; 0x1 = input stream size less than 16 byte in ECB, CBC and CTR mode &lt;br&gt; 0x2 = data is not multiple of 16 bytes in ECB mode or data is more than 2^13-1 bytes in MMO mode &lt;br&gt; 0x3 = data is not multiple of 16 bytes and less than 16 byte in ECB mode &lt;br&gt; 0x4 = MIC mismatch during CCM* decryption &lt;br&gt; others = not valid</td>
</tr>
<tr>
<td>10:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7</td>
<td>of_empty</td>
<td>R 0x1</td>
<td>Output FIFO Empty &lt;br&gt; 0x0 = output FIFO is not empty &lt;br&gt; 0x1 = output FIFO is empty</td>
</tr>
<tr>
<td>6</td>
<td>of_rdy</td>
<td>R 0x0</td>
<td>Output FIFO Is Ready to Read &lt;br&gt; 0x0 = output FIFO is not ready to read &lt;br&gt; 0x1 = output FIFO is ready to read</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>if_full</td>
<td>R 0x0</td>
<td>Input FIFO Full &lt;br&gt; 0x0 = input FIFO is not full &lt;br&gt; 0x1 = input FIFO is full</td>
</tr>
<tr>
<td>3</td>
<td>lock1</td>
<td>R 0x0</td>
<td>Lock AES on Hardware (BH-MAC) Side &lt;br&gt; 0x0 = hardware unlocks AES &lt;br&gt; 0x1 = hardware requests to lock AES</td>
</tr>
<tr>
<td>2</td>
<td>rsvd1</td>
<td>R 0x0</td>
<td>AES Is Locked by Hardware (BH-MAC) &lt;br&gt; 0x0 = AES is not locked by hardware &lt;br&gt; 0x1 = AES is locked by hardware</td>
</tr>
<tr>
<td>1</td>
<td>rsvd0</td>
<td>R 0x0</td>
<td>AES Is Locked by MCU &lt;br&gt; 0x0 = AES is not locked by MCU &lt;br&gt; 0x1 = AES is locked by MCU</td>
</tr>
<tr>
<td>0</td>
<td>done</td>
<td>R 0x1</td>
<td>AES Operation Done &lt;br&gt; 0x0 = AES operation has not done yet &lt;br&gt; 0x1 = AES operation done</td>
</tr>
</tbody>
</table>
24.5.2.4  AES Astr Length Register (astr_len)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>astr_len</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

Table 334: AES Astr Length Register (astr_len)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>astr_len</td>
<td>R/W 0x0</td>
<td>Size of Associate String</td>
</tr>
</tbody>
</table>

24.5.2.5  AES Mstr Length Register (mstr_len)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>mstr_len</td>
<td>0x10</td>
</tr>
</tbody>
</table>

Table 335: AES Mstr Length Register (mstr_len)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>mstr_len</td>
<td>R/W 0x0</td>
<td>Size of Message String</td>
</tr>
</tbody>
</table>

24.5.2.6  AES Stream Input Register (str_in)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>str_in</td>
<td>0x14</td>
</tr>
</tbody>
</table>

Table 336: AES Stream Input Register (str_in)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>str_in</td>
<td>W 0x0</td>
<td>Input Message Word</td>
</tr>
</tbody>
</table>

24.5.2.7  AES Input Vector Register 0 (iv0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>iv0</td>
<td>0x18</td>
</tr>
</tbody>
</table>
### Table 337: AES Input Vector Register 0 (iv0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>iv0</td>
<td>R/W 0x0</td>
<td>Byte 0-3 of Initial Vector</td>
</tr>
</tbody>
</table>

### 24.5.2.8 AES Input Vector Register 1 (iv1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>iv1</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

### Table 338: AES Input Vector Register 1 (iv1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>iv1</td>
<td>R/W 0x0</td>
<td>Byte 4-7 of Initial Vector</td>
</tr>
</tbody>
</table>

### 24.5.2.9 AES Input Vector Register 2 (iv2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>iv2</td>
<td>0x20</td>
</tr>
</tbody>
</table>

### Table 339: AES Input Vector Register 2 (iv2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>iv2</td>
<td>R/W 0x0</td>
<td>Byte 8-11 of Initial Vector</td>
</tr>
</tbody>
</table>

### 24.5.2.10 AES Input Vector Register 3 (iv3)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>iv3</td>
<td>0x24</td>
</tr>
</tbody>
</table>

### Table 340: AES Input Vector Register 3 (iv3)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>iv3</td>
<td>R/W 0x0</td>
<td>Byte 12-15 of Initial Vector</td>
</tr>
</tbody>
</table>
24.5.2.11  AES Key 0 Register (key0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key0</td>
<td>0x28</td>
</tr>
</tbody>
</table>

Table 341: AES Key 0 Register (key0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>key0</td>
<td>R/W 0x0</td>
<td>Byte 0-3 of Key</td>
</tr>
</tbody>
</table>

24.5.2.12  AES Key 1 Register (key1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key1</td>
<td>0x2C</td>
</tr>
</tbody>
</table>

Table 342: AES Key 1 Register (key1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>key1</td>
<td>R/W 0x0</td>
<td>Byte 4-7 of Key</td>
</tr>
</tbody>
</table>

24.5.2.13  AES Key 2 Register (key2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key2</td>
<td>0x30</td>
</tr>
</tbody>
</table>

Table 343: AES Key 2 Register (key2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>key2</td>
<td>R/W 0x0</td>
<td>Byte 8-11 of Key</td>
</tr>
</tbody>
</table>

24.5.2.14  AES Key 3 Register (key3)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key3</td>
<td>0x34</td>
</tr>
</tbody>
</table>
### 24.5.2.15 AES Key 4 Register (key4)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>key4</td>
<td>R/W 0x0</td>
<td>Byte 16-19 of Key</td>
</tr>
</tbody>
</table>

#### Table 345: AES Key 4 Register (key4)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key4</td>
<td>0x38</td>
</tr>
</tbody>
</table>

### 24.5.2.16 AES Key 5 Register (key5)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>key5</td>
<td>R/W 0x0</td>
<td>Byte 20-23 of Key</td>
</tr>
</tbody>
</table>

#### Table 346: AES Key 5 Register (key5)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key5</td>
<td>0x3C</td>
</tr>
</tbody>
</table>

### 24.5.2.17 AES Key 6 Register (key6)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>key6</td>
<td>R/W 0x0</td>
<td>Byte 24-27 of Key</td>
</tr>
</tbody>
</table>

#### Table 347: AES Key 6 Register (key6)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key6</td>
<td>0x40</td>
</tr>
</tbody>
</table>
24.5.2.18  AES Key 7 Register (key7)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>key7</td>
<td>0x44</td>
</tr>
</tbody>
</table>

Table 348: AES Key 7 Register (key7)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>key7</td>
<td>R/W 0x0</td>
<td>Byte 28-31 of Key</td>
</tr>
</tbody>
</table>

24.5.2.19  AES Stream Output Port Register (str_out)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>str_out</td>
<td>0x48</td>
</tr>
</tbody>
</table>

Table 349: AES Stream Output Port Register (str_out)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>str_out</td>
<td>R 0x0</td>
<td>Output Message Word</td>
</tr>
</tbody>
</table>

24.5.2.20  AES Output Vector 0 Register (ov0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ov0</td>
<td>0x4C</td>
</tr>
</tbody>
</table>

Table 350: AES Output Vector 0 Register (ov0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>ov0</td>
<td>R 0x0</td>
<td>Byte 0-3 of Output Vector</td>
</tr>
</tbody>
</table>

24.5.2.21  AES Output Vector 1 Register (ov1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ov1</td>
<td>0x50</td>
</tr>
</tbody>
</table>
### 24.5.2.22 AES Output Vector 2 Register (ov2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ov2</td>
<td>0x54</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>ov2</td>
<td>R 0x0</td>
<td>Byte 8-11 of Output Vector</td>
</tr>
</tbody>
</table>

### 24.5.2.23 AES Output Vector 3 Register (ov3)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ov3</td>
<td>0x58</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>ov3</td>
<td>R 0x0</td>
<td>Byte 12-15 of Output Vector</td>
</tr>
</tbody>
</table>

### 24.5.2.24 AES Interrupt Status Register (isr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>isr</td>
<td>0x5C</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 354: AES Interrupt Status Register (isr) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>status[2]</td>
<td>R 0x0</td>
<td>Status of AES Output FIFO Empty Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = AES output FIFO empty interrupt not occurred</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = AES output FIFO empty interrupt occurred</td>
</tr>
<tr>
<td>1</td>
<td>status[1]</td>
<td>R 0x0</td>
<td>Status of AES Input FIFO Full Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = AES input FIFO full interrupt not occurred</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = AES input FIFO full interrupt occurred</td>
</tr>
<tr>
<td>0</td>
<td>status[0]</td>
<td>R 0x0</td>
<td>Status of AES Output FIFO Empty Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = AES operation done interrupt not occurred</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = AES operation done interrupt occurred</td>
</tr>
</tbody>
</table>

24.5.2.25 AES Interrupt Mask Register (imr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>imr</td>
<td>0x60</td>
</tr>
</tbody>
</table>

Table 355: AES Interrupt Mask Register (imr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2</td>
<td>mask[2]</td>
<td>R/W 0x1</td>
<td>Mask of AES Output FIFO Empty Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = enable AES output FIFO empty interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = disable AES output FIFO empty interrupt</td>
</tr>
<tr>
<td>1</td>
<td>mask[1]</td>
<td>R/W 0x1</td>
<td>Mask of AES Input FIFO Full Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = enable AES input FIFO full interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = disable AES input FIFO full interrupt</td>
</tr>
<tr>
<td>0</td>
<td>mask[0]</td>
<td>R/W 0x1</td>
<td>Mask of AES Operation Done Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = enable AES operation done interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = disable AES operation done interrupt</td>
</tr>
</tbody>
</table>

24.5.2.26 AES Interrupt Raw Status Register (irsr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>irsr</td>
<td>0x64</td>
</tr>
</tbody>
</table>
Table 356: AES Interrupt Raw Status Register (irsr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2</td>
<td>status_raw[2]</td>
<td>R 0x0</td>
<td>AES Output FIFO Empty Interrupt Raw Status Regardless of Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = AES output FIFO empty interrupt not occurred</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = AES output FIFO empty interrupt</td>
</tr>
<tr>
<td>1</td>
<td>status_raw[1]</td>
<td>R 0x0</td>
<td>AES Input FIFO Full Interrupt Raw Status Regardless of Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = AES no input FIFO full interrupt not occurred</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = AES no input FIFO full interrupt occurred</td>
</tr>
<tr>
<td>0</td>
<td>status_raw[0]</td>
<td>R 0x0</td>
<td>AES Operation Done Interrupt Raw Status Regardless of Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = AES operation done interrupt not occurred</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = AES operation done interrupt occurred</td>
</tr>
</tbody>
</table>

24.5.2.27 AES Interrupt Clear Register (icr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>icr</td>
<td>0x68</td>
</tr>
</tbody>
</table>

Table 357: AES Interrupt Clear Register (icr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2</td>
<td>clear[2]</td>
<td>R/W 0x0</td>
<td>Clearance of AES Output FIFO Empty Interrupt Status and Raw Status</td>
</tr>
<tr>
<td>1</td>
<td>clear[1]</td>
<td>R/W 0x0</td>
<td>Clearance of AES Input FIFO Full Interrupt Status and Raw Status</td>
</tr>
<tr>
<td>0</td>
<td>clear[0]</td>
<td>R/W 0x0</td>
<td>Clearance of AES Operation Done Interrupt Status and Raw Status</td>
</tr>
</tbody>
</table>

24.5.2.28 AES Revision Register (rev_id)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>rev_id</td>
<td>0x8C</td>
</tr>
</tbody>
</table>
Table 358: AES Revision Register (rev_id)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:4</td>
<td>major_rev_id</td>
<td>R 0x1</td>
<td>Major Revision ID</td>
</tr>
<tr>
<td>3:0</td>
<td>minor_rev_id</td>
<td>R 0x2</td>
<td>Minor Revision ID</td>
</tr>
</tbody>
</table>
24.6 CRC Address Block

24.6.1 CRC Register Map

Table 359: CRC Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>isr</td>
<td>0x0000_0000</td>
<td>Interrupt Status Register</td>
<td>Page: 453</td>
</tr>
<tr>
<td>0x04</td>
<td>irsr</td>
<td>0x0000_0000</td>
<td>Interrupt Raw Status Register</td>
<td>Page: 454</td>
</tr>
<tr>
<td>0x08</td>
<td>icr</td>
<td>0x0000_0000</td>
<td>Interrupt Clear Register</td>
<td>Page: 454</td>
</tr>
<tr>
<td>0x0C</td>
<td>imr</td>
<td>0x0000_0001</td>
<td>Interrupt Mask Register</td>
<td>Page: 454</td>
</tr>
<tr>
<td>0x10</td>
<td>ctrl</td>
<td>0x0000_0000</td>
<td>CRC Module Control Register</td>
<td>Page: 455</td>
</tr>
<tr>
<td>0x14</td>
<td>stream_len_m1</td>
<td>0x0000_0000</td>
<td>Stream Length Minus 1 Register</td>
<td>Page: 455</td>
</tr>
<tr>
<td>0x18</td>
<td>stream_in</td>
<td>0x0000_0000</td>
<td>Stream Input Register</td>
<td>Page: 456</td>
</tr>
<tr>
<td>0x1C</td>
<td>result</td>
<td>0x0000_0000</td>
<td>CRC Calculation Result Register</td>
<td>Page: 456</td>
</tr>
<tr>
<td>0x3C</td>
<td>rev_id</td>
<td>0x0000_0012</td>
<td>CRC Revision ID Register</td>
<td>Page: 456</td>
</tr>
</tbody>
</table>

24.6.2 CRC Registers

24.6.2.1 Interrupt Status Register (isr)

Table 360: Interrupt Status Register (isr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>status</td>
<td>R 0x0</td>
<td>CRC Calculation Interrupt Status After Mask status[0]: CRC done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = interrupt is not occurred</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = interrupt is occurred</td>
</tr>
</tbody>
</table>

24.6.2.2 Interrupt Raw Status Register (irsr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>isr</td>
<td>0x04</td>
</tr>
</tbody>
</table>
### Table 361: Interrupt Raw Status Register (irsr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>status_raw[0]</td>
<td>R 0x0</td>
<td>Raw Status of IRQ Regardless of Mask</td>
</tr>
</tbody>
</table>

### 24.6.2.3 Interrupt Clear Register (icr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>icr</td>
<td>0x08</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Table 362: Interrupt Clear Register (icr)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bits</td>
</tr>
<tr>
<td>------</td>
</tr>
<tr>
<td>31:1</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

### 24.6.2.4 Interrupt Mask Register (imr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>imr</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Table 363: Interrupt Mask Register (imr)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bits</td>
</tr>
<tr>
<td>------</td>
</tr>
<tr>
<td>31:1</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>
24.6.2.5   CRC Module Control Register (ctrl)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ctrl</td>
<td>0x10</td>
</tr>
</tbody>
</table>

Table 364: CRC Module Control Register (ctrl)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:1</td>
<td>mode</td>
<td>R/W 0x0</td>
<td>CRC Mode Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = x<strong>16+x</strong>12+x**5+1 (CRC-16-CCITT, CRC-CCITT)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = x<strong>16+x</strong>15+x**2+1 (CRC-16, CRC-16-IBM, CRC-16-ANSI)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = x<strong>16+x</strong>15+x<strong>11+x</strong>9+x<strong>7+x</strong>5+x<strong>4+x</strong>2+x+1 (CRC-16-T10-DIF)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = x<strong>32+x</strong>26+x<strong>23+x</strong>22+x<strong>16+x</strong>12+x<strong>11+x</strong>10+x<strong>8+x</strong>7+x<strong>5+x</strong>4+x**2+x+1 ( CRC-32-IEEE802.3)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = x<strong>16+x</strong>13+x<strong>12+x</strong>11+x<strong>10+x</strong>8+x<strong>6+x</strong>5+x**2+1 (CRC-16-DNP)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
<tr>
<td>0</td>
<td>enable</td>
<td>R/W 0x0</td>
<td>CRC Calculate Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable CRC calculation</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable CRC calculation (automatically cleared when CRC calculation is finished)</td>
</tr>
</tbody>
</table>

24.6.2.6   Stream Length Minus 1 Register (stream_len_m1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>stream_len_m1</td>
<td>0x14</td>
</tr>
</tbody>
</table>

Table 365: Stream Length Minus 1 Register (stream_len_m1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>length_m1</td>
<td>R/W 0x0</td>
<td>Input Stream Length Minus 1 (units of bytes)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Example:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0000_0000 = input stream length of 1 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0000_00FF = input stream length of 256 bytes</td>
</tr>
</tbody>
</table>
24.6.2.7  Stream Input Register (stream_in)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>stream_in</td>
<td>0x18</td>
</tr>
</tbody>
</table>

Table 366: Stream Input Register (stream_in)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R/W 0x0</td>
<td>Stream Input Data</td>
</tr>
</tbody>
</table>

24.6.2.8  CRC Calculation Result (result)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>result</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

Table 367: CRC Calculation Result (result)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R 0x0</td>
<td>CRC Calculation Result</td>
</tr>
</tbody>
</table>

24.6.2.9  CRC Revision ID Register (rev_id)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>rev_id</td>
<td>0x3C</td>
</tr>
</tbody>
</table>

Table 368: CRC Revision ID Register (rev_id)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVDD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:4</td>
<td>major_rev_id</td>
<td>R 0x1</td>
<td>Major Revision ID</td>
</tr>
<tr>
<td>3:0</td>
<td>minor_rev_id</td>
<td>R 0x2</td>
<td>Minor Revision ID</td>
</tr>
</tbody>
</table>
# 24.7 I²C Address Block

## 24.7.1 I²C Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>IC_CON</td>
<td>0x0000_007F</td>
<td>I²C Control Register</td>
<td>Page: 459</td>
</tr>
<tr>
<td>0x04</td>
<td>IC_TAR</td>
<td>0x0000_1055</td>
<td>I²C Target Address Register</td>
<td>Page: 461</td>
</tr>
<tr>
<td>0x08</td>
<td>IC_SAR</td>
<td>0x0000_0055</td>
<td>I²C Slave Address Register</td>
<td>Page: 462</td>
</tr>
<tr>
<td>0x0C</td>
<td>IC_HS_MADDR</td>
<td>0x0000_0001</td>
<td>I²C High Speed Master Mode Code Address Register</td>
<td>Page: 462</td>
</tr>
<tr>
<td>0x10</td>
<td>IC_DATA_CMD</td>
<td>0x0000_0000</td>
<td>I²C Rx/Tx Data Buffer and Command Register</td>
<td>Page: 463</td>
</tr>
<tr>
<td>0x14</td>
<td>IC_SS_SCL_HCNT</td>
<td>0x0000_01F4</td>
<td>Standard Speed I²C Clock SCL High Count Register</td>
<td>Page: 463</td>
</tr>
<tr>
<td>0x18</td>
<td>IC_SS_SCL_LCNT</td>
<td>0x0000_024C</td>
<td>Standard Speed I²C Clock SCL Low Count Register</td>
<td>Page: 464</td>
</tr>
<tr>
<td>0x1C</td>
<td>IC_FS_SCL_HCNT</td>
<td>0x0000_004B</td>
<td>Fast Speed I²C Clock SCL High Count Register</td>
<td>Page: 465</td>
</tr>
<tr>
<td>0x20</td>
<td>IC_FS_SCL_LCNT</td>
<td>0x0000_0003</td>
<td>Fast Speed I²C Clock SCL Low Count Register</td>
<td>Page: 466</td>
</tr>
<tr>
<td>0x24</td>
<td>IC_HS_SCL_HCNT</td>
<td>0x0000_0008</td>
<td>High Speed I²C Clock SCL High Count Register</td>
<td>Page: 466</td>
</tr>
<tr>
<td>0x28</td>
<td>IC_HS_SCL_LCNT</td>
<td>0x0000_0014</td>
<td>High Speed I²C Clock SCL Low Count Register</td>
<td>Page: 467</td>
</tr>
<tr>
<td>0x2C</td>
<td>IC_INTR_STAT</td>
<td>0x0000_0000</td>
<td>I²C Interrupt Status Register</td>
<td>Page: 468</td>
</tr>
<tr>
<td>0x30</td>
<td>IC_INTR_MASK</td>
<td>0x0000_08FF</td>
<td>I²C Interrupt Mask Register</td>
<td>Page: 470</td>
</tr>
<tr>
<td>0x34</td>
<td>IC_RAW_INTR_STAT</td>
<td>0x0000_0000</td>
<td>I²C Raw Interrupt Status Register</td>
<td>Page: 472</td>
</tr>
<tr>
<td>0x38</td>
<td>IC_RX_TL</td>
<td>0x0000_0000</td>
<td>I²C Receive FIFO Threshold Register</td>
<td>Page: 474</td>
</tr>
<tr>
<td>0x3C</td>
<td>IC_TX_TL</td>
<td>0x0000_0000</td>
<td>I²C Transmit FIFO Threshold Register</td>
<td>Page: 475</td>
</tr>
<tr>
<td>0x40</td>
<td>IC_CLR_INTR</td>
<td>0x0000_0000</td>
<td>Clear Combined and Individual Interrupt Register</td>
<td>Page: 475</td>
</tr>
<tr>
<td>0x44</td>
<td>IC_CLR_RX_UNDER</td>
<td>0x0000_0000</td>
<td>Clear RX_UNDER Interrupt Register</td>
<td>Page: 476</td>
</tr>
<tr>
<td>0x48</td>
<td>IC_CLR_RX_OVER</td>
<td>0x0000_0000</td>
<td>Clear RX_OVER Interrupt Register</td>
<td>Page: 476</td>
</tr>
<tr>
<td>0x4C</td>
<td>IC_CLR_TX_OVER</td>
<td>0x0000_0000</td>
<td>Clear TX_OVER Interrupt Register</td>
<td>Page: 477</td>
</tr>
<tr>
<td>0x50</td>
<td>IC_CLR_RD_REQ</td>
<td>0x0000_0000</td>
<td>Clear RD_REQ Interrupt Register</td>
<td>Page: 477</td>
</tr>
<tr>
<td>0x54</td>
<td>IC_CLR_TX_ABRT</td>
<td>0x0000_0000</td>
<td>Clear TX_ABRT Interrupt Register</td>
<td>Page: 477</td>
</tr>
<tr>
<td>0x58</td>
<td>IC_CLR_RX_DONE</td>
<td>0x0000_0000</td>
<td>Clear RX_DONE Interrupt Register</td>
<td>Page: 478</td>
</tr>
<tr>
<td>0x5C</td>
<td>IC_CLR_ACTIVITY</td>
<td>0x0000_0000</td>
<td>Clear ACTIVITY Interrupt Register</td>
<td>Page: 478</td>
</tr>
<tr>
<td>0x60</td>
<td>IC_CLR_STOP_DET</td>
<td>0x0000_0000</td>
<td>Clear STOP_DET Interrupt Register</td>
<td>Page: 479</td>
</tr>
</tbody>
</table>
24.7.2 I2C Registers

24.7.2.1 IC_CON Register

If configuration parameter I2C_DYNAMIC_TAR_UPDATE = 0, all bits are Read/Write. If I2C_DYNAMIC_TAR_UPDATE = 1, bit 4 is Read-only. This register can be written only when the I2C is disabled, which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CON</td>
<td>0x00</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
</tr>
<tr>
<td>------</td>
<td>----------------------------</td>
</tr>
<tr>
<td>31:7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 6    | ic_slave_disable          | R/W 0x1     | This bit controls whether I2C has its slave disabled, which means once the presen signal is applied, then this bit takes on the value of the configuration parameter IC_SLAVE_DISABLE. You have the choice of having the slave enabled or disabled after reset is applied, which means software does not have to configure the slave. By default, the slave is always enabled (in reset state as well). If you need to disable it after reset, set this bit to 1. If this bit is set (slave is disabled), I²C functions only as a master and does not perform any action that requires a slave.  
- Reset value: IC_SLAVE_DISABLE configuration parameter  
- Software should ensure that if this bit is written with 0, then bit 0 should also be written with a 0.  
0x0 = slave is enabled  
0x1 = slave is disabled |
| 5    | ic_restart_en             | R/W 0x1     | Determines whether RESTART conditions may be sent when acting as a master. Some older slaves do not support handling RESTART conditions; however, RESTART conditions are used in several I²C operations. When RESTART is disabled, the master is prohibited from performing the following functions:  
- Change direction within a transfer (split)  
- Send a START BYTE  
- High-speed mode operation  
- Combined format transfers in 7-bit addressing modes  
- Read operation with a 10-bit address  
- Send multiple bytes per transfer By replacing RESTART condition followed by a STOP and a subsequent START condition, split operations are broken down into multiple I²C transfers. If the above operations are performed, it will result in setting bit 6 (TX_ABRT) of the IC_RAW_INTR_STAT register.  
- Reset value: IC_RESTART_EN configuration parameter  
0x0 = disable  
0x1 = enable |
| 4    | ic_10bitaddr_master_rd_only | R 0x1      | If the I²C_DYNAMIC_TAR_UPDATE configuration parameter is set to 'No' (0), this bit is named IC_10BITADDR_MASTER and controls whether the I²C starts its transfers in 7- or 10-bit addressing mode when acting as a master. If I²C_DYNAMIC_TAR_UPDATE is set to 'Yes' (1), the function of this bit is handled by bit 12 of IC_TAR register, and becomes a read-only copy called IC_10BITADDR_MASTER_rd_only.  
- Dependencies: If I²C_DYNAMIC_TAR_UPDATE = 1, then this bit is read-only. If I²C_DYNAMIC_TAR_UPDATE = 0, then this bit can be read or write.  
- Reset value: IC_10BITADDR_MASTER configuration parameter  
0x0 = 7-bit addressing  
0x1 = 10-bit addressing |
24.7.2.2 IC_TAR Register

12 bits or 13 bits; 13 bits only when I2C_DYNAMIC_TAR_UPDATE = 1

If the configuration parameter I2C_DYNAMIC_TAR_UPDATE is set to 'No' (0), this register is 12 bits wide, and bits 15:12 are reserved. This register can be written to only when IC_ENABLE is set to 0. However, if I2C_DYNAMIC_TAR_UPDATE = 1, then the register becomes 13 bits wide. All bits can be dynamically updated as long as any set of the following conditions are true:

- I2C is NOT enabled (IC_ENABLE is set to 0); or
- I2C is enabled (IC_ENABLE=1); AND I2C is NOT engaged in any Master (tx, rx) operation (IC_STATUS[5]=0); AND I2C is enabled to operate in Master mode (IC_CON[0]=1); AND there are NO entries in the TX FIFO (IC_STATUS[2]=1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_TAR</td>
<td>0x04</td>
</tr>
</tbody>
</table>

Table 370: I2C Control Register (IC_CON) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>ic_10bitaddr_slave</td>
<td>R/W 0x1</td>
<td>When acting as a slave, this bit controls whether the I2C responds to 7- or 10-bit addresses. &lt;br&gt;• Reset value: IC_10BITADDR_SLAVE configuration parameter &lt;br&gt;0x0 = 7-bit addressing (I2C ignores transactions that involve 10-bit addressing; for 7-bit addressing, only the lower 7 bits of the IC_SAR register are compared) &lt;br&gt;0x1 = 10-bit addressing (I2C responds to only 10-bit addressing transfers that match the full 10 bits of the IC_SAR register)</td>
</tr>
<tr>
<td>2:1</td>
<td>speed</td>
<td>R/W 0x3</td>
<td>These bits control at which speed the I2C operates; its setting is relevant only if one is operating the I2C in master mode. Hardware protects against illegal values being programmed by software. This register should be programmed only with a value in the range of 1 to IC_MAX_SPEED_MODE; otherwise, hardware updates this register with the value of IC_MAX_SPEED_MODE. &lt;br&gt;• Reset value: IC_MAX_SPEED_MODE configuration &lt;br&gt;0x1 = standard mode (100 Kbps) &lt;br&gt;0x2 = fast mode (400 Kbps) &lt;br&gt;0x3 = high speed mode (3.4 Mbps)</td>
</tr>
<tr>
<td>0</td>
<td>master_mode</td>
<td>R/W 0x1</td>
<td>This bit controls whether the I2C master is enabled. &lt;br&gt;• Reset value: IC_MASTER_MODE configuration parameter &lt;br&gt;• Software should ensure that if this bit is written with 1 then bit 6 should also be written with a 1. &lt;br&gt;0x0 = master disabled &lt;br&gt;0x1 = master enabled</td>
</tr>
</tbody>
</table>
Table 371: I2C Target Address Register (IC_TAR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:13</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 12    | ic_10bitaddr_master    | R/W 0x1      | This bit controls whether the I2C starts its transfers in 7- or 10-bit addressing mode when acting as a master.  
|       |                        |              | • Dependencies: This bit exists in this register only if the I2C_DYNAMIC_TAR_UPDATE configuration parameter is set to “Yes” (1).  
|       |                        |              | • Reset value: IC_10BITADDR_MASTER configuration parameter  
|       |                        |              | 0x0 = 7-bit addressing  
|       |                        |              | 0x1 = 10-bit addressing  
| 11    | special                | R/W 0x0      | This bit indicates whether software performs a General Call or START BYTE command.  
|       |                        |              | 0x0 = ignore bit 10 GC_OR_START and use IC_TAR normally  
|       |                        |              | 0x1 = perform special I2C command as specified in GC_OR_START bit  
| 10    | gc_or_start            | R/W 0x0      | If bit 11 (SPECIAL) is set to 1, then this bit indicates whether a General Call or START byte command is to be performed by the I2C.  
|       |                        |              | 0x0 = general call address after issuing a general call, only writes may be performed. attempting to issue a read command results in setting bit 6 (TX_ABRT) of the IC_RAW_INTR_STAT register. the I2C remains in general call mode until the SPECIAL bit value (bit 11) is cleared.  
|       |                        |              | 0x1 = START BYTE  
| 9:0   | ic_tar                 | R/W 0x55     | This is the target address for any master transaction. When transmitting a General Call, these bits are ignored. To generate a START BYTE, the CPU needs to write only once into these bits.  
|       |                        |              | • Reset value: IC_DEFAULT_TAR_SLAVE_ADDR configuration parameter  
|       |                        |              | If the IC_TAR and IC_SAR are the same, loopback exists but the FIFOs are shared between master and slave, so full loopback is not feasible. Only one direction loopback mode is supported (simplex), not duplex. A master cannot transmit to itself; it can transmit to only a slave.  

24.7.2.3 IC_SAR Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_SAR</td>
<td>0x08</td>
</tr>
</tbody>
</table>
24.7.2.4  IC_HS_MADDR Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_HS_MADDR</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

Table 373: I2C High Speed Master Mode Code Address Register (IC_HS_MADDR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 2:0  | ic_hs_mar| R/W          | This bit field holds the value of the I2C HS mode master code. HS-mode master codes are reserved 8-bit codes (00001xxx) that are not used for slave addressing or other purposes. Each master has its unique master code; up to eight high-speed mode masters can be present on the same I2C bus system. Valid values are from 0 to 7. This register goes away and becomes read-only returning 0s if the IC_MAX_SPEED_MODE configuration parameter is set to either Standard (1) or Fast (2). This register can be written only when the I2C interface is disabled, which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. Note  
  • The default values cannot be any of the reserved address locations: that is, 0x00 to 0x07, or 0x78 to 0x7f. The correct operation of the device is not guaranteed if you program the IC_SAR or IC_TAR to a reserved value.  
  • Reset value: IC_HS_MASTER_CODE configuration parameter |
| 2:0  | ic_hs_mar| R/W 0x1      | This bit field holds the value of the I2C HS mode master code. HS-mode master codes are reserved 8-bit codes (00001xxx) that are not used for slave addressing or other purposes. Each master has its unique master code; up to eight high-speed mode masters can be present on the same I2C bus system. Valid values are from 0 to 7. This register goes away and becomes read-only returning 0s if the IC_MAX_SPEED_MODE configuration parameter is set to either Standard (1) or Fast (2). This register can be written only when the I2C interface is disabled, which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. Note  
  • The default values cannot be any of the reserved address locations: that is, 0x00 to 0x07, or 0x78 to 0x7f. The correct operation of the device is not guaranteed if you program the IC_SAR or IC_TAR to a reserved value.  
  • Reset value: IC_HS_MASTER_CODE configuration parameter |

24.7.2.5  IC_DATA_CMD Register

- This is the register the CPU writes to when filling the TX FIFO and the CPU reads from when retrieving bytes from RX FIFO.
- Size: 9 bits (writes) 8 bits (reads)
- With 9 bits required for writes, the \(^2\text{C}\) requires 16-bit data on the APB bus transfers when writing into the transmit FIFO. 8-bit transfers remain for reads from the receive FIFO.
### Table 374: I2C Rx/Tx Data Buffer and Command Register (IC_DATA_CMD)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:9</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>8</td>
<td>cmd</td>
<td>R/W 0x0</td>
<td>This bit controls whether a read or a write is performed. This bit does not control the direction when the I²C acts as a slave. It controls only the direction when it acts as a master. When a command is entered in the TX FIFO, this bit distinguishes the write and read commands. In slave-receiver mode, this bit is a ‘don’t care’ because writes to this register are not required. In slave-transmitter mode, a ‘0’ indicates that CPU data is to be transmitted and as DAT or IC_DATA_CMD[7:0]. When programming this bit, you should remember the following: attempting to perform a read operation after a General Call command has been sent results in a TX_ABRT interrupt (bit 6 of the IC_RAW_INTR_STAT register), unless bit 11 (SPECIAL) in the IC_TAR register has been cleared. If a 1 is written to this bit after receiving a RD_REQ interrupt, then a TX_ABRT interrupt occurs.</td>
</tr>
<tr>
<td>7:0</td>
<td>dat</td>
<td>R/W 0x0</td>
<td>This register contains the data to be transmitted or received on the I²C bus. If you are writing to this register and want to perform a read, bits 7:0 (DAT) are ignored by the I²C. However, when this register is read, these bits return the value of data received on the I²C interface.</td>
</tr>
</tbody>
</table>

### 24.7.2.6 IC_SS_SCL_HCNT Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_SS_SCL_HCNT</td>
<td>0x14</td>
</tr>
</tbody>
</table>

### Table 375: Name: Standard Speed I2C Clock SCL High Count Register (IC_SS_SCL_HCNT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 375: Name: Standard Speed I2C Clock SCL High Count Register (IC_SS_SCL_HCNT)  
(Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15:0</td>
<td>ic_ss_scl_hcnt</td>
<td>R/W 0xF4</td>
<td>This register must be set before any I2C bus transaction can take place to ensure proper I/O timing. This register sets the SCL clock high-period count for standard speed. The table below shows some sample IC_SS_SCL_HCNT calculations. These values apply only if the ic_clk is set to the given frequency in the table. This register can be written only when the I2C interface is disabled which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. The minimum valid value is 6; hardware prevents values less than this being written, and if attempted results in 6 being set. For designs with APB_DATA_WIDTH = 8, the order of programming is important to ensure the correct operation of the I2C. The lower byte must be programmed first. Then the upper byte is programmed. When the configuration parameter IC_HC_COUNT_VALUES is set to 1, this register is read only.</td>
</tr>
</tbody>
</table>

- This register must not be programmed to a value higher than 65525, because the I2C uses a 16-bit counter to flag an I2C bus idle condition when this counter reaches a value of IC_SS_SCL_HCNT + 10.  
- Reset value: IC_SS_SCL_HIGH_COUNT configuration parameter

24.7.2.7 IC_SS_SCL_LCNT Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_SS_SCL_LCNT</td>
<td>0x18</td>
</tr>
</tbody>
</table>

Table 376: Name: Standard Speed I2C Clock SCL Low Count Register (IC_SS_SCL_LCNT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.7.2.8 IC_FS_SCL_HCNT Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_FS_SCL_HCNT</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

Table 377: Name: Fast Speed I2C Clock SCL High Count Register (IC_FS_SCL_HCNT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
This register must be set before any I2C bus transaction can take place to ensure proper I/O timing. This register sets the SCL clock high-period count for fast speed. It is used in high-speed mode to send the Master Code and START BYTE or General CALL. The table below shows some sample IC_FS_SCL_HCNT calculations. These values apply only if the ic_clk is set to the given frequency in the table. This register goes away and becomes read-only returning 0s if IC_MAX_SPEED_MODE = standard. This register can be written only when the I2C interface is disabled, which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. The minimum valid value is 6; hardware prevents values less than this being written, and if attempted results in 6 being set. For designs with APB_DATA_WIDTH == 8 the order of programming is important to ensure the correct operation of the I2C. The lower byte must be programmed first. Then the upper byte is programmed. When the configuration parameter IC_HC_COUNT_VALUES is set to 1, this register is read only.

- Reset value: IC_FS_SCL_HIGH_COUNT configuration parameter

Table 377: Name: Fast Speed I2C Clock SCL High Count Register (IC_FS_SCL_HCNT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15:0</td>
<td>ic_fs_scl_hcnt</td>
<td>R/W 0x4B</td>
<td>This register must be set before any I2C bus transaction can take place to ensure proper I/O timing. This register sets the SCL clock high-period count for fast speed. It is used in high-speed mode to send the Master Code and START BYTE or General CALL. The table below shows some sample IC_FS_SCL_HCNT calculations. These values apply only if the ic_clk is set to the given frequency in the table. This register goes away and becomes read-only returning 0s if IC_MAX_SPEED_MODE = standard. This register can be written only when the I2C interface is disabled, which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. The minimum valid value is 6; hardware prevents values less than this being written, and if attempted results in 6 being set. For designs with APB_DATA_WIDTH == 8 the order of programming is important to ensure the correct operation of the I2C. The lower byte must be programmed first. Then the upper byte is programmed. When the configuration parameter IC_HC_COUNT_VALUES is set to 1, this register is read only.</td>
</tr>
</tbody>
</table>

24.7.2.9 IC_FS_SCL_LCNT Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_FS_SCL_LCNT</td>
<td>0x20</td>
</tr>
</tbody>
</table>

Table 378: Fast Speed I2C Clock SCL Low Count Register (IC_FS_SCL_LCNT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.7.2.10 IC_HS_SCL_HCNT Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_HS_SCL_HCNT</td>
<td>0x24</td>
</tr>
</tbody>
</table>

### Table 379: High Speed I2C Clock SCL High Count Register (IC_HS_SCL_HCNT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.7.2.11 IC_HS_SCL_LCNT Register

Table 380: High Speed I2C Clock SCL Low Count Register (IC_HS_SCL_LCNT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.7.2.12 IC_INTR_STAT Register

Each bit in this register has a corresponding mask bit in the IC_INTR_MASK register. These bits are cleared by reading the matching interrupt clear register. The unmasked raw versions of these bits are available in the IC_RAW_INTR_STAT register.

### Table 381: I2C Interrupt Status Register (IC_INTR_STAT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD -</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>r_gen_call</td>
<td>R 0x0</td>
<td>Set only when a General Call address is received and it is acknowledged. It stays set until it is cleared either by disabling the I²C or when the CPU reads bit 0 of the IC_CLR_GEN_CALL register. The I²C stores the received data in the Rx buffer.</td>
</tr>
<tr>
<td>10</td>
<td>r_start_det</td>
<td>R 0x0</td>
<td>Indicates whether a START or RESTART condition has occurred on the I2C interface regardless of whether I²C is operating in slave or master mode.</td>
</tr>
</tbody>
</table>
Table 381: I2C Interrupt Status Register (IC_INTR_STAT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>9</td>
<td>r_stop_det</td>
<td>R 0x0</td>
<td>Indicates whether a STOP condition has occurred on the I2C interface regardless of whether the I²C is operating in slave or master mode.</td>
</tr>
<tr>
<td>8</td>
<td>r_activity</td>
<td>R 0x0</td>
<td>This bit captures I²C activity and stays set until it is cleared. There are 4 ways to clear it:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Disabling the I²C</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Reading the IC_CLR_ACTIVITY register</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Reading the IC_CLR_INTR register</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• System reset</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Once this bit is set, it stays set unless one of the 4 methods is used to clear it. Even if the I²C module is idle, this bit remains set until cleared, indicating that there was activity on the bus.</td>
</tr>
<tr>
<td>7</td>
<td>r_rx_done</td>
<td>R 0x0</td>
<td>When the I²C is acting as a slave-transmitter, this bit is set to 1 if the master does not acknowledge a transmitted byte. This occurs on the last byte of the transmission, indicating that the transmission is done.</td>
</tr>
<tr>
<td>6</td>
<td>r_tx_abrt</td>
<td>R 0x0</td>
<td>This bit indicates if the I²C, as an I²C transmitter, is unable to complete the intended actions on the contents of the transmit FIFO. This situation can occur both as an I²C master or an I²C slave, and is referred to as a 'transmit abort'. When this bit is set to 1, the IC_TX_ABRT_SOURCE register indicates the reason why the transmit abort takes places.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• The I²C flushes/resets/empties the TX FIFO whenever this bit is set. The TX FIFO remains in this flushed state until the register IC_CLR_TX_ABRT is read. Once this read is performed, the TX FIFO is then ready to accept more data bytes from the APB interface.</td>
</tr>
<tr>
<td>5</td>
<td>r_rd_req</td>
<td>R 0x0</td>
<td>This bit is set to 1 when the I²C is acting as a slave and another I²C master is attempting to read data from I²C. The I²C holds the I²C bus in a wait state (SCL=0) until this interrupt is serviced, which means that the slave has been addressed by a remote master that is asking for data to be transferred. The processor must respond to this interrupt and then write the requested data to the IC_DATA_CMD register. This bit is set to 0 just after the processor reads the IC_CLR_RD_REQ register.</td>
</tr>
<tr>
<td>4</td>
<td>r_tx_empty</td>
<td>R 0x0</td>
<td>This bit is set to 1 when the transmit buffer is at or below the threshold value set in the IC_TX_TL register. It is automatically cleared by hardware when the buffer level goes above the threshold. When the IC_ENABLE bit 0 is 0, the TX FIFO is flushed and held in reset. Then the TX FIFO looks like it has no data within it, so this bit is set to 1, provided there is activity in the master or slave state machines. When there is no longer activity, then with ic_en=0, this bit is set to 0.</td>
</tr>
</tbody>
</table>
### 24.7.2.13 IC_INTR_MASK Register

These bits mask their corresponding interrupt status bits. They are active high; a value of 0 prevents a bit from generating an interrupt.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>m_gen_call</td>
<td>R/W 0x1</td>
<td>Set only when a General Call address is received and it is acknowledged. It stays set until it is cleared either by disabling I2C or when the CPU reads bit 0 of the IC_CLR_GEN_CALL register. I2C stores the received data in the Rx buffer.</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>----------------</td>
<td>-------------</td>
<td>-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>10</td>
<td>m_start_det</td>
<td>R/W 0x0</td>
<td>Indicates whether a START or RESTART condition has occurred on the I2C interface regardless of whether I²C is operating in slave or master mode.</td>
</tr>
<tr>
<td>9</td>
<td>m_stop_det</td>
<td>R/W 0x0</td>
<td>Indicates whether a STOP condition has occurred on the I2C interface regardless of whether I²C is operating in slave or master mode.</td>
</tr>
<tr>
<td>8</td>
<td>m_activity</td>
<td>R/W 0x0</td>
<td>This bit captures I²C activity and stays set until it is cleared. There are 4 ways to clear it:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Disabling the I²C</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Reading the IC_CLR_ACTIVITY register</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Reading the IC_CLR_INTR register</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• System reset</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Once this bit is set, it stays set unless one of the 4 methods is used to clear it. Even if the I²C module is idle, this bit remains set until cleared, indicating that there was activity on the bus.</td>
</tr>
<tr>
<td>7</td>
<td>m_rx_done</td>
<td>R/W 0x1</td>
<td>When the I²C is acting as a slave-transmitter, this bit is set to 1 if the master does not acknowledge a transmitted byte. This occurs on the last byte of the transmission, indicating that the transmission is done.</td>
</tr>
<tr>
<td>6</td>
<td>m_tx_abrt</td>
<td>R/W 0x1</td>
<td>This bit indicates if the I²C, as an I²C transmitter, is unable to complete the intended actions on the contents of the transmit FIFO. This situation can occur both as an I²C master or an I²C slave, and is referred to as a 'transmit abort'. When this bit is set to 1, the IC_TX_ABRT_SOURCE register indicates the reason why the transmit abort takes places.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• The I²C flushes/resets/empties the TX FIFO whenever this bit is set. The TX FIFO remains in this flushed state until the register IC_CLR_TX_ABRT is read. Once this read is performed, the TX FIFO is then ready to accept more data bytes from the APB interface.</td>
</tr>
<tr>
<td>5</td>
<td>m_rd_req</td>
<td>R/W 0x1</td>
<td>This bit is set to 1 when I²C is acting as a slave and another I²C master is attempting to read data from I²C. The I²C holds the I²C bus in a wait state (SCL=0) until this interrupt is serviced, which means that the slave has been addressed by a remote master that is asking for data to be transferred. The processor must respond to this interrupt and then write the requested data to the IC_DATA_CMD register. This bit is set to 0 just after the processor reads the IC_CLR_RD_REQ register.</td>
</tr>
<tr>
<td>4</td>
<td>m_tx_empty</td>
<td>R/W 0x1</td>
<td>This bit is set to 1 when the transmit buffer is at or below the threshold value set in the IC_TX_TL register. It is automatically cleared by hardware when the buffer level goes above the threshold. When the IC_ENABLE bit is 0, the TX FIFO is flushed and held in reset. There the TX FIFO looks like it has no data within it, so this bit is set to 1, provided there is activity in the master or slave state machines. When there is no longer activity, then with ic_en=0, this bit is set to 0.</td>
</tr>
</tbody>
</table>
**Table 382: I2C Interrupt Mask Register (IC_INTR_MASK) (Continued)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>m_tx_over</td>
<td>R/W 0x1</td>
<td>Set during transmit if the transmit buffer is filled to IC_TX_BUFFER_DEPTH and the processor attempts to issue another I2C command by writing to the IC_DATA_CMD register. When the module is disabled, this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared.</td>
</tr>
<tr>
<td>2</td>
<td>m_rx_full</td>
<td>R/W 0x1</td>
<td>Set when the receive buffer reaches or goes above the RX_TL threshold in the IC_RX_TL register. It is automatically cleared by hardware when buffer level goes below the threshold. If the module is disabled (IC_ENABLE[0]=0), the RX FIFO is flushed and held in reset; therefore the RX FIFO is not full. So this bit is cleared once the IC_ENABLE bit 0 is programmed with a 0, regardless of the activity that continues.</td>
</tr>
<tr>
<td>1</td>
<td>m_rx_over</td>
<td>R/W 0x1</td>
<td>Set if the receive buffer is completely filled to IC_RX_BUFFER_DEPTH and an additional byte is received from an external I2C device. The I2C acknowledges this, but any data bytes received after the FIFO is full are lost. If the module is disabled (IC_ENABLE[0]=0), this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared.</td>
</tr>
<tr>
<td>0</td>
<td>m_rx_under</td>
<td>R/W 0x1</td>
<td>Set if the processor attempts to read the receive buffer when it is empty by reading from the IC_DATA_CMD register. If the module is disabled (IC_ENABLE[0]=0), this bit keeps its level until the master or slave state machines go into idle, and when ic_en goes to 0, this interrupt is cleared.</td>
</tr>
</tbody>
</table>

**24.7.2.14 IC_RAW_INTR_STAT Register**

Unlike the IC_INTR_STAT register, these bits are not masked so they always show the true status of the I2C.

### Instance Name | Offset
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_RAW_INTR_STAT</td>
<td>0x34</td>
</tr>
</tbody>
</table>

**Table 383: I2C Raw Interrupt Status Register (IC_RAW_INTR_STAT)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>gen_call</td>
<td>R 0x0</td>
<td>Set only when a General Call address is received and it is acknowledged. It stays set until it is cleared either by disabling I2C or when the CPU reads bit 0 of the IC_CLR GEN_CALL register. I2C stores the received data in the Rx buffer.</td>
</tr>
</tbody>
</table>
### Table 383: I2C Raw Interrupt Status Register (IC_RAW_INTR_STAT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>start_det</td>
<td>R 0x0</td>
<td>Indicates whether a START or RESTART condition has occurred on the I2C interface regardless of whether I2C is operating in slave or master mode.</td>
</tr>
<tr>
<td>9</td>
<td>stop_det</td>
<td>R 0x0</td>
<td>Indicates whether a STOP condition has occurred on the I2C interface regardless of whether I2C is operating in slave or master mode.</td>
</tr>
</tbody>
</table>
| 8    | activity  | R 0x0        | This bit captures I2C activity and stays set until it is cleared. There are 4 ways to clear it:  
- Disabling the I2C  
- Reading the IC_CLR_ACTIVITY register  
- Reading the IC_CLR_INTR register  
- System reset  
   Once this bit is set, it stays set unless one of the 4 methods is used to clear it. Even if the I2C module is idle, this bit remains set until cleared, indicating that there was activity on the bus. |
| 7    | rx_done   | R 0x0        | When the I2C is acting as a slave-transmitter, this bit is set to 1 if the master does not acknowledge a transmitted byte. This occurs on the last byte of the transmission, indicating that the transmission is done. |
| 6    | tx_abrt   | R 0x0        | This bit indicates if I2C, as an I2C transmitter, is unable to complete the intended actions on the contents of the transmit FIFO. This situation can occur both as an I2C master or an I2C slave, and is referred to as a 'transmit abort'. When this bit is set to 1, the IC_TX_ABRT_SOURCE register indicates the reason why the transmit abort takes places.  
- The I2C flushes/resets/empties the TX FIFO whenever this bit is set. The TX FIFO remains in this flushed state until the register IC_CLR_TX_ABRT is read. Once this read is performed, the TX FIFO is then ready to accept more data bytes from the APB interface. |
| 5    | rd_req    | R 0x0        | This bit is set to 1 when I2C is acting as a slave and another I2C master is attempting to read data from I2C. The I2C holds the I2C bus in a wait state (SCL=0) until this interrupt is serviced, which means that the slave has been addressed by a remote master that is asking for data to be transferred. The processor must respond to this interrupt and then write the requested data to the IC_DATA_CMD register. This bit is set to 0 just after the processor reads the IC_CLR_RD_REQ register. |
| 4    | tx_empty  | R 0x0        | This bit is set to 1 when the transmit buffer is at or below the threshold value set in the IC_TX_TL register. It is automatically cleared by hardware when the buffer level goes above the threshold. When the IC_ENABLE bit is 0, the TX FIFO is flushed and held in reset. There the TX FIFO looks like it has no data within it, so this bit is set to 1, provided there is activity in the master or slave state machines. When there is no longer activity, then with ic_en=0, this bit is set to 0. |
### 24.7.2.15 IC_RX_TL Register

**Instance Name**
- IC_RX_TL

**Offset**
- 0x38

#### Table 384: I2C Receive FIFO Threshold Register (IC_RX_TL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.7.2.16 IC_TX_TL Register

Table 385: I2C Transmit FIFO Threshold Register (IC_TX_TL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:0</td>
<td>tx_tl</td>
<td>R/W 0x0</td>
<td>Transmit FIFO Threshold Level Controls the level of entries (or below) that trigger the TX_EMPTY interrupt (bit 4 in IC_RAW_INTR_STAT register). The valid range is 0-255, with the additional restriction that it may not be set to value larger than the depth of the buffer. If an attempt is made to do that, the actual value set will be the maximum depth of the buffer. A value of 0 sets the threshold for 0 entries, and a value of 255 sets the threshold for 255 entries.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_TX_TL</td>
<td>0x3C</td>
</tr>
</tbody>
</table>

24.7.2.17 IC_CLR_INTR Register

Table 386: Clear Combined and Individual Interrupt Register (IC_CLR_INTR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_INTR</td>
<td>0x40</td>
</tr>
</tbody>
</table>
24.7.2.18 IC_CLR_RX_UNDER Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_RX_UNDER</td>
<td>0x44</td>
</tr>
</tbody>
</table>

Table 387: Clear RX_UNDER Interrupt Register (IC_CLR_RX_UNDER)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_rx_under</td>
<td>R 0x0</td>
<td>Read this register to clear the RX_UNDER interrupt (bit 0) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>

24.7.2.19 IC_CLR_RX_OVER Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_RX_OVER</td>
<td>0x48</td>
</tr>
</tbody>
</table>

Table 388: Clear RX_OVER Interrupt Register (IC_CLR_RX_OVER)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_rx_over</td>
<td>R 0x0</td>
<td>Read this register to clear the RX_OVER interrupt (bit 1) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>
24.7.2.20 IC_CLR_TX_OVER Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_TX_OVER</td>
<td>0x4C</td>
</tr>
</tbody>
</table>

Table 389: Clear TX_OVER Interrupt Register (IC_CLR_TX_OVER)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_tx_over</td>
<td>R 0x0</td>
<td>Read this register to clear the TX_OVER interrupt (bit 3) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>

24.7.2.21 IC_CLR_RD_REQ Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_RD_REQ</td>
<td>0x50</td>
</tr>
</tbody>
</table>

Table 390: Clear RD_REQ Interrupt Register (IC_CLR_RD_REQ)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_rd_req</td>
<td>R 0x0</td>
<td>Read this register to clear the RD_REQ interrupt (bit 5) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>

24.7.2.22 IC_CLR_TX_ABRT Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_TX_ABRT</td>
<td>0x54</td>
</tr>
</tbody>
</table>

Table 391: Clear TX_ABRT Interrupt Register (IC_CLR_TX_ABRT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 391: Clear TX_ABRT Interrupt Register (IC_CLR_TX_ABRT) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>clr_tx_abrt</td>
<td>R 0x0</td>
<td>Read this register to clear the TX_ABRT interrupt (bit 6) of the IC_RAW_INTR_STAT register, and the IC_TX_ABRT_SOURCE register. This also releases the TX FIFO from the flushed/reset state, allowing more writes to the TX FIFO. Refer to Bit 9 of the IC_TX_ABRT_SOURCE register for an exception to clearing IC_TX_ABRT_SOURCE.</td>
</tr>
</tbody>
</table>

24.7.2.23 IC_CLR_RX_DONE Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_RX_DONE</td>
<td>0x58</td>
</tr>
</tbody>
</table>

Table 392: Clear RX_DONE Interrupt Register (IC_CLR_RX_DONE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_rx_done</td>
<td>R 0x0</td>
<td>Read this register to clear the RX_DONE interrupt (bit 7) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>

24.7.2.24 IC_CLR_ACTIVITY Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_ACTIVITY</td>
<td>0x5C</td>
</tr>
</tbody>
</table>

Table 393: Clear ACTIVITY Interrupt Register (IC_CLR_ACTIVITY)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_activity</td>
<td>R 0x0</td>
<td>Reading this register clears the ACTIVITY interrupt if the I2C is not active anymore. If the I2C module is still active on the bus, the ACTIVITY interrupt bit continues to be set. It is automatically cleared by hardware if the module is disabled and if there is no further activity on the bus. The value read from this register to get status of the ACTIVITY interrupt (bit 8) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>
24.7.2.25  **IC_CLR_STOP_DET Register**

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_STOP_DET</td>
<td>0x60</td>
</tr>
</tbody>
</table>

**Table 394: Clear STOP_DET Interrupt Register (IC_CLR_STOP_DET)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_stop_det</td>
<td>R 0x0</td>
<td>Read this register to clear the STOP_DET interrupt (bit 9) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>

24.7.2.26  **IC_CLR_START_DET Register**

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_START_DET</td>
<td>0x64</td>
</tr>
</tbody>
</table>

**Table 395: Clear START_DET Interrupt Register (IC_CLR_START_DET)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_start_det</td>
<td>R 0x0</td>
<td>Read this register to clear the START_DET interrupt (bit 10) of the IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>

24.7.2.27  **IC_CLR_GEN_CALL Register**

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_CLR_GEN_CALL</td>
<td>0x68</td>
</tr>
</tbody>
</table>

**Table 396: Clear GEN_CALL Interrupt Register (IC_CLR_GEN_CALL)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>clr_gen_call</td>
<td>R 0x0</td>
<td>Read this register to clear the GEN_CALL interrupt (bit 11) of IC_RAW_INTR_STAT register.</td>
</tr>
</tbody>
</table>
24.7.2.28 IC_ENABLE Register

Instance Name | Offset  
---|---
IC_ENABLE | 0x6C

Table 397: I2C Enable Register (IC_ENABLE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 0 | enable | R/W 0x0 | Controls whether the I²C is enabled. 
0x0 = disables I²C (TX and RX FIFOs are held in an erased state) 
0x1 = enables I²C software can disable I²C while it is active. 
however, it is important that care be taken to ensure that I²C is 
disabled properly. when I²C is disabled, the following occurs: 
• TX FIFO and RX FIFO get flushed. 
• Status bits in the IC_INTR_STAT register are still active until I²C goes into IDLE state. If the module is transmitting, it stops as well as deletes the contents of the transmit buffer after the current transfer is complete. If the module is receiving, the I²C stops the current transfer at the end of the current byte and does not acknowledge the transfer. In systems with asynchronous pclk and ic_clk when IC_CLK_TYPE parameter set to asynchronous (1), there is a 2 ic_clk delay when enabling or disabling the I²C. |

24.7.2.29 IC_STATUS Register

Table 398: I2C Status Register (IC_STATUS)

Instance Name | Offset  
---|---
IC_STATUS | 0x70

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 398: I2C Status Register (IC_STATUS) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 6    | slv_activity | R 0x0       | Slave FSM Activity Status  
When the Slave Finite State Machine (FSM) is not in the IDLE state, this bit is set.  
0x0 = slave FSM is in IDLE state so the slave part of I2C is not active  
0x1 = slave FSM is not in IDLE state so the slave part of I2C is active |
| 5    | mst_activity | R 0x0       | Master FSM Activity Status  
When the Master Finite State Machine (FSM) is not in the IDLE state, this bit is set.  
Note: IC_STATUS[0]-that is, ACTIVITY bit-is the OR of SLV_ACTIVITY and MST_ACTIVITY bits.  
0x0 = master FSM is in IDLE state so the master part of I2C is not active  
0x1 = master FSM is not in IDLE state so the master part of I2C is active note IC_STATUS[0]-that is, ACTIVITY bit-is the OR of SLV_ACTIVITY and MST_ACTIVITY bits |
| 4    | rff     | R 0x0       | Receive FIFO Completely Full  
When the receive FIFO is completely full, this bit is set. When the receive FIFO contains one or more empty location, this bit is cleared.  
0x0 = receive FIFO is not full  
0x1 = receive FIFO is full |
| 3    | rfne    | R 0x0       | Receive FIFO Not Empty  
This bit is set when the receive FIFO contains one or more entries; it is cleared when the receive FIFO is empty.  
0x0 = receive FIFO is empty  
0x1 = receive FIFO is not empty |
| 2    | tfe     | R 0x1       | Transmit FIFO Completely Empty  
When the transmit FIFO is completely empty, this bit is set. When it contains one or more valid entries, this bit is cleared. This bit field does not request an interrupt.  
0x0 = transmit FIFO is not empty  
0x1 = transmit FIFO is empty |
| 1    | tfnf    | R 0x1       | Transmit FIFO Not Full  
Set when the transmit FIFO contains one or more empty locations, and is cleared when the FIFO is full.  
0x0 = transmit FIFO is full  
0x1 = transmit FIFO is not full |
| 0    | activity | R 0x0       | I2C Activity Status |

24.7.2.30 IC_TXFLR Register

- Size: TX_ABW + 1
This register contains the number of valid data entries in the transmit FIFO buffer. It is cleared whenever:

- The I2C is disabled.
- There is a transmit abort that is, TX_ABRT bit is set in the IC_RAW_INTR_STAT register.
- The slave bulk transmit mode is aborted.

The register increments whenever data is placed into the transmit FIFO and decrements when data is taken from the transmit FIFO.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_TXFLR</td>
<td>0x74</td>
</tr>
</tbody>
</table>

### Table 399: I2C Transmit FIFO Level Register (IC_TXFLR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4:0</td>
<td>txflr</td>
<td>R 0x0</td>
<td>Transmit FIFO Level. Contains the number of valid data entries in the transmit FIFO.</td>
</tr>
</tbody>
</table>

#### 24.7.2.31 IC_RXFLR Register

- Size: RX_ABW + 1

This register contains the number of valid data entries in the receive FIFO buffer. It is cleared whenever:

- The I2C is disabled.
- Whenever there is a transmit abort caused by any of the events tracked in IC_TX_ABRT_SOURCE.

The register increments whenever data is placed into the receive FIFO and decrements when data is taken from the receive FIFO.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_RXFLR</td>
<td>0x78</td>
</tr>
</tbody>
</table>

### Table 400: I2C Receive FIFO Level Register (IC_RXFLR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4:0</td>
<td>rxfir</td>
<td>R 0x0</td>
<td>Receive FIFO Level. Contains the number of valid data entries in the receive FIFO.</td>
</tr>
</tbody>
</table>
24.7.2.32 IC_SDA_HOLD Register

This register controls the amount of time delay (in terms of number of ic_clk clock periods) introduced in the falling edge of SCL, relative to SDA changing, when I2C services a read request in a slave-transmitter operation. The relevant I2C requirement is tHd:DAT as detailed in the I2C Bus Specification.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_SDA_HOLD</td>
<td>0x7C</td>
</tr>
</tbody>
</table>

Table 401: I2C SDA Hold Register (IC_SDA_HOLD)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVDD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>ic_sda_hold</td>
<td>R/W 0x1</td>
<td>SDA Hold • Default Reset value: 0x1, but can be hard-coded by setting the IC_DEFAULT_SDA_HOLD configuration parameter.</td>
</tr>
</tbody>
</table>

24.7.2.33 IC_TX_ABRT_SOURCE Register

This register has 16 bits that indicate the source of the TX_ABRT bit. Except for Bit 9, this register is cleared whenever the IC_CLR_TX_ABRT register or the IC_CLR_INTR register is read. To clear Bit 9, the source of the ABRT_SBYTE_NORSTRT must be fixed first; RESTART must be enabled (IC_CON[5]=1), the bit must be cleared (IC_TAR[11]), or the GC_OR_START bit must be cleared (IC_TAR[10]). Once the source of the ABRT_SBYTE_NORSTRT is fixed, then this bit can be cleared in the same manner as other bits in this register. If the source of the ABRT_SBYTE_NORSTRT is not fixed before attempting to clear this bit, Bit 9 clears for one cycle and is then re-asserted.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_TX_ABRT_SOURCE</td>
<td>0x80</td>
</tr>
</tbody>
</table>

Table 402: I2C Transmit Abort Source Register (IC_TX_ABRT_SOURCE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVDD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>abrt_slvrd_intx</td>
<td>R 0x0</td>
<td>Slave-Transmitter • 0x1 = when the processor side responds to a slave mode request for data to be transmitted to a remote master and user writes a 1 in CMD (bit 8) of IC_DATA_CMD register</td>
</tr>
</tbody>
</table>
Table 402: I2C Transmit Abort Source Register (IC_TX_ABRT_SOURCE) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14</td>
<td>abrt_slv_arblost</td>
<td>R 0x0</td>
<td>Slave-Transmitter</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Even though the slave never ‘owns’ the bus, something could go wrong on the bus. This is a fail safe check. For instance, during a data transmission at the low-to-high transition of SCL, if what is on the data bus is not what is supposed to be transmitted, then I2C no longer own the bus. 0x1 = slave lost the bus while transmitting data to a remote master. IC_TX_ABRT_SOURCE[12] is set at the same time.</td>
</tr>
<tr>
<td>13</td>
<td>abrt_slvflush_txfifo</td>
<td>R 0x0</td>
<td>Slave-Transmitter</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = slave has received a read command and some data exists in the TX FIFO so the slave issues a TX_ABRT interrupt to flush old data in TX FIFO</td>
</tr>
<tr>
<td>12</td>
<td>arb_lost</td>
<td>R 0x0</td>
<td>Master-Transmitter or Slave-Transmitter</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• I2C can be both master and slave at the same time. 0x1 = master has lost arbitration, or if IC_TX_ABRT_SOURCE[14] is also set, then the slave transmitter has lost arbitration</td>
</tr>
<tr>
<td>11</td>
<td>abrt_master_dis</td>
<td>R 0x0</td>
<td>Master-Transmitter or Master-Receiver</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = user tries to initiate a master operation with the master mode disabled</td>
</tr>
<tr>
<td>10</td>
<td>abrt_10b_rd_norstrt</td>
<td>R 0x0</td>
<td>Master-Receiver</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = the restart is disabled (IC_RESTART_EN bit (IC_CON[5]) =0) and the master sends a read command in 10-bit addressing mode</td>
</tr>
<tr>
<td>9</td>
<td>abrt_sbyte_norstrt</td>
<td>R 0x0</td>
<td>Master</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>To clear Bit 9, the source of the ABRT_SBYTE_NORSTRT must be fixed first; restart must be enabled (IC_CON[5]=1), the SPECIAL bit must be cleared (IC_TAR[11]), or the GC_OR_START bit must be cleared (IC_TAR[10]). Once the source of the ABRT_SBYTE_NORSTRT is fixed, then this bit can be cleared in the same manner as other bits in this register. If the source of the ABRT_SBYTE_NORSTRT is not fixed before attempting to clear this bit, bit 9 clears for one cycle and then gets reasserted. 0x1 = the restart is disabled (IC_RESTART_EN bit (IC_CON[5]) =0) and the user is trying to send a START byte</td>
</tr>
<tr>
<td>8</td>
<td>abrt_hs_norstrt</td>
<td>R 0x0</td>
<td>Master-Transmitter or Master-Receiver</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = the restart is disabled (IC_RESTART_EN bit (IC_CON[5]) =0) and the user is trying to use the master to transfer data in high speed mode</td>
</tr>
<tr>
<td>7</td>
<td>abrt_sbyte_ackdet</td>
<td>R 0x0</td>
<td>Master</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = master has sent a START byte and the START byte was acknowledged (wrong behavior)</td>
</tr>
<tr>
<td>6</td>
<td>abrt_hs_ackdet</td>
<td>R 0x0</td>
<td>Master</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = master is in high speed mode and the high speed master code was acknowledged (wrong behavior)</td>
</tr>
</tbody>
</table>
24.7.2.34 **IC_SLV_DATA_NACK_ONLY Register**

The register is used to generate a NACK for the data part of a transfer when \(^2\)C is acting as a slave-receiver. This register only exists when the IC_SLV_DATA_NACK_ONLY parameter is set to 1. When this parameter disabled, this register does not exist and writing to the register's address has no effect.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_SLV_DATA_NACK_ONLY</td>
<td>0x84</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.7.2.35  **IC_DMA_CR Register**

This register is only valid when I²C is configured with a set of DMA Controller interface signals (IC_HAS_DMA = 1). When I²C is not configured for DMA operation, this register does not exist and writing to the register address has no effect and reading from this register address will return zero. The register is used to enable the DMA Controller interface operation. There is a separate bit for transmit and receive. This can be programmed regardless of the state of IC_ENABLE.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_DMA_CR</td>
<td>0x88</td>
</tr>
</tbody>
</table>

Table 404: DMA Control Register (IC_DMA_CR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 1    | tdmae | R/W 0x0 | Transmit DMA Enable  
|      |       |   | This bit enables/disables the transmit FIFO DMA channel.  
|      |       |   | 0x0 = transmit DMA disabled  
|      |       |   | 0x1 = transmit DMA enabled  |
| 0    | rdmae | R/W 0x0 | Receive DMA Enable  
|      |       |   | This bit enables/disables the receive FIFO DMA channel.  
|      |       |   | 0x0 = receive DMA disabled  
|      |       |   | 0x1 = receive DMA enabled  |

24.7.2.36  **IC_DMA_TDLR Register**

This register is only valid when I²C is configured with a set of DMA interface signals (IC_HAS_DMA = 1). When I²C is not configured for DMA operation, this register does not exist; writing to its address has no effect; reading from its address returns zero.
24.7.2.37 IC_DMA_RDLR Register

This register is only valid when \( i^2C \) is configured with a set of DMA interface signals (IC_HAS_DMA = 1). When \( i^2C \) is not configured for DMA operation, this register does not exist; writing to its address has no effect; reading from its address returns zero.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:0</td>
<td>dmardl</td>
<td>R/W 0x0</td>
<td>Receive Data Level This bit field controls the level at which a DMA request is made by the receive logic. The watermark level = DMARDL+1; that is, dma_rx_req is generated when the number of valid data entries in the receive FIFO is equal to or more than this field value + 1, and RDMAE =1. For instance, when DMARDL is 0, then dma_rx_req is asserted when 1 or more data entries are present in the receive FIFO.</td>
</tr>
</tbody>
</table>
24.7.2.39 IC_ACK_GENERAL_CALL Register

The register controls whether I^2^C responds with a ACK or NACK when it receives an I^2^C General Call address.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>ack_gen_call</td>
<td>R/W 0x1</td>
<td>ACK General Call</td>
</tr>
</tbody>
</table>

When set to 1, the I^2^C responds with a ACK (by asserting ic_data_oe) when it receives a General Call. Otherwise, the I^2^C responds with a NACK (by negating ic_data_oe).

• Default Reset value: 0x1, but can be hard-coded by setting the IC_DEFAULT_ACK_GENERAL_CALL configuration parameter.

24.7.2.40 IC_ENABLE_STATUS Register

The register is used to report the I^2^C hardware status when the IC_ENABLE register is set from 1 to 0; that is, when the I^2^C is disabled. If IC_ENABLE has been set to 1, bits [2:1] are forced to 0, and bit 0 is forced to 1. If IC_ENABLE has been set to 0, bits [2:1] is only be valid as soon as bit 0 is read as 0.

When IC_ENABLE has been written with 0 a delay occurs for bit 0 to be read as '0' because disabling the I^2^C depends on I^2^C bus activities.
### IC_ENABLE_STATUS

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 2    | slv_rx_data_lost    | R 0x0        | Slave Received Data Lost  
This bit indicates if a Slave-Receiver operation has been aborted with at least one data byte received from an I2C transfer due to the setting of IC_ENABLE from 1 to 0. When read as 1, the I^2^C is deemed to have been actively engaged in an aborted I2C transfer (with matching address) and the data phase of the I2C transfer has been entered, even though a data byte has been responded with a NACK.  
• If the remote I2C master terminates the transfer with a STOP condition before the I^2^C has a chance to NACK a transfer, and IC_ENABLE has been set to 0, then this bit is also set to 1. When read as 0, the I^2^C is deemed to have been disabled without being actively involved in the data phase of a Slave-Receiver transfer.  
• The CPU can safely read this bit when IC_EN (bit 0) is read as 0. |
| 1    | slv_disabled_while_busy | R 0x0     | Slave Disabled While Busy (Transmit, Receive)  
This bit indicates if a potential or active Slave operation has been aborted due to the setting of the IC_ENABLE register from 1 to 0. This bit is set when the CPU writes a 0 to the IC_ENABLE register while: (a) I^2^C is receiving the address byte of the Slave-Transmitter operation from a remote master; OR, (b) address and data bytes of the Slave-Receiver operation from a remote master. When read as 1, I^2^C is deemed to have forced a NACK during any part of an I2C transfer, irrespective of whether the I2C address matches the slave address set in I^2^C (IC_SAR register) OR if the transfer is completed before IC_ENABLE is set to 0 but has not taken effect.  
• If the remote I2C master terminates the transfer with a STOP condition before the I^2^C has a chance to NACK a transfer, and IC_ENABLE has been set to 0, then this bit will also be set to 1. When read as 0, I^2^C is deemed to have been disabled when there is master activity, or when the I2C bus is idle.  
• The CPU can safely read this bit when IC_EN (bit 0) is read as 0. |
| 0    | ic_en               | R 0x0        | ic_en Status  
This bit always reflects the value driven on the output port ic_en.  
When read as 1, I^2^C is deemed to be in an enabled state. When read as 0, I^2^C is deemed completely inactive.  
• The CPU can safely read this bit anytime. When this bit is read as 0, the CPU can safely read SLV_RX_DATA_LOST (bit 2) and SLV_DISABLED_WHILE_BUSY (bit 1). |
24.7.2.41 IC_FS_SPKLEN Register

This register is used to store the duration, measured in ic_clk cycles, of the longest spike that is filtered out by the spike suppression logic when the component is operating in SS or FS modes. The relevant I2C requirement is tSP (table 4) as detailed in the I2C Bus Specification. This register must be programmed with a minimum value of 2.

Table 410: I2C SS and FS Spike Suppression Limit Register (IC_FS_SPKLEN)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 7:0  | ic_fs_spklen | R/W 0x6    | This register must be set before any I2C bus transaction can take place to ensure stable operation. This register sets the duration, measured in ic_clk cycles, of the longest spike in the SCL or SDA lines that will be filtered out by the spike suppression logic. This register can be written only when the I2C interface is disabled which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. The minimum valid value is 2; hardware prevents values less than this being written, and if attempted results in 2 being set.  
• Default Reset value: IC_DEFAULT_FS_SPKLEN configuration parameter. |

24.7.2.42 IC_HS_SPKLEN Register

This register is used to store the duration, measured in ic_clk cycles, of the longest spike that is filtered out by the spike suppression logic when the component is operating in HS modes. The relevant I2C requirement is tSP (table 6) as detailed in the I2C Bus Specification. This register must be programmed with a minimum value of 2.

Table 411: I2C HS Spike Suppression Limit Register (IC_HS_SPKLEN)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
This is a constant read-only register that contains encoded information about the component's parameter settings. The reset value depends on coreConsultant parameter(s).

### Table 411: I2C HS Spike Suppression Limit Register (IC_HS_SPKLEN) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7:0</td>
<td>ic_hs_spklen</td>
<td>R/W 0x2</td>
<td>This register must be set before any I2C bus transaction can take place to ensure stable operation. This register sets the duration, measured in ic_clk cycles, of the longest spike in the SCL or SDA lines that will be filtered out by the spike suppression logic. This register can be written only when the I2C interface is disabled which corresponds to the IC_ENABLE register being set to 0. Writes at other times have no effect. The minimum valid value is 2; hardware prevents values less than this being written, and if attempted results in 2 being set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Default Reset value: IC_DEFAULT_HS_SPKLEN configuration parameter.</td>
</tr>
</tbody>
</table>

### 24.7.2.43 IC_COMP_PARAM_1 Register

This is a constant read-only register that contains encoded information about the component's parameter settings. The reset value depends on coreConsultant parameter(s).

#### Instance Name

| Offset | IC_COMP_PARAM_1 0xF4 |

#### Table 412: Component Parameter Register 1 (IC_COMP_PARAM_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>23:16</td>
<td>tx_buffer_depth</td>
<td>R 0xF</td>
<td>The value of this register is derived from the IC_TX_BUFFER_DEPTH coreConsultant parameter.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 3 to</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xFF = 256</td>
</tr>
<tr>
<td>15:8</td>
<td>rx_buffer_depth</td>
<td>R 0xF</td>
<td>The value of this register is derived from the IC_RX_BUFFER_DEPTH coreConsultant parameter.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 3 to</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xFF = 256</td>
</tr>
</tbody>
</table>
### 24.7.2.44 IC_COMP_VERSION Register

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>add_encoded_params</td>
<td>R 0x1</td>
<td>The value of this register is derived from the IC_ADD_ENCODED_PARAMS coreConsultant parameter. Reading 1 in this bit means that the capability of reading these encoded parameters with software has been included. Otherwise, the entire register is 0 regardless of the setting of any other parameters that are encoded in the bits. 0x0 = false 0x1 = true</td>
</tr>
<tr>
<td>6</td>
<td>has_dma</td>
<td>R 0x1</td>
<td>The value of this register is derived from the IC_HAS_DMA coreConsultant parameter 0x0 = false 0x1 = true</td>
</tr>
<tr>
<td>5</td>
<td>intr_io</td>
<td>R 0x1</td>
<td>The value of this register is derived from the IC_INTR_IO coreConsultant parameter 0x0 = individual 0x1 = combined</td>
</tr>
<tr>
<td>4</td>
<td>hc_count_values</td>
<td>R 0x0</td>
<td>The value of this register is derived from the IC_HC_COUNT VALUES coreConsultant parameter 0x0 = false 0x1 = true</td>
</tr>
<tr>
<td>3:2</td>
<td>max_speed_mode</td>
<td>R 0x3</td>
<td>The value of this register is derived from the IC_MAX_SPEED_MODE coreConsultant parameter. 0x0 = reserved 0x1 = standard 0x2 = fast 0x3 = high</td>
</tr>
<tr>
<td>1:0</td>
<td>apb_data_width</td>
<td>R 0x2</td>
<td>The value of this register is derived from the APB_DATA_WIDTH coreConsultant parameter. 0x0 = 8 bits 0x1 = 16 bits 0x2 = 32 bits 0x3 = reserved</td>
</tr>
</tbody>
</table>

---

**Table 412: Component Parameter Register 1 (IC_COMP_PARAM_1) (Continued)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>add_encoded_params</td>
<td>R 0x1</td>
<td>The value of this register is derived from the IC_ADD_ENCODED_PARAMS coreConsultant parameter. Reading 1 in this bit means that the capability of reading these encoded parameters with software has been included. Otherwise, the entire register is 0 regardless of the setting of any other parameters that are encoded in the bits. 0x0 = false 0x1 = true</td>
</tr>
<tr>
<td>6</td>
<td>has_dma</td>
<td>R 0x1</td>
<td>The value of this register is derived from the IC_HAS_DMA coreConsultant parameter 0x0 = false 0x1 = true</td>
</tr>
<tr>
<td>5</td>
<td>intr_io</td>
<td>R 0x1</td>
<td>The value of this register is derived from the IC_INTR_IO coreConsultant parameter 0x0 = individual 0x1 = combined</td>
</tr>
<tr>
<td>4</td>
<td>hc_count_values</td>
<td>R 0x0</td>
<td>The value of this register is derived from the IC_HC_COUNT VALUES coreConsultant parameter 0x0 = false 0x1 = true</td>
</tr>
<tr>
<td>3:2</td>
<td>max_speed_mode</td>
<td>R 0x3</td>
<td>The value of this register is derived from the IC_MAX_SPEED_MODE coreConsultant parameter. 0x0 = reserved 0x1 = standard 0x2 = fast 0x3 = high</td>
</tr>
<tr>
<td>1:0</td>
<td>apb_data_width</td>
<td>R 0x2</td>
<td>The value of this register is derived from the APB_DATA_WIDTH coreConsultant parameter. 0x0 = 8 bits 0x1 = 16 bits 0x2 = 32 bits 0x3 = reserved</td>
</tr>
</tbody>
</table>
### Table 413: I2C Component Version Register (IC_COMP_VERSION)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>ic_comp_version</td>
<td>R 0x3131_352A</td>
<td>Specific values for this register are described in the Releases Table in the I2C Release Notes.</td>
</tr>
</tbody>
</table>

### 24.7.2.45 IC_COMP_TYPE Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC_COMP_TYPE</td>
<td>0xFC</td>
</tr>
</tbody>
</table>

### Table 414: I2C Component Type Register (IC_COMP_TYPE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>ic_comp_type</td>
<td>R 0x4457_0140</td>
<td>Designware Component Type number = 0x44_57_01_40. This assigned unique hex value is constant and is derived from the 2 ASCII letters 'DW' followed by a 16-bit unsigned number.</td>
</tr>
</tbody>
</table>
24.8  QSPI Address Block

24.8.1  QSPI Register Map

Table 415: QSPI Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>Cntl</td>
<td>0x0000_0052</td>
<td>Serial Interface Control Register</td>
<td>Page: 494</td>
</tr>
<tr>
<td>0x04</td>
<td>Conf</td>
<td>0x0000_0002</td>
<td>Serial Interface Configuration Register</td>
<td>Page: 496</td>
</tr>
<tr>
<td>0x08</td>
<td>Dout</td>
<td>0x0000_0000</td>
<td>Serial Interface Data Out Register</td>
<td>Page: 498</td>
</tr>
<tr>
<td>0x0C</td>
<td>Din</td>
<td>0x0000_0000</td>
<td>Serial Interface Data Input Register</td>
<td>Page: 498</td>
</tr>
<tr>
<td>0x10</td>
<td>Instr</td>
<td>0x0000_0000</td>
<td>Serial Interface Instruction Register</td>
<td>Page: 499</td>
</tr>
<tr>
<td>0x14</td>
<td>Addr</td>
<td>0x0000_0000</td>
<td>Serial Interface Address Register</td>
<td>Page: 499</td>
</tr>
<tr>
<td>0x18</td>
<td>RdMode</td>
<td>0x0000_0000</td>
<td>Serial Interface Read Mode Register</td>
<td>Page: 500</td>
</tr>
<tr>
<td>0x1C</td>
<td>HdrCnt</td>
<td>0x0000_0000</td>
<td>Serial Interface Header Count Register</td>
<td>Page: 500</td>
</tr>
<tr>
<td>0x20</td>
<td>DlnCnt</td>
<td>0x0000_0000</td>
<td>Serial Interface Data Input Count Register</td>
<td>Page: 501</td>
</tr>
<tr>
<td>0x24</td>
<td>Timing</td>
<td>0x0000_0111</td>
<td>Serial Interface Timing Register</td>
<td>Page: 502</td>
</tr>
<tr>
<td>0x28</td>
<td>Conf2</td>
<td>0x0000_1100</td>
<td>Serial Interface Configuration 2 Register</td>
<td>Page: 502</td>
</tr>
<tr>
<td>0x2C</td>
<td>ISR</td>
<td>0x0000_0000</td>
<td>Serial Interface Interrupt Status Register</td>
<td>Page: 504</td>
</tr>
<tr>
<td>0x30</td>
<td>IMR</td>
<td>0x0000_0000</td>
<td>Serial Interface Interrupt Mask Register</td>
<td>Page: 505</td>
</tr>
<tr>
<td>0x34</td>
<td>IRSR</td>
<td>0x0000_005B</td>
<td>Serial Interface Interrupt Raw Status Register</td>
<td>Page: 506</td>
</tr>
<tr>
<td>0x38</td>
<td>ISC</td>
<td>0x0000_0000</td>
<td>Serial Interface Interrupt Clear Register</td>
<td>Page: 508</td>
</tr>
</tbody>
</table>

24.8.2  QSPI Registers

24.8.2.1  Serial Interface Control Register (Cntl)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cntl</td>
<td>0x00</td>
</tr>
</tbody>
</table>

Table 416: Serial Interface Control Register (Cntl)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>wfifo_overflw</td>
<td>R 0x0</td>
<td>Write FIFO Overflow</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO is not overflowed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO is overflowed</td>
</tr>
</tbody>
</table>
### Table 416: Serial Interface Control Register (Cntl) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>wfifo_undrflw</td>
<td>R 0x0</td>
<td>Write FIFO Underflow&lt;br&gt;0x0 = write FIFO is not underflowed&lt;br&gt;0x1 = write FIFO is underflowed</td>
</tr>
<tr>
<td>9</td>
<td>rfifo_ovrflw</td>
<td>R 0x0</td>
<td>Read FIFO Overflow&lt;br&gt;0x0 = read FIFO is not overflowed&lt;br&gt;0x1 = read FIFO is overflowed</td>
</tr>
<tr>
<td>8</td>
<td>rfifo_undrflw</td>
<td>R 0x0</td>
<td>Read FIFO Underflow&lt;br&gt;0x0 = read FIFO is not underflowed&lt;br&gt;0x1 = read FIFO is underflowed</td>
</tr>
<tr>
<td>7</td>
<td>wfifo_full</td>
<td>R 0x0</td>
<td>Write FIFO Full&lt;br&gt;0x0 = write FIFO is not full&lt;br&gt;0x1 = write FIFO is full</td>
</tr>
<tr>
<td>6</td>
<td>wfifo_empty</td>
<td>R 0x1</td>
<td>Write FIFO Empty&lt;br&gt;0x0 = write FIFO is not emptied&lt;br&gt;0x1 = write FIFO is emptied</td>
</tr>
<tr>
<td>5</td>
<td>rfifo_full</td>
<td>R 0x0</td>
<td>Read FIFO Full&lt;br&gt;0x0 = read FIFO is not filled&lt;br&gt;0x1 = read FIFO is full</td>
</tr>
<tr>
<td>4</td>
<td>rfifo_empty</td>
<td>R 0x1</td>
<td>Read FIFO Empty&lt;br&gt;0x0 = read FIFO is not emptied&lt;br&gt;0x1 = read FIFO is emptied</td>
</tr>
<tr>
<td>3:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>xfer_rdy</td>
<td>R 0x1</td>
<td>Serial Interface Transfer Ready&lt;br&gt;0x0 = serial interface is currently transferring data&lt;br&gt;0x1 = serial interface is ready for a new transfer</td>
</tr>
<tr>
<td>0</td>
<td>ss_en</td>
<td>R/W 0x0</td>
<td>Serial Select Enable&lt;br&gt;0x0 = serial select is de-activated, ss_n (serial interface select) output is driven high&lt;br&gt;0x1 = serial select is activated, ss_n (serial interface select) output is driven low</td>
</tr>
</tbody>
</table>

#### 24.8.2.2 Serial Interface Configuration Register (Conf)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Conf</td>
<td>0x04</td>
</tr>
</tbody>
</table>
### Table 417: Serial Interface Configuration Register (Conf)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>xfer_start</td>
<td>R/W 0x0</td>
<td>Transfer Start&lt;br&gt;This bit starts the serial interface I/O transfer.&lt;br&gt;For read transfers, RW_EN (R04[13]) = 0, the hardware resets this bit to 0 when the number of bytes indicated in DInCnt (R20h) register have been read in from the interface.&lt;br&gt;For write transfers, RW_EN (R04[13]) = 1, firmware sets XFER_STOP (R04h[14]) = 1 when all data have been written to the WFIFO and WFIFO_EMPTY (R00h[6]) = 1. Hardware resets this bit to 0 when all data have been written out the the interface.&lt;br&gt;0x0 = transfer has completed&lt;br&gt;0x1 = transfer has started</td>
</tr>
<tr>
<td>14</td>
<td>xfer_stop</td>
<td>R/W 0x0</td>
<td>Transfer Stop&lt;br&gt;This bit stops the serial interface I/O transfer.&lt;br&gt;The transfer stops at either a 1-byte or 4-byte boundary, depending on the setting of BYTE_LEN (R04h[5]). Once the byte boundary is reached, the hardware resets XFER_START (R04h[15]) to 0.&lt;br&gt;Hardware resets this bit to 0 after XFER_START has been reset.&lt;br&gt;0x0 = continue current transfer&lt;br&gt;0x1 = stop current transfer</td>
</tr>
<tr>
<td>13</td>
<td>rw_en</td>
<td>R/W 0x0</td>
<td>Read Write Enable&lt;br&gt;0x0 = read data from the serial interface&lt;br&gt;0x1 = write data to the serial interface</td>
</tr>
<tr>
<td>12</td>
<td>addr_pin</td>
<td>R/W 0x0</td>
<td>Address Transfer Pin&lt;br&gt;Number of pins used for transferring the content of the Addr (R14h) register.&lt;br&gt;0x0 = use one serial interface pin&lt;br&gt;0x1 = use the number of pins as indicated in DATA_PIN (R04h[11:10])</td>
</tr>
<tr>
<td>11:10</td>
<td>data_pin</td>
<td>R/W 0x0</td>
<td>Data Transfer Pin&lt;br&gt;Number of pins used for transferring the non-command and nonaddress portions of each serial interface I/O transfer.&lt;br&gt;0x0 = use 1 serial interface pin (use in single mode)&lt;br&gt;0x1 = use 2 serial interface pins (use in dual mode)&lt;br&gt;0x2 = use 4 serial interface pins (use in quad mode)&lt;br&gt;0x3 = reserved</td>
</tr>
<tr>
<td>9</td>
<td>fifo_flush</td>
<td>R/W 0x0</td>
<td>Flush Read and Write FIFOs&lt;br&gt;This bit flushes the Read and Write FIFOs. The FIFOs are emptied after being flushed. Hardware resets this bit to 0 after flushing.&lt;br&gt;0x0 = read and write FIFOs are not flushed&lt;br&gt;0x1 = read and write FIFOs are flushed</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/ HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>------------</td>
<td>--------------</td>
<td>-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
</tbody>
</table>
| 8    | clk_pol    | R/W 0x0      | Serial Interface Clock Polarity  
Selects the serial interface clock as high or low when inactive.  
0x0 = serial interface clock is low when inactive  
0x1 = serial interface clock is high when inactive |
| 7    | clk_pha    | R/W 0x0      | Serial Interface Clock Phase  
Selects the serial interface clock phase.  
0x0 = data is latched at the rising edge of the serial interface clock when CLK_POL (R04h [8]) = 0, and at the falling edge of the serial interface clock when CLK_POL = 1  
0x1 = data is latched at the falling edge of the serial interface clock when CLK_POL = 0, and at the rising edge of the serial interface clock when CLK_POL = 1 |
| 6    | Reserved   | RSVD --      | Reserved. Always write 0. Ignore read value.                                                                                                                                                           |
| 5    | byte_len   | R/W 0x0      | Byte Length  
The number of bytes in each serial interface I/O transfer.  
0x0 = 1 byte  
0x1 = 4 bytes |
| 4:0  | clk_prescale | R/W 0x2      | Serial Interface Clock Prescaler (from SPI clock)  
0x00 = SPI clock/1  
0x01 = SPI clock/1  
0x02 = SPI clock/2  
0x03 = SPI clock/3  
0x04 = SPI clock/4  
0x05 = SPI clock/5  
...  
0x0D = SPI clock/13  
0x0E = SPI clock/14  
0x0F = SPI clock/15  
0x10 = SPI clock/2  
0x11 = SPI clock/2  
0x12 = SPI clock/4  
0x13 = SPI clock/6  
0x14 = SPI clock/8  
0x15 = SPI clock/10  
...  
0x1D = SPI clock/26  
0x1E = SPI clock/28  
0x1F = SPI clock/30 |
24.8.2.3 Serial Interface Data Out Register (Dout)

Table 418: Serial Interface Data Out Register (Dout)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data_out</td>
<td>R/W 0x0</td>
<td>Serial Interface Data Out&lt;br&gt;Writing to this register stores the data in a 8X32 bit Write FIFO. After the contents of the Instruction register (R10h), the Address register (R14h), the Read Mode register (R18h) and Dummy value are transferred out to the the serial interface, the data in the Write FIFO is shifted out. The serial interface clock stops when a Write FIFO empty condition occurs, WFIFO_EMPTY (R00h [6]) = 1. The clock restarts when Write FIFO is not empty, WFIFO_EMPTY (R00h [6]) = 0. When BYTE_LEN (R04h [5]) = 0, bits [7:0] are shifted out with bit 7 shifted out first and bit 0 shifted out last. When BYTE_LEN (R04h [5]) = 1, bits [7:0] are shifted out (bit 7 shifted out first and bit 0 shifted out last), followed by bits [15:8] (bit 15 shifted out first and bit 8 shifted out last), then bits [23:16] (bit 23 shifted out first and bit 16 shifted out last) and finally bits [31:24] (bit 31 shifted out first and bit 24 shifted out last). To avoid a Write FIFO overflow condition (WFIFO_OVRFLW (R00h [11]) = 1), check WFIFO_FULL (R00h [7]) is equal to 0 before writing to this register.</td>
</tr>
</tbody>
</table>

24.8.2.4 Serial Interface Data Input Register (Din)

Table 419: Serial Interface Data Input Register (Din)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data_in</td>
<td>R 0x0</td>
<td>Serial Interface Data In&lt;br&gt;For read transfers, RW_EN (R04h [13]) = 0, data from the serial interface input pins are shifted in and stores in a 8X32 bit Read FIFO. The contents of the Read FIFO is read from this register. The serial interface clock stops when a Read FIFO full condition occurs, RFIFO_FULL (R00h [5]) = 1. The clock restarts when Read FIFO is not full, RFIFO_FULL (R00h [5]) = 0. When BYTE_LEN (R04h [5]) = 0, data is shifted into bits [7:0]. When BYTE_LEN (R04h [5]) = 1, data is shifted into bits [7:0] first, followed by bits [15:8], then bits [23:16] and finally bits [31:24]. To avoid a Read FIFO underflow condition, RFIFO_UNDRFLW (R00h [8]) = 1, check RFIFO_EMPTY (R00h [4]) is equal to 0 before reading this register.</td>
</tr>
</tbody>
</table>
24.8.2.5 Serial Interface Instruction Register (Instr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Instr</td>
<td>0x10</td>
</tr>
</tbody>
</table>

Table 420: Serial Interface Instruction Register (Instr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>instr</td>
<td>R/W 0x0</td>
<td>Instruction After XFER_START (R04h [15]) is set to 1, the content of this register is shifted out to the serial interface. When INSTR_CNT (R1Ch [1:0]) = 0, the content of this register is not shifted out to the serial interface. When INSTR_CNT (R1Ch [1:0]) = 1, bits [7:0] are shifted out. When INSTR_CNT (R1Ch [1:0]) = 2, bits [15:8] are shifted out first, followed by bits [7:0].</td>
</tr>
</tbody>
</table>

24.8.2.6 Serial Interface Address Register (Addr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Addr</td>
<td>0x14</td>
</tr>
</tbody>
</table>

Table 421: Serial Interface Address Register (Addr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>addr</td>
<td>R/W 0x0</td>
<td>Serial Interface Address After Instr (R10h) is shifted out, the content of this register is shifted out to the serial interface. When ADDR_CNT (R1Ch [6:4]) = 0, the content of this register is not shifted out to the serial interface. When ADDR_CNT (R1Ch [6:4]) = 1, bits [7:0] are shifted out. When ADDR_CNT (R1Ch [6:4]) = 2, bits [15:8] are shifted out first, followed by bits [7:0]. When ADDR_CNT (R1Ch [6:4]) = 3, bits [23:16] are shifted out first, followed by bits [15:8], then bits [7:0]. When ADDR_CNT (R1Ch [6:4]) = 4, bits [31:24] are shifted out first, followed by bits [23:16], then bits [15:8] and finally bits [7:0].</td>
</tr>
</tbody>
</table>

24.8.2.7 Serial Interface Read Mode Register (RdMode)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RdMode</td>
<td>0x18</td>
</tr>
</tbody>
</table>
Table 422: Serial Interface Read Mode Register (RdMode)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>rmode</td>
<td>R/W 0x0</td>
<td>Serial Interface Read Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>After Addr (R14h) is shifted out, the content of this register is shifted</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>out to the serial interface.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>When RM_CNT (R1Ch [9:8]) = 0, the content of this register is not</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>shifted out to the serial interface.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>When RM_CNT (R1Ch [9:8]) = 1, bits [7:0] are shifted out.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>When RM_CNT (R1Ch [9:8]) = 2, bits [15:8] are shifted out first,</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>followed by bits [7:0].</td>
</tr>
</tbody>
</table>

24.8.2.8 Serial Interface Header Count Register (HdrCnt)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HdrCnt</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

Table 423: Serial Interface Header Count Register (HdrCnt)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:14</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>13:12</td>
<td>dummy_cnt</td>
<td>R/W 0x0</td>
<td>Dummy Count</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Number of bytes to shift out to the serial interface after the content of</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>RdMode (R18h) register is shifted out.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The value being shifted out is 0.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 0 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 1 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 2 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 3 bytes</td>
</tr>
<tr>
<td>11:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9:8</td>
<td>rm_cnt</td>
<td>R/W 0x0</td>
<td>Read Mode Count</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Number of bytes in RdMode (R18h) register to shift out to the serial</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>interface.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 0 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 1 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 2 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 423: Serial Interface Header Count Register (HdrCnt) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6:4</td>
<td>addr_cnt</td>
<td>R/W 0x0</td>
<td>Address Count</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Number of bytes in Addr (R14h) register to shift out to the serial interface.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 0 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 1 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 2 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 3 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = 4 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
<tr>
<td>3:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1:0</td>
<td>instr_cnt</td>
<td>R/W 0x0</td>
<td>Instruction Count</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Number of bytes in Instr (R10h) register to shift out to the serial interface.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 0 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 1 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 2 bytes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = reserved</td>
</tr>
</tbody>
</table>

24.8.2.9  Serial Interface Data Input Count Register (DInCnt)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DInCnt</td>
<td>0x20</td>
</tr>
</tbody>
</table>

Table 424: Serial Interface Data Input Count Register (DInCnt)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:20</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>19:0</td>
<td>data_in_cnt</td>
<td>R/W 0x0</td>
<td>Serial Interface Data In Count</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>For read transfers, RW_EN (R04h [13]) = 0, this register indicates the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>number of bytes of data to shift in from the serial interface and stores</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>in the 8X32 bit Read FIFO. When this register is set to 0, data is shifted</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>in continuously until XFER_STOP (R04h [14]) bit is set to 1 by firmware.</td>
</tr>
</tbody>
</table>
24.8.2.10  Serial Interface Timing Register (Timing)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Timing</td>
<td>0x24</td>
</tr>
</tbody>
</table>

Table 425: Serial Interface Timing Register (Timing)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6</td>
<td>clk_capt_edge</td>
<td>R/W 0x0</td>
<td>Serial Interface Capture Clock Edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Capture serial interface input data on either the rising or falling edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>of the serial interface clock. This bit is used to allow more time to</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>capture the input data.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 =</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 0, capture input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>data on rising edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 1, capture input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>data on falling edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 1 and CLK_PHA (R04 [7]) = 0, capture input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>data on falling edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 1 and CLK_PHA (R04 [7]) = 1, capture input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>data on rising edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 =</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 0, capture input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>data on falling edge of the serial interface clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• When CLK_POL (R04 [8]) = 0 and CLK_PHA (R04 [7]) = 1, capture input</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>data on rising edge of the serial interface clock</td>
</tr>
<tr>
<td>5:0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

24.8.2.11  Serial Interface Configuration 2 Register (Conf2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Conf2</td>
<td>0x28</td>
</tr>
</tbody>
</table>

Table 426: Serial Interface Configuration 2 Register (Conf2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:14</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.8.2.12 Serial Interface Interrupt Status Register (ISR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISR</td>
<td>0x2C</td>
</tr>
</tbody>
</table>
Table 427: Serial Interface Interrupt Status Register (ISR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 11     | wfifo_ovrflw_is   | R 0x0        | Write FIFO Overflow Interrupt Status  
0x0 = write FIFO is not overflowed after masking  
0x1 = write FIFO is overflowed after masking                                                                 |
| 10     | wfifo_undrflw_is  | R 0x0        | Write FIFO Underflow Interrupt Status  
0x0 = write FIFO is not underflowed after masking  
0x1 = write FIFO is underflowed after masking                                                                 |
| 9      | rfifo_ovrflw_is   | R 0x0        | Read FIFO Overflow Interrupt Status  
0x0 = read FIFO is not overflowed after masking  
0x1 = read FIFO is overflowed after masking                                                                 |
| 8      | rfifo_undrflw_is  | R 0x0        | Read FIFO Underflow Interrupt Status  
0x0 = read FIFO is not underflowed after masking  
0x1 = read FIFO is underflowed after masking                                                                 |
| 7      | wfifo_full_is     | R 0x0        | Write FIFO Full Interrupt Status  
0x0 = write FIFO is not full after masking  
0x1 = write FIFO is full after masking                                                                 |
| 6      | wfifo_empty_is    | R 0x0        | Write FIFO Empty Interrupt Status  
0x0 = write FIFO is not empty after masking  
0x1 = write FIFO is empty after masking                                                                 |
| 5      | rfifo_full_is     | R 0x0        | Read FIFO Full Interrupt Status  
0x0 = read FIFO is not full after masking  
0x1 = read FIFO is full after masking                                                                 |
| 4      | rfifo_empty_is    | R 0x0        | Read FIFO Empty Interrupt Status  
0x0 = read FIFO is not empty after masking  
0x1 = read FIFO is empty after masking                                                                 |
| 3      | wfifo_dma_burst_is| R 0x0        | Write FIFO DMA Burst Interrupt Status  
0x0 = number of unused entries in the write FIFO is less than DMA_WR_BURST (R28h [13:12]) after masking  
0x1 = number of unused entries in the write FIFO is greater than or equal to DMA_WR_BURST (R28h [13:12]) after masking |
| 2      | rfifo_dma_burst_is| R 0x0        | Read FIFO DMA Burst Interrupt Status  
0x0 = number of available data in the read FIFO is less than DMA_RD_BURST (R28h [9:8]) after masking  
0x1 = number of available data in the read FIFO is greater than or equal to DMA_RD_BURST (R28h [9:8]) after masking |
| 1      | xfer_rdy_is       | R 0x0        | Serial Interface Transfer Ready Interrupt Status  
0x0 = serial interface is currently transferring data after masking  
0x1 = serial interface is ready for a new transfer after masking |


Table 427: Serial Interface Interrupt Status Register (ISR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>xfer_done_is</td>
<td>R 0x0</td>
<td>Transfer Done Interrupt Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer has not completed after masking</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer has completed after masking</td>
</tr>
</tbody>
</table>

24.8.2.13 Serial Interface Interrupt Mask Register (IMR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMR</td>
<td>0x30</td>
</tr>
</tbody>
</table>

Table 428: Serial Interface Interrupt Mask Register (IMR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>wfifo_ovrlf_im</td>
<td>R 0x1</td>
<td>Write FIFO Overflow Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO overflow interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO overflow interrupt is masked</td>
</tr>
<tr>
<td>10</td>
<td>wfifo_underlf_im</td>
<td>R 0x1</td>
<td>Write FIFO Underflow Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO underflow interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO underflow interrupt is masked</td>
</tr>
<tr>
<td>9</td>
<td>rfifo_ovrlf_im</td>
<td>R 0x1</td>
<td>Read FIFO Overflow Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = read FIFO overflow interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = read FIFO overflow interrupt is masked</td>
</tr>
<tr>
<td>8</td>
<td>rfifo_underlf_im</td>
<td>R 0x1</td>
<td>Read FIFO Underflow Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = read FIFO underflow interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = read FIFO underflow interrupt is masked</td>
</tr>
<tr>
<td>7</td>
<td>wfifo_full_im</td>
<td>R 0x1</td>
<td>Write FIFO Full Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO full interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO full interrupt is masked</td>
</tr>
<tr>
<td>6</td>
<td>wfifo_empty_im</td>
<td>R 0x1</td>
<td>Write FIFO Empty Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO empty interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO empty interrupt is masked</td>
</tr>
<tr>
<td>5</td>
<td>rfifo_full_im</td>
<td>R 0x1</td>
<td>Read FIFO Full Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = read FIFO full interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = read FIFO full interrupt is masked</td>
</tr>
</tbody>
</table>
Table 428: Serial Interface Interrupt Mask Register (IMR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>rfifo_empty_im</td>
<td>R 0x1</td>
<td>Read FIFO Empty Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = read FIFO empty interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = read FIFO empty interrupt is masked</td>
</tr>
<tr>
<td>3</td>
<td>wfifo_dma_burst_im</td>
<td>R 0x1</td>
<td>Write FIFO DMA Burst Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO DMA burst interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO DMA burst interrupt is masked</td>
</tr>
<tr>
<td>2</td>
<td>rfifo_dma_burst_im</td>
<td>R 0x1</td>
<td>Read FIFO DMA Burst Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = read FIFO DMA burst interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = read FIFO DMA burst interrupt is masked</td>
</tr>
<tr>
<td>1</td>
<td>xfer_rdy_im</td>
<td>R 0x1</td>
<td>Serial Interface Transfer Ready Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer ready interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer ready interrupt is masked</td>
</tr>
<tr>
<td>0</td>
<td>xfer_done_im</td>
<td>R 0x1</td>
<td>Transfer Done Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer done interrupt is not masked</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer done interrupt is masked</td>
</tr>
</tbody>
</table>

24.8.2.14 Serial Interface Interrupt Raw Status Register (IRSR)

Table 429: Serial Interface Interrupt Raw Status Register (IRSR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IRSR</td>
<td>0x34</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>wfifo_ovrfw_ir</td>
<td>R 0x0</td>
<td>Write FIFO Overflow Interrupt Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO is not overflowed before masking</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO is overflowed before masking</td>
</tr>
<tr>
<td>10</td>
<td>wfifo_undrfw_ir</td>
<td>R 0x0</td>
<td>Write FIFO Underflow Interrupt Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = write FIFO is not underflowed before masking</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = write FIFO is underflowed before masking</td>
</tr>
<tr>
<td>9</td>
<td>rfifo_ovrfw_ir</td>
<td>R 0x0</td>
<td>Read FIFO Overflow Interrupt Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = read FIFO is not overflowed before masking</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = read FIFO is overflowed before masking</td>
</tr>
</tbody>
</table>
## 24.8.2.15 Serial Interface Interrupt Clear Register (ISC)

### Table 429: Serial Interface Interrupt Raw Status Register (IRSR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>rfifo_undrftw_ir</td>
<td>R 0x0</td>
<td>Read FIFO Underflow Interrupt Raw&lt;br&gt;0x0 = read FIFO is not underflowed before masking&lt;br&gt;0x1 = read FIFO is underflowed before masking</td>
</tr>
<tr>
<td>7</td>
<td>wfifo_full_ir</td>
<td>R 0x0</td>
<td>Write FIFO Full Interrupt Raw&lt;br&gt;0x0 = write FIFO is not fulled before masking&lt;br&gt;0x1 = write FIFO is fulled before masking</td>
</tr>
<tr>
<td>6</td>
<td>wfifo_empty_ir</td>
<td>R 0x1</td>
<td>Write FIFO Empty Interrupt Raw&lt;br&gt;0x0 = write FIFO is not emptied before masking&lt;br&gt;0x1 = write FIFO is emptied before masking</td>
</tr>
<tr>
<td>5</td>
<td>rfifo_full_ir</td>
<td>R 0x0</td>
<td>Read FIFO Full Interrupt Raw&lt;br&gt;0x0 = read FIFO is not fulled before masking&lt;br&gt;0x1 = read FIFO is fulled before masking</td>
</tr>
<tr>
<td>4</td>
<td>rfifo_empty_ir</td>
<td>R 0x1</td>
<td>Read FIFO Empty Interrupt Raw&lt;br&gt;0x0 = read FIFO is not emptied before masking&lt;br&gt;0x1 = read FIFO is empty before masking</td>
</tr>
<tr>
<td>3</td>
<td>wfifo_dma_burst_ir</td>
<td>R 0x1</td>
<td>Write FIFO DMA Burst Interrupt Raw&lt;br&gt;0x0 = number of unused entries in the write FIFO is less than DMA_WR_BURST (R28h [13:12]) before masking&lt;br&gt;0x1 = number of unused entries in the write FIFO is greater than or equal to DMA_WR_BURST (R28h [13:12]) before masking</td>
</tr>
<tr>
<td>2</td>
<td>rfifo_dma_burst_ir</td>
<td>R 0x0</td>
<td>Read FIFO DMA Burst Interrupt Raw&lt;br&gt;0x0 = number of available data in the read FIFO is less than DMA_RD_BURST (R28h [9:8]) before masking&lt;br&gt;0x1 = number of available data in the read FIFO is greater than or equal to DMA_RD_BURST (R28h [9:8]) before masking</td>
</tr>
<tr>
<td>1</td>
<td>xfer_rdy_ir</td>
<td>R 0x1</td>
<td>Serial Interface Transfer Ready Raw&lt;br&gt;0x0 = serial interface is currently transferring data before masking&lt;br&gt;0x1 = serial interface is ready for a new transfer before masking</td>
</tr>
<tr>
<td>0</td>
<td>xfer_done_ir</td>
<td>R 0x1</td>
<td>Transfer Done Interrupt Raw&lt;br&gt;0x0 = transfer has not completed before masking&lt;br&gt;0x1 = transfer has completed before masking</td>
</tr>
</tbody>
</table>

**Instance Name**

<table>
<thead>
<tr>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISC</td>
</tr>
</tbody>
</table>
Table 430: Serial Interface Interrupt Clear Register (ISC)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>xfer_done_ic</td>
<td>W 0x0</td>
<td>Transfer Done Interrupt Clear</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = transfer done interrupt is not cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = transfer done interrupt is cleared</td>
</tr>
</tbody>
</table>
24.9  SSP Address Block

24.9.1  SSP Register Map

Table 431: SSP Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>SSCR0</td>
<td>0x0000_0000</td>
<td>SSP Control Register 0</td>
<td>Page: 509</td>
</tr>
<tr>
<td>0x04</td>
<td>SSCR1</td>
<td>0x0000_0000</td>
<td>SSP Control Register 1</td>
<td>Page: 511</td>
</tr>
<tr>
<td>0x08</td>
<td>SSSR</td>
<td>0x0000_F004</td>
<td>SSP Status Register</td>
<td>Page: 514</td>
</tr>
<tr>
<td>0x0C</td>
<td>SSITR</td>
<td>0x0000_0000</td>
<td>SSP Interrupt Test Register</td>
<td>Page: 516</td>
</tr>
<tr>
<td>0x10</td>
<td>SSDR</td>
<td>0x0000_0000</td>
<td>SSP Data Register</td>
<td>Page: 517</td>
</tr>
<tr>
<td>0x28</td>
<td>Reserved</td>
<td>0x0000_0000</td>
<td>Reserved --</td>
<td></td>
</tr>
<tr>
<td>0x2C</td>
<td>SSPSP</td>
<td>0x0000_0000</td>
<td>SSP Programmable Serial Protocol Register</td>
<td>Page: 517</td>
</tr>
<tr>
<td>0x30</td>
<td>SSTSA</td>
<td>0x0000_0000</td>
<td>SSP TX Time Slot Active Register</td>
<td>Page: 519</td>
</tr>
<tr>
<td>0x34</td>
<td>SSRSA</td>
<td>0x0000_0000</td>
<td>SSP RX Time Slot Active Register</td>
<td>Page: 519</td>
</tr>
<tr>
<td>0x38</td>
<td>SSTSS</td>
<td>0x0000_0000</td>
<td>SSP Time Slot Status Register</td>
<td>Page: 520</td>
</tr>
</tbody>
</table>

24.9.2  SSP Registers

24.9.2.1  SSP Control Register 0 (SSCR0)

The SSP Control 0 registers contain 13 different bit fields that control various functions within the SSP port. The following table shows the bit locations corresponding to the different control bit fields within the SSP Control 0 Register. The reset state of all bits are as shown, but they must be programmed to their preferred values before enabling the SSP port.

 Writes to reserved bits must be 0b0, and read values of reserved bits are undefined.

Table 432: SSP Control Register 0 (SSCR0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31   | mod   | R/W 0x0      | Mode 
0x0 = normal SSP mode 
0x1 = network mode |
| 30   | Reserved | R/W 0x0      | Reserved. Do not change the reset value.         |
### Table 432: SSP Control Register 0 (SSCR0) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 29   | fpcke | R/W 0x0     | FIFO Packing Enable  
|      |       |             | 0x0 = FIFO packing mode disabled  
|      |       |             | 0x1 = FIFO packing mode enabled  |
| 28   | rhcd  | R/W 0x0     | RX Half Cycle Delay  
|      |       |             | 0x0 = not select RX half cycle delay  
|      |       |             | 0x1 = receive data delay half cycle  |
| 27   | mcrt  | R/W 0x0     | Master Clock Return  
|      |       |             | 0x0 = not select master return_clock  
|      |       |             | 0x1 = master clock delay  |
| 26:24| frdc  | R/W 0x0     | Frame Rate Divider Control  
|      |       |             | Value of 0x0-0x7 specifies the number of time slots per frame when  
|      |       |             | in network mode (the actual number of time slots is this field +1, so 1  
|      |       |             | to 8 time slots can be specified).  |
| 23   | tim   | R/W 0x0     | Transmit FIFO Underrun Interrupt Mask  
|      |       |             | 0x0 = TUR events generate an SSP interrupt  
|      |       |             | 0x1 = TUR events do NOT generate an SSP interrupt  |
| 22   | rim   | R/W 0x0     | Receive FIFO Overrun Interrupt Mask  
|      |       |             | 0x0 = ROR events generate an SSP interrupt  
|      |       |             | 0x1 = ROR events do NOT generate an SSP interrupt  |
| 21   | Reserved | R/W 0x0 | Reserved. Do not change the reset value.  |
| 20   | edss  | R/W 0x0     | Extended Data Size Select  
|      |       |             | 0x0 = a 0 is pre-appended to the DSS value to set the DSS range  
|      |       |             | from 8 to 16 bits  
|      |       |             | 0x1 = a 1 is pre-appended to the DSS value to set the DSS range  
|      |       |             | from 18 to 32 bits  |
| 19:8 | Reserved | R/W 0x0 | Reserved. Do not change the reset value.  |
| 7    | sse   | R/W 0x0     | Synchronous Serial Port Enable  
|      |       |             | 0x0 = SSPx port is disabled  
|      |       |             | 0x1 = SSPx port is enabled  |
| 6    | Reserved | R/W 0x0 | Reserved. Do not change the reset value.  |
| 5:4  | frf   | R/W 0x0     | Frame Format  
|      |       |             | This field must be written with 0x3 = to select the PSP format.  
|      |       |             | 0x0 = Motorola* Serial Peripheral Interface (SPI)  
|      |       |             | 0x1 = Texas Instruments* Synchronous Serial Protocol (SSP)  
|      |       |             | 0x2 = National Semiconductor* microwire  
|      |       |             | 0x3 = Programmable Serial Protocol (PSP)  |
24.9.2.2 SSP Control Register 1 (SSCR1)

The SSP Port Control 1 registers contain bit fields that control various SSP port functions. The following table shows bit locations corresponding to control bit fields in SSCR1. The reset state of all bits is shown, but must be set to the preferred value before enabling the SSP port by setting the <Synchronous Serial Port Enable> field in the SSP Control Register 0.

Write 0b0 to reserved bits, the read values of reserved bits are undetermined.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSCR1</td>
<td>0x04</td>
</tr>
</tbody>
</table>

Table 433: SSP Control Register 1 (SSCR1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31   | ttelp | R/W 0x0      | TXD 3-state Enable On Last Phase  
|      |       |              | 0x0 = TXDx is 3-stated 1/2 clock cycle after the beginning of the LSb  
|      |       |              | 0x1 = TXD output is 3-stated on the clock edge that ends the LSb |
| 30   | tte   | R/W 0x0      | TXD 3-State Enable  
|      |       |              | 0x0 = TXD output signal is 3-stated  
|      |       |              | 0x1 = TXD is 3-stated when not transmitting data |
| 29   | ebcei | R/W 0x0      | Enable Bit Count Error Interrupt  
|      |       |              | 0x0 = interrupt due to a bit count error is disabled  
|      |       |              | 0x1 = interrupt due to a bit count error is enabled |
| 28   | scfr  | R/W 0x0      | Slave Clock Free Running  
|      |       |              | 0x0 = clock input to SSPSCLKx is continuously running  
|      |       |              | 0x1 = clock input to SSPSCLKx is only active during data transfers(required for slave mode.) |
| 27   | ecra  | R/W 0x0      | Enable Clock Request A  
|      |       |              | 0x0 = clock request from other SSPx is disabled  
|      |       |              | 0x1 = clock request from other SSPx is enabled |
| 26   | ecrb  | R/W 0x0      | Enable Clock Request B  
|      |       |              | 0x0 = clock request from other SSPx is disabled  
|      |       |              | 0x1 = clock request from other SSPx is enabled |
### Table 433: SSP Control Register 1 (SSCR1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 25   | sclkdir | R/W 0x0     | SSP Serial Bit Rate Clock (SSPSCLKx) Direction  
|      |        |             | 0x0 = master mode, SSPx port drives SSPSCLKx  
|      |        |             | 0x1 = slave mode, SSPx port receives SSPSCLKx  |
| 24   | sfmdir  | R/W 0x0     | SSP Frame (SSPSFRMx) Direction  
|      |        |             | 0x0 = master mode, SSPx port drives SSPSFRMx  
|      |        |             | 0x1 = slave mode, SSPx port receives SSPSFRMx  |
| 23   | rwot    | R/W 0x0     | Receive Without Transmit  
|      |        |             | 0x0 = transmit/Receive mode  
|      |        |             | 0x1 = receive without transmit mode  |
| 22   | Reserved | RSVD --     | Reserved  
|      |        |             | Always write 0. Ignore read value.  |
| 21   | tsre    | R/W 0x0     | Transmit Service Request Enable  
|      |        |             | 0x0 = DMA service request is disabled  
|      |        |             | 0x1 = DMA service request is enabled  |
| 20   | rsre    | R/W 0x0     | Receive Service Request Enable  
|      |        |             | 0x0 = DMA service request is disabled  
|      |        |             | 0x1 = DMA service request is enabled  |
| 19:17 | Reserved | RSVD --     | Reserved  
|      |        |             | Always write 0. Ignore read value.  |
| 16   | ifs     | R/W 0x0     | Invert Frame Signal  
|      |        |             | 0x0 = SSPSFRMx polarity is determined by the PSP polarity bits  
|      |        |             | 0x1 = SSPSFRMx is inverted from normal-SSPSFRMx (as defined by the PSP polarity bits). (Works in all frame formats: SPI, SSP, and PSP)  |
| 15   | strf    | R/W 0x0     | Select FIFO For Efwr  
|      |        |             | Select FIFO For Efwr (Test Mode Bit). Only when EFWR = 1  
|      |        |             | 0x0 = TXFIFO is selected for both writes and reads through the SSP data register  
|      |        |             | 0x1 = RXFIFO is selected for both writes and reads through the SSP data register  |
| 14   | efwr    | R/W 0x0     | Enable FIFO Write/read  
|      |        |             | Enable FIFO Write/read (Test Mode Bit)  
|      |        |             | 0x0 = FIFO write/read special function is disabled (normal SSPx operational mode)  
|      |        |             | 0x1 = FIFO write/read special function is enabled  |
| 13:10| rft     | R/W 0x0     | RXFIFO Trigger Threshold  
|      |        |             | Sets threshold level at which RXFIFO asserts interrupt. Level should be set to the preferred threshold value minus 1.  |
| 9:6  | tft     | R/W 0x0     | TXFIFO Trigger Threshold  
|      |        |             | Sets threshold level at which TXFIFO asserts interrupt. Level should be set to the preferred threshold value minus 1.  |
### 24.9.2.3 SSP Status Register (SSSR)

The SSP Port Status registers contain bits that signal overrun errors as well as the TXFIFO and RXFIFO service requests. Each of these hardware-detected events signals an interrupt request to the interrupt controller, or a DMA request. The Status register also contains flags that indicate if the SSPx port is actively transmitting data, if the TXFIFO is not full, and if the RXFIFO is not empty. A signal interrupt signal is sent to the interrupt controller for each SSPx port. These events can cause an interrupt request or a DMA request: RXFIFO overrun, RXFIFO service request, and TXFIFO service request.

Bits that cause an interrupt request remain set until they are cleared by writing a 0b1 to each bit. Once a status bit is cleared, the interrupt is cleared. Read-write bits are called status bits (status bits are referred to as sticky and once set by hardware, they can only be cleared by writing a 0b1 to each bit), read-only bits are called flags. Writing a 0b1 to a sticky status bit clears it, writing a 0b0 has no effect. Read-only flags are set to 0b1 and are cleared automatically to 0b0 by hardware, and writes have no effect. Some bits that cause interrupt requests have corresponding mask bits in the Control registers and are indicated in the section headings that follow.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>mwds</td>
<td>R/W 0x0</td>
<td>Microwire Date Size</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 8 bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 16 bits</td>
</tr>
<tr>
<td>4</td>
<td>sph</td>
<td>R/W 0x0</td>
<td>Motorola SPI SSPSCLK Phase Setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = SSPSCLKx is inactive until one cycle after the start of a frame and active until 1/2 cycle before the end of a frame</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = SSPSCLKx is inactive until 1/2 cycle after the start of a frame and active until one cycle</td>
</tr>
<tr>
<td>3</td>
<td>spo</td>
<td>R/W 0x0</td>
<td>Motorola SPI SSPSCLK Polarity Setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = the inactive or idle state of SSPSCLKx is low</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = the inactive or idle state of SSPSCLKx is high</td>
</tr>
<tr>
<td>2</td>
<td>lbm</td>
<td>R/W 0x0</td>
<td>Loopback Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Loopback Mode (Test Mode Bit)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = normal serial port operation is enabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = output of TX serial shifter is internally connected to input of RX serial shifter</td>
</tr>
<tr>
<td>1</td>
<td>tie</td>
<td>R/W 0x0</td>
<td>Transmit FIFO Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = TXFIFO threshold-level-reached interrupt is disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = TXFIFO threshold-level-reached interrupt is enabled</td>
</tr>
<tr>
<td>0</td>
<td>rie</td>
<td>R/W 0x0</td>
<td>Receive FIFO Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = RXFIFO threshold-level-reached interrupt is disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = RXFIFO threshold-level-reached interrupt is enabled</td>
</tr>
</tbody>
</table>

### Table 433: SSP Control Register 1 (SSCR1) (Continued)
The following table shows the bit locations corresponding to the status and flag bits within the SSP Port Status Register. All bits are read-only except the <Receive FIFO Overrun>, <Transmit FIFO Underrun>, and <Bit Count Error>, which are all read-write. The reset state of read-write bits is 0b0 and all bits return to their reset state when <Synchronous Serial Port Enable> field in the SSP Control Register 0 is cleared.

Write 0b0 to reserved bits, reads from reserved bits are undetermined.

### Table 434: SSP Status Register (SSSR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31   | oss   | R 0x0        | Odd Sample Status  
Note: that this bit needs to be looked at only when FIFO Packing is enabled (<FIFO Packing Enable> field in SSP Control Register 0 is set). Otherwise this bit is zero.  
When SSPx port is in Packed mode, and the CPU is used instead of DMA to read the RxFIFO, CPU should make sure that <Receive FIFO Not Empty>=1 AND this field=0 before it attempts to read the RxFIFO.  
0x0 = RxFIFO entry has 2 samples  
0x1 = RxFIFO entry has 1 sample |
| 30   | tx_oss | R 0x0        | TX FIFO Odd Sample Status  
When SSPx port is in packed mode, the number of samples in the TX FIFO is:  
(<Transmit FIFO Level>*2 + this field), when <Transmit FIFO Not Full>=1 32, when <Transmit FIFO Not Full>=0. The TX FIFO cannot accept new data when <Transmit FIFO Not Full>=1 and <Transmit FIFO Level>=15 and this field=1. (The TX FIFO has 31 samples).  
Note: that this bit needs to be read only when FIFO Packing is enabled (<FIFO Packing Enable> in the SSP Control Register 0 set). Otherwise this bit is zero.  
0x0 = TxFIFO entry has an even number of samples  
0x1 = TxFIFO entry has an odd number of sample |
| 29:24 | Reserved | RSVD  --     | Reserved. Always write 0. Ignore read value. |
| 23   | bce   | R/W 0x0      | Bit Count Error  
0x0 = the SSPx port has not experienced a bit count error  
0x1 = the SSPSFRMx signal was asserted when the bit counter was not zero |
| 22   | css   | R 0x0        | Clock Synchronization Status  
0x0 = the SSPx port is ready for slave clock operations  
0x1 = the SSPx port is currently busy synchronizing slave mode signals |
### Table 434: SSP Status Register (SSSR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 21   | tur   | R/W 0x0      | Transmit FIFO Underrun  
0x0 = the TXFIFO has not experienced an underrun  
0x1 = a read from the TXFIFO was attempted when the TXFIFO was empty, causes an interrupt if it is enabled (<Transmit FIFO underrun interrupt Mask> in the SSP control register 0 is 0) |
| 20:16| Reserved | RSVD -- | Reserved  
Always write 0. Ignore read value. |
| 15:12| rfl   | R 0xF       | Receive FIFO Level  
Number of entries minus one in RXFIFO.  
Note: When the value 0xF is read, the RXFIFO is either empty or full, and software should read the <Receive FIFO Not Empty> field. |
| 11:8 | tfl   | R 0x0       | Transmit FIFO Level  
Number of entries in TXFIFO.  
Note: When the value 0x0 is read, the TXFIFO is either empty or full, and software should read the <Transmit FIFO Not Full> field. |
| 7    | ror   | R/W 0x0     | Receive FIFO Overrun  
0x0 = RXFIFO has not experienced an overrun  
0x1 = attempted data write to full RXFIFO, causes an interrupt request |
| 6    | rfs   | R 0x0       | Receive FIFO Service Request  
0x0 = RXFIFO level is at or below RFT threshold (RFT), or SSPx port is disabled  
0x1 = RXFIFO level exceeds RFT threshold (RFT), causes an interrupt request |
| 5    | tfs   | R 0x0       | Transmit FIFO Service Request  
0x0 = TX FIFO level exceeds the TFT threshold (TFT + 1), or SSPx port disabled  
0x1 = TX FIFO level is at or below TFT threshold (TFT + 1), causes an interrupt request |
| 4    | bsy   | R 0x0       | SSP Busy  
0x0 = SSPx port is idle or disabled  
0x1 = SSPx port is currently transmitting or receiving framed data |
| 3    | rne   | R 0x0       | Receive FIFO Not Empty  
0x0 = RXFIFO is empty  
0x1 = RXFIFO is not empty |
| 2    | tnf   | R 0x1       | Transmit FIFO Not Full  
0x0 = TXFIFO is full  
0x1 = TXFIFO is not full |
| 1:0  | Reserved | RSVD -- | Reserved. Always write 0. Ignore read value. |
24.9.2.4  SSP Interrupt Test Register (SSITR)

Setting the <Test TXFIFO Service Request> field generates a non-maskable interrupt request and a DMA service request for the TXFIFO.

Write 0b0 to reserved bits, reads from reserved bits are undetermined.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSITR</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

Table 435: SSP Interrupt Test Register (SSITR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7</td>
<td>tror</td>
<td>R/W 0x0</td>
<td>Test RXFIFO Overrun</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no RXFIFO-overrun service request</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = generates a non-maskable RXFIFO-overrun interrupt request. no DMA request</td>
</tr>
<tr>
<td>6</td>
<td>trfs</td>
<td>R/W 0x0</td>
<td>Test RXFIFO Service Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no RXFIFO-service request</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = generates a non-maskable RXFIFO-service interrupt request and DMA request</td>
</tr>
<tr>
<td>5</td>
<td>tefs</td>
<td>R/W 0x0</td>
<td>Test TXFIFO Service Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no TXFIFO-service request</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = generates a non-maskable TXFIFO-service interrupt request and DMA request</td>
</tr>
<tr>
<td>4:0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

24.9.2.5  SSP Data Register (SSDR)

The SSP Data Registers are each two physical registers that have a common address. One SSDR_x is temporary storage for data that is transferred automatically into the TXFIFO, the other SSDR_x is temporary storage for data that is transferred automatically from the RXFIFO.

As programmed I/O or DMA access the SSDR_x, the TXFIFO or RXFIFO control logic transfers data automatically between the SSDR_x and the FIFO as fast as the system moves it. Data in the TXFIFO shifts up to accommodate new data that is written to the SSDR_X, unless it is an attempted write to a full TXFIFO. Data in the RXFIFO shifts down to accommodate data that is read from the SSP Data Register. The <Transmit FIFO Level>, <Receive FIFO Level>, <Receive FIFO Not Empty>, and <Transmit FIFO Not Full> fields in the SSP Status Register show whether the FIFO is full, above/below a programmable FIFO trigger threshold level, or empty.

When using programmed I/O, data can be written to the SSP Data Register anytime the TXFIFO falls below its trigger threshold level.
When a data sample size of less than 32-bits is selected, or 16 bits for packed mode, software should right-justify the data that is written to the SSP Data Register for automatic insertion into the TXFIFO. The transmit logic left-justifies the data and ignores any unused bits. Received data of less than 32 bits is right-justified automatically in the RXFIFO (cannot perform a write in packed mode of less than 32 bits wide). The TXFIFO and RXFIFO are cleared to 0b0 when the SSPx port is reset or disabled (by writing a 0b0 to the <Synchronous Serial Port Enable> field in the SSP Control Register 0).

The reset state of SSDR_x is undetermined. The following table shows the location of the SSPx port SSDR_x.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSDR</td>
<td>0x10</td>
</tr>
</tbody>
</table>

Table 436: SSP Data Register (SSDR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R/W 0x0</td>
<td>DATA</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Data to be written to the TXFIFO read from the RXFIFO</td>
</tr>
</tbody>
</table>

24.9.2.6 SSP Programmable Serial Protocol Register (SSPSP)

The SSP Programmable Serial Protocol registers contain 8 fields that program the various programmable serial-protocol (PSP) parameters. When using Programmable Serial Protocol (PSP) format in network mode, the parameters <Serial Frame Delay>, <Serial Frame Delay>, <Start Delay>, <Dummy Stop>, <Extended Dummy Stop>, <Dummy Start>, and <Extended Dummy Start> must be set to 0b0. The other parameters <Serial Frame Polarity>, <Serial Bit-rate Clock Mode>, <Frame Sync Relative Timing Bit>, and <Serial Frame Width> are programmable.

 Writes 0b0 to reserved bits, reads from reserved bits are undetermined.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSPSP</td>
<td>0x2C</td>
</tr>
</tbody>
</table>

Table 437: SSP Programmable Serial Protocol Register (SSPSP)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
<td>RSVDD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>30:28</td>
<td>edmystop</td>
<td>R/W 0x0</td>
<td>Extended Dummy Stop</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The most-significant bits of the dummy stop delay</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Note: Do not use in PSP Network mode.</td>
</tr>
<tr>
<td>27:26</td>
<td>edmystrt</td>
<td>R/W 0x0</td>
<td>Extended Dummy Start</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The most-significant bits of the dummy start delay</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Note: Do not use in PSP Network mode.</td>
</tr>
</tbody>
</table>
### Table 437: SSP Programmable Serial Protocol Register (SSPSP) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 25   | fsrt    | R/W 0x0     | Frame Sync Relative Timing Bit  
|      |         |             | 0x0 = next frame is asserted after the end of the DMTSTOP timing  
|      |         |             | 0x1 = next frame is asserted with the LSb of the previous frame                                                                      |
| 24:23| dmystop | R/W 0x0     | Dummy Stop  
|      |         |             | The least-significant bits of the dummy stop delay.  
|      |         |             | Programmed value of <Extended Dummy Stop> + this field specifies the number (0-31) of active clocks (SSPCLKx) that follow the end of the transmitted data.  
|      |         |             | Note: Do not use in PSP Network mode.                                                                                                   |
| 22   | Reserved| RSVD --     | Reserved. Always write 0. Ignore read value.                                                                                             |
| 21:16| sfrmwdth| R/W 0x0     | Serial Frame Width  
|      |         |             | Least-significant bits of the serial frame width  
|      |         |             | Programmed value of this field specifies the frame width from 0x00 (one SSPCLKx cycle) to 0x3F (63 SSPCLKx cycles).               |
| 15:9 | sfmdly  | R/W 0x0     | Serial Frame Delay  
|      |         |             | Programmed value specifies the number (0-127) of active one-half clocks (SSPCLKx) asserted from the most-significant bit of TXDx (output) or RXD (input) being driven to SSPSFRMx.  
|      |         |             | Note: Do not use in PSP Network mode.                                                                                                   |
| 8:7  | dmystrt | R/W 0x0     | Dummy Start  
|      |         |             | Least-significant bits of the dummy start delay  
|      |         |             | Programmed value of this field specifies the number (0-15) of active clocks (SSPCLKx) between the end of start delay and when the most-significant bit of transmit/receive data is driven  
|      |         |             | Note: Do not use in PSP Network mode.                                                                                                   |
| 6:4  | stdcly  | R/W 0x0     | Start Delay  
|      |         |             | Programmed value specifies the number (0-7) of non-active clocks (SSPCLKx) that define the duration of idle time  
|      |         |             | Note: Do not use in PSP Network mode.                                                                                                   |
| 3    | etds    | R/W 0x0     | End Of Transfer Data State                                                                                                               |
| 2    | sfmp    | R/W 0x0     | Serial Frame Polarity  
|      |         |             | 0x0 = SSPSFRMx is active low (0b0)  
|      |         |             | 0x1 = SSPSFRMx is active high (0b1)                                                                                                    |
| 1:0  | scmode  | R/W 0x0     | Serial Bit-rate Clock Mode  
|      |         |             | 0x0 = data driven (Falling), data sampled (Rising), idle state (Low)  
|      |         |             | 0x1 = data driven (Rising), data sampled (Falling), idle state (Low)  
|      |         |             | 0x2 = data driven (Rising), data sampled (Falling), idle state (High)  
|      |         |             | 0x3 = data driven (Falling), data sampled (Rising), idle state (High)                                                                 |
24.9.2.7 SSA TX Time Slot Active Register (SSTSA)

Only used in Network mode (<Mode> in SSP Control Register 0 set), the read-write SSP TX Time Slot Active registers specify in which time slot the SSPx port transmits data.

The 8-bit <TX Time Slot Active> field specifies in which time slots the SSPx port transmits data and in which time slots the SSPx port does not transmit data. Bits beyond the <Frame Rate Divider Control> field in the SSP Control Register 0 value are ignored (for example, if <Frame Rate Divider Control>= 0x3, specifying that 4 time slots are used, then <TX Time Slot Active> bits 7:4 are ignored). If the <TXD 3-State Enable> field in the SSP Control Register 1 is set, the SSPx port 3-states the SSPTXDx interface output signal line during time slots that have associated TTSA bits programmed to 0b0.

Write 0b0 to reserved bits, reads from reserved bits are undetermined.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSTSA</td>
<td>0x30</td>
</tr>
</tbody>
</table>

Table 438: SSP TX Time Slot Active Register (SSTSA)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 7:0  | ttsa   | R/W 0x0    | TX Time Slot Active  
0x0 = SSPx port does NOT transmit data in this time slot  
0x1 = SSPx port does transmit data in this time slot |

24.9.2.8 SSP RX Time Slot Active Register (SSRSA)

Only used in Network mode (<Mode> in SSP Control Register 0 set), the read-write SSP RX Time Slot Active registers specify in which time slot the SSPx port receives data.

The 8-bit <RX Time Slot Active> field specifies in which time slots the SSPx port receives data and in which time slots the SSPx port does not receive data. Bits beyond the <Frame Rate Divider Control> field in the SSP Control Register 0 value are ignored. For example, if <Frame Rate Divider Control>=0x3, specifying that 4 time slots are used, then RX Time Slot Active> bits 7:4 are ignored.

Write 0b0 to reserved bits, reads from reserved bits are undetermined.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSRSA</td>
<td>0x34</td>
</tr>
</tbody>
</table>

Table 439: SSP RX Time Slot Active Register (SSRSA)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
The <Network Mode Busy> field shows when the SSPx port is within a frame only when in Network mode (<Mode> in SSP Control Register 0 set). It can be used by software to determine when a clean shutdown of the SSPx port can be initiated. Software should:

1. Determine that the TXFIFO is either empty or is emptied at the end of the next frame.
2. Deactivate the TXFIFO DMA service requests.
3. Clear <Mode> in SSP Control Register 0 (to exit network mode).
4. Then poll <Network Mode Busy> until it is cleared before disabling the SSPx port by clearing the <Synchronous Serial Port Enable> field in the SSP Control Register 0.

When the SSPx port is a master of the frame signal (<SSP Frame (SSPSFRMx) Direction> field in SSP Control Register 1 set), <Network Mode Busy> is set as long as the port remains in Network mode. When the SSPx port is a slave of the frame signal, the <Network Mode Busy> field is cleared if the current frame (number of bits per sample * number of time slots per frame) has not expired since the last SSPSFRMx interface signal (in/out) was asserted.

Time Slot Status (TSS)

The 3-bit <Time Slot Status> field value identifies the time slot in which the SSPx port is operating. Due to synchronization between the SSPSCLKx domain and an internal bus clock domain, the TSS value becomes stable approximately two internal bus clock cycles after the beginning of the associated time slot. The <Time Slot Status> value is not valid if the <Network Mode Busy> field is cleared.

Write 0b0 to reserved bits, reads from reserved bits are undetermined.
Table 440: SSP Time Slot Status Register (SSTSS) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2:0</td>
<td>tss</td>
<td>R 0x0</td>
<td>Time Slot Status Value indicates which time slot is currently active. Because of synchronization between the SSPx port's SSPSCLKx domain and an internal bus clock domain, the value in this field becomes stable between the beginning and end of the currently active time slot.</td>
</tr>
</tbody>
</table>
24.10 UART Address Block

24.10.1 UART Register Map

Table 441: UART Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>RBR</td>
<td>0x0000_0000</td>
<td>Receive Buffer Register</td>
<td>Page: 522</td>
</tr>
<tr>
<td>0x00</td>
<td>THR</td>
<td>0x0000_0000</td>
<td>Transmit Holding Register</td>
<td>Page: 523</td>
</tr>
<tr>
<td>0x00</td>
<td>DLL</td>
<td>0x0000_0002</td>
<td>Divisor Latch Low Byte Registers</td>
<td>Page: 523</td>
</tr>
<tr>
<td>0x04</td>
<td>DLH</td>
<td>0x0000_0000</td>
<td>Divisor Latch High Byte Registers</td>
<td>Page: 524</td>
</tr>
<tr>
<td>0x04</td>
<td>IER</td>
<td>0x0000_0000</td>
<td>Interrupt Enable Register</td>
<td>Page: 524</td>
</tr>
<tr>
<td>0x08</td>
<td>IIR</td>
<td>0x0000_0001</td>
<td>Interrupt Identification Register</td>
<td>Page: 525</td>
</tr>
<tr>
<td>0x08</td>
<td>FCR</td>
<td>0x0000_0000</td>
<td>FIFO Control Register</td>
<td>Page: 526</td>
</tr>
<tr>
<td>0x0C</td>
<td>LCR</td>
<td>0x0000_0000</td>
<td>Line Control Register</td>
<td>Page: 527</td>
</tr>
<tr>
<td>0x10</td>
<td>MCR</td>
<td>0x0000_0000</td>
<td>Modem Control Register</td>
<td>Page: 528</td>
</tr>
<tr>
<td>0x14</td>
<td>LSR</td>
<td>0x0000_0060</td>
<td>Line Status Register</td>
<td>Page: 529</td>
</tr>
<tr>
<td>0x18</td>
<td>MSR</td>
<td>0x0000_0000</td>
<td>Modem Status Register</td>
<td>Page: 530</td>
</tr>
<tr>
<td>0x1C</td>
<td>SCR</td>
<td>0x0000_0000</td>
<td>Scratchpad Register</td>
<td>Page: 530</td>
</tr>
<tr>
<td>0x20</td>
<td>ISR</td>
<td>0x0000_0000</td>
<td>Infrared Selection Register</td>
<td>Page: 530</td>
</tr>
<tr>
<td>0x24</td>
<td>RFOR</td>
<td>0x0000_0000</td>
<td>Receive FIFO Occupancy Register</td>
<td>Page: 531</td>
</tr>
<tr>
<td>0x28</td>
<td>ABR</td>
<td>0x0000_0000</td>
<td>Auto-Baud Control Register</td>
<td>Page: 532</td>
</tr>
<tr>
<td>0x2C</td>
<td>ACR</td>
<td>0x0000_0000</td>
<td>Auto-Baud Count Register</td>
<td>Page: 532</td>
</tr>
</tbody>
</table>

24.10.2 UART Registers

24.10.2.1 Receive Buffer Register (RBR)

Table 442: Receive Buffer Register (RBR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>byte_3</td>
<td>R 0x0</td>
<td>Byte 3 (valid Only in 32-bit Peripheral Bus mode)</td>
</tr>
</tbody>
</table>
24.10.2.2 Transmit Holding Register (THR)

Table 443: Transmit Holding Register (THR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>byte_3</td>
<td>W 0x0</td>
<td>Byte 3 (valid Only in 32-bit Peripheral Bus mode)</td>
</tr>
<tr>
<td>23:16</td>
<td>byte_2</td>
<td>W 0x0</td>
<td>Byte 2 (valid Only in 32-bit Peripheral Bus mode)</td>
</tr>
<tr>
<td>15:8</td>
<td>byte_1</td>
<td>W 0x0</td>
<td>Byte 1 (valid Only in 32-bit Peripheral Bus mode)</td>
</tr>
<tr>
<td>7:0</td>
<td>byte_0</td>
<td>W 0x0</td>
<td>Byte 0</td>
</tr>
</tbody>
</table>

24.10.2.3 Divisor Latch Low Byte Registers (DLL)

Table 444: Divisor Latch Low Byte Registers (DLL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:0</td>
<td>dll</td>
<td>R/W 0x2</td>
<td>DLL, Low-byte Compare Value to Generate Baud Rate</td>
</tr>
</tbody>
</table>
24.10.2.4 Divisor Latch High Byte Registers (DLH)

Table 445: Divisor Latch High Byte Registers (DLH)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:0</td>
<td>dlh</td>
<td>R/W 0x0</td>
<td>DLH, High-byte Compare Value to Generate Baud Rate</td>
</tr>
</tbody>
</table>

24.10.2.5 Interrupt Enable Register (IER)

Table 446: Interrupt Enable Register (IER)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:9</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>8</td>
<td>hse</td>
<td>R/W 0x0</td>
<td>High Speed UART Enable (HSE)</td>
</tr>
<tr>
<td>7</td>
<td>dmae</td>
<td>R/W 0x0</td>
<td>DMA Requests Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA requests are disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA requests are enabled</td>
</tr>
<tr>
<td>6</td>
<td>uue</td>
<td>R/W 0x0</td>
<td>UART Unit Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = the unit is disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = the unit is enabled</td>
</tr>
<tr>
<td>5</td>
<td>nrze</td>
<td>R/W 0x0</td>
<td>NRZ Coding Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>NRZ encoding/decoding is only used in UART mode, not in infrared mode. If the serial infrared receiver or transmitter is enabled, NRZ coding is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = NRZ coding disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = NRZ coding enabled</td>
</tr>
<tr>
<td>4</td>
<td>rtoie</td>
<td>R/W 0x0</td>
<td>Receiver Timeout Interrupt Enable (Source IIR[TOD])</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = receiver data timeout interrupt disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = receiver data timeout interrupt enabled</td>
</tr>
</tbody>
</table>
### Table 446: Interrupt Enable Register (IER) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>mie</td>
<td>R/W 0x0</td>
<td>Modem Interrupt Enable (Source IIR[IID]) 0x0 = modem status interrupt disabled 0x1 = modem status interrupt enabled</td>
</tr>
<tr>
<td>2</td>
<td>rls</td>
<td>R/W 0x0</td>
<td>Receiver Line Status Interrupt Enable (Source IIR[IID]) 0x0 = receiver line status interrupt disabled 0x1 = receiver line status interrupt enabled</td>
</tr>
<tr>
<td>1</td>
<td>tie</td>
<td>R/W 0x0</td>
<td>Transmit Data Request Interrupt Enable (Source IIR[IID]) 0x0 = transmit FIFO data request interrupt disabled 0x1 = transmit FIFO data request interrupt enabled</td>
</tr>
<tr>
<td>0</td>
<td>ravie</td>
<td>R/W 0x0</td>
<td>Receiver Data Available Interrupt Enable (Source IIR[IID]) 0x0 = receiver data available(trigger threshold reached) interrupt disabled 0x1 = receiver data available(trigger threshold reached) interrupt enabled</td>
</tr>
</tbody>
</table>

### 24.10.2.6 Interrupt Identification Register (IIR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IIR</td>
<td>0x08</td>
</tr>
</tbody>
</table>

#### Table 447: Interrupt Identification Register (IIR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:6</td>
<td>fifoes10</td>
<td>R 0x0</td>
<td>FIFO Mode Enable Status 0x0 = Non-FIFO mode is selected 0x1 = reserved 0x2 = reserved 0x3 = FIFO mode is selected</td>
</tr>
<tr>
<td>5</td>
<td>eoc</td>
<td>R 0x0</td>
<td>DMA End of Descriptor Chain 0x0 = DMA has not signaled the end of its programmed descriptor chain 0x1 = DMA has signaled the end of its programmed descriptor chain</td>
</tr>
<tr>
<td>4</td>
<td>abl</td>
<td>R 0x0</td>
<td>Auto-baud Lock 0x0 = Auto-baud circuitry has not programmed divisor latch registers (DLR) 0x1 = divisor latch registers (DLR) programmed by auto-baud circuitry</td>
</tr>
</tbody>
</table>
24.10.2.7 FIFO Control Register (FCR)

Table 447: Interrupt Identification Register (IIR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>tod</td>
<td>R 0x0</td>
<td>Timeout Detected 0x0 = no timeout interrupt is pending 0x1 = timeout interrupt is pending (FIFO mode only)</td>
</tr>
<tr>
<td>2:1</td>
<td>iid10</td>
<td>R 0x0</td>
<td>Interrupt Source Encoded 0x0 = modern Status (CTS) 0x1 = transmit FIFO request data 0x2 = receive data available 0x3 = receive error (overrun)</td>
</tr>
<tr>
<td>0</td>
<td>nip</td>
<td>R 0x1</td>
<td>Interrupt Is Pending 0x0 = interrupt is pending (active low) 0x1 = no interrupt is pending</td>
</tr>
</tbody>
</table>

Table 448: FIFO Control Register (FCR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCR</td>
<td>0x08</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:6</td>
<td>itl</td>
<td>W 0x0</td>
<td>Interrupt Trigger Level When the number of the bytes in the receive FIFO equals the interrupt trigger threshold programmed into this field and the received-data-available interrupt is enabled with the IER, an interrupt is generated and appropriate bits are set in the IIR. The receive DMA request is also generated when the trigger threshold is reached. 0x0 = 1 byte or more in FIFO causes interrupt (Not valid in DMA mode) 0x1 = 8 bytes or more in FIFO cause interrupt and DMA request 0x2 = 16 bytes or more in FIFO causes interrupt and DMA request 0x3 = 32 bytes or more in FIFO causes interrupt and DMA request</td>
</tr>
<tr>
<td>5</td>
<td>bus</td>
<td>W 0x0</td>
<td>32-Bit Peripheral Bus 0x0 = 8-bit peripheral bus 0x1 = 32-bit peripheral bus, transmit and receive FIFO need to be enabled in this mode</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.10.2.8 Line Control Register (LCR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCR</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

#### Table 449: Line Control Register (LCR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7</td>
<td>dlab</td>
<td>R/W 0x0</td>
<td>Divisor Latch Access 0x0 = access transmit holding register, receive buffer register, and interrupt enable register 0x1 = access divisor latch registers</td>
</tr>
<tr>
<td>6</td>
<td>sb</td>
<td>R/W 0x0</td>
<td>Set Break 0x0 = no effect on TXD output 0x1 = forces TXD output to 0</td>
</tr>
<tr>
<td>5</td>
<td>stkyp</td>
<td>R/W 0x0</td>
<td>Sticky Parity 0x0 = no effect on parity bit 0x1 = forces parity bit to be opposite of EPS bit value</td>
</tr>
</tbody>
</table>
Table 449: Line Control Register (LCR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>eps</td>
<td>R/W 0x0</td>
<td>Even Parity Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = sends or checks for odd parity</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = sends or checks for even parity</td>
</tr>
<tr>
<td>3</td>
<td>pen</td>
<td>R/W 0x0</td>
<td>Parity Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no parity</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = Parity</td>
</tr>
<tr>
<td>2</td>
<td>stb</td>
<td>R/W 0x0</td>
<td>Stop Bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 1 stop bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 2 stop bit</td>
</tr>
<tr>
<td>1:0</td>
<td>wls10</td>
<td>R/W 0x0</td>
<td>World Length Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 5-bit character</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 6-bit character</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 7-bit character</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 8-bit character</td>
</tr>
</tbody>
</table>

24.10.2.9 Modem Control Register (MCR)

Table 450: Modem Control Register (MCR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR</td>
<td>0x10</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>afe</td>
<td>R/W 0x0</td>
<td>Auto-flow Control Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = auto-RTS and auto-CTS are disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = auto-RTS and auto-CTS are enabled</td>
</tr>
<tr>
<td>4</td>
<td>loop</td>
<td>R/W 0x0</td>
<td>Loopback Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = normal UART operation</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = loopback mode UART operation</td>
</tr>
<tr>
<td>3:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>rts</td>
<td>R/W 0x0</td>
<td>Request to Send</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = non-auto-flow mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = auto-flow mode</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.10.2.10 Line Status Register (LSR)

### Table 451: Line Status Register (LSR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7</td>
<td>fifoe</td>
<td>R 0x0</td>
<td>FIFO Error Status 0x0 = no FIFO or no errors in receive FIFO 0x1 = at least one character in receive FIFO has errors</td>
</tr>
<tr>
<td>6</td>
<td>temt</td>
<td>R 0x1</td>
<td>Transmitter Empty 0x0 = there is data in the transmit shift register, the transmit holding register, or the FIFO 0x1 = all the data in the transmitter has been shifted out</td>
</tr>
<tr>
<td>5</td>
<td>tdrq</td>
<td>R 0x1</td>
<td>Transmit Data Request 0x0 = there is data in the holding register or FIFO waiting to be shifted out 0x1 = transmit FIFO has half or less then half data</td>
</tr>
<tr>
<td>4</td>
<td>bi</td>
<td>R 0x0</td>
<td>Break Interrupt 0x0 = no break signal has been received 0x1 = break signal received</td>
</tr>
<tr>
<td>3</td>
<td>fe</td>
<td>R 0x0</td>
<td>Framing Error 0x0 = no framing error 0x1 = invalid stop bit has been detected</td>
</tr>
<tr>
<td>2</td>
<td>pe</td>
<td>R 0x0</td>
<td>Parity Error 0x0 = no parity error 0x1 = parity error has been detected</td>
</tr>
<tr>
<td>1</td>
<td>oe</td>
<td>R 0x0</td>
<td>Overrun Error 0x0 = no data has been lost 0x1 = receive data has been lost</td>
</tr>
<tr>
<td>0</td>
<td>dr</td>
<td>R 0x0</td>
<td>Data Ready 0x0 = no data has been received 0x1 = data is available in RBR or the FIFO</td>
</tr>
</tbody>
</table>

24.10.2.11 Modem Status Register (MSR)

### Table 452: Modem Status Register (MSR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MSR</td>
<td>0x18</td>
</tr>
</tbody>
</table>
24.10.2.12 Scratchpad Register (SCR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCR</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

### Table 453: Scratchpad Register (SCR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVDD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:0</td>
<td>scratchpad</td>
<td>R/W 0x0</td>
<td>No Effect on UART Functions</td>
</tr>
</tbody>
</table>

24.10.2.13 Infrared Selection Register (ISR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISR</td>
<td>0x20</td>
</tr>
</tbody>
</table>

### Table 454: Infrared Selection Register (ISR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVDD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.10.2.14 Receive FIFO Occupancy Register (RFOR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>Reserved</td>
<td>R/W</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5:0</td>
<td>byte_count</td>
<td>R 0x0</td>
<td>Number of Bytes (0-63) Remaining in Receive FIFO In non-FIFO mode, 0 is returned.</td>
</tr>
</tbody>
</table>

24.10.2.15 Auto-Baud Control Register (ABR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ABR</td>
<td>0x28</td>
</tr>
</tbody>
</table>
### Table 456: Auto-Baud Control Register (ABR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3</td>
<td>abt</td>
<td>R/W 0x0</td>
<td>Auto-Baud Table&lt;br&gt;0x0 = formula used to calculate baud rates&lt;br&gt;0x1 = table used to calculate baud rates, which limits UART to choosing common baud rates</td>
</tr>
<tr>
<td>2</td>
<td>abup</td>
<td>R/W 0x0</td>
<td>Auto-baud Programmer Select&lt;br&gt;0x0 = CPU programs divisor latch register&lt;br&gt;0x1 = UART programs divisor latch register</td>
</tr>
<tr>
<td>1</td>
<td>abie</td>
<td>R/W 0x0</td>
<td>Auto-baud-lock Interrupt Enable&lt;br&gt;0x0 = auto-baud-lock interrupt is disabled&lt;br&gt;0x1 = auto-baud-lock interrupt is enabled</td>
</tr>
<tr>
<td>0</td>
<td>abe</td>
<td>R/W 0x0</td>
<td>Auto-baud Enable&lt;br&gt;0x0 = auto-baud disabled&lt;br&gt;0x1 = auto-baud enabled</td>
</tr>
</tbody>
</table>

### 24.10.2.16 Auto-Baud Count Register (ACR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACR</td>
<td>0x2C</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Table 457: Auto-Baud Count Register (ACR)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bits</td>
</tr>
<tr>
<td>--------</td>
</tr>
<tr>
<td>31:16</td>
</tr>
<tr>
<td>15:0</td>
</tr>
</tbody>
</table>
## 24.11 GPIO Address Block

### 24.11.1 GPIO Register Map

**Table 458: GPIO Register Map**

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>GPIO_GPLR_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Pin Level Register0</td>
<td>Page: 534</td>
</tr>
<tr>
<td>0x04</td>
<td>GPIO_GPLR_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Pin Level Register1</td>
<td>Page: 534</td>
</tr>
<tr>
<td>0x0C</td>
<td>GPIO_GPDR_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Pin Direction Register0</td>
<td>Page: 535</td>
</tr>
<tr>
<td>0x10</td>
<td>GPIO_GPDR_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Pin Direction Register1</td>
<td>Page: 535</td>
</tr>
<tr>
<td>0x18</td>
<td>GPIO_GPSR_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Pin Output Set Register 0</td>
<td>Page: 535</td>
</tr>
<tr>
<td>0x1C</td>
<td>GPIO_GPSR_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Pin Output Set Register 1</td>
<td>Page: 536</td>
</tr>
<tr>
<td>0x24</td>
<td>GPIO_GPCR_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Pin Output Clear Register 0</td>
<td>Page: 536</td>
</tr>
<tr>
<td>0x28</td>
<td>GPIO_GPCR_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Pin Output Clear Register 1</td>
<td>Page: 536</td>
</tr>
<tr>
<td>0x30</td>
<td>GPIO_GRER_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Rising Edge Detect Enable Register 0</td>
<td>Page: 537</td>
</tr>
<tr>
<td>0x34</td>
<td>GPIO_GRER_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Rising Edge Detect Enable Register 1</td>
<td>Page: 537</td>
</tr>
<tr>
<td>0x3C</td>
<td>GPIO_GFER_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Falling Edge Detect Enable Register 0</td>
<td>Page: 537</td>
</tr>
<tr>
<td>0x40</td>
<td>GPIO_GFER_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Falling Edge Detect Enable Register 1</td>
<td>Page: 538</td>
</tr>
<tr>
<td>0x48</td>
<td>GPIO_GEDR_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Edge Detect Status Register 0</td>
<td>Page: 538</td>
</tr>
<tr>
<td>0x4C</td>
<td>GPIO_GEDR_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Edge Detect Status Register 1</td>
<td>Page: 538</td>
</tr>
<tr>
<td>0x54</td>
<td>GPIO_GSDR_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Pin Bitwise Set Direction Register 0</td>
<td>Page: 539</td>
</tr>
<tr>
<td>0x58</td>
<td>GPIO_GSDR_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Pin Bitwise Set Direction Register 1</td>
<td>Page: 539</td>
</tr>
<tr>
<td>0x60</td>
<td>GPIO_GCDDR_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Pin Bitwise Clear Direction Register 0</td>
<td>Page: 539</td>
</tr>
<tr>
<td>0x64</td>
<td>GPIO_GCDDR_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Pin Bitwise Clear Direction Register 1</td>
<td>Page: 540</td>
</tr>
<tr>
<td>0x6C</td>
<td>GPIO_GSRER_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Bitwise Set Rising Edge Detect Enable Register 0</td>
<td>Page: 540</td>
</tr>
<tr>
<td>0x70</td>
<td>GPIO_GSRER_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Bitwise Set Rising Edge Detect Enable Register 1</td>
<td>Page: 540</td>
</tr>
<tr>
<td>0x78</td>
<td>GPIO_GCRER_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Bitwise Clear Rising Edge Detect Enable Register 0</td>
<td>Page: 541</td>
</tr>
<tr>
<td>0x7C</td>
<td>GPIO_GCRER_REG1</td>
<td>0x0000_0000</td>
<td>GPIO Bitwise Clear Rising Edge Detect Enable Register 1</td>
<td>Page: 541</td>
</tr>
<tr>
<td>0x84</td>
<td>GPIO_GSFER_REG0</td>
<td>0x0000_0000</td>
<td>GPIO Bitwise Set Falling Edge Detect Enable Register 0</td>
<td>Page: 542</td>
</tr>
</tbody>
</table>
24.11.2 GPIO Registers

24.11.2.1 GPIO Pin Level Register0 (GPIO_GPLR_REG0)

Table 459: GPIO Pin Level Register0 (GPIO_GPLR_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>gplr_reg0</td>
<td>R 0x0</td>
<td>GPLR Reg0 0x0 = port state low 0x1 = port state high</td>
</tr>
</tbody>
</table>

24.11.2.2 GPIO Pin Level Register1 (GPIO_GPLR_REG1)

Table 460: GPIO Pin Level Register1 (GPIO_GPLR_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:0</td>
<td>gplr_reg1</td>
<td>R 0x0</td>
<td>GPLR Reg1 0x0 = port state low 0x1 = port state high</td>
</tr>
</tbody>
</table>
### 24.11.2.3 GPIO Pin Direction Register0 (GPIO_GPDR_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GPDR_REG0</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

#### Table 461: GPIO Pin Direction Register0 (GPIO_GPDR_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0 | gpdr_reg0 | R/W 0x0     | GPDR Reg0  
0x0 = input port  
0x1 = output port |

### 24.11.2.4 GPIO Pin Direction Register1 (GPIO_GPDR_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GPDR_REG1</td>
<td>0x10</td>
</tr>
</tbody>
</table>

#### Table 462: GPIO Pin Direction Register1 (GPIO_GPDR_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 17:0 | gpdr_reg1 | R/W 0x0     | GPDR Reg1  
0x0 = input port  
0x1 = output port |

### 24.11.2.5 GPIO Pin Output Set Register 0 (GPIO_GPSR_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GPSR_REG0</td>
<td>0x18</td>
</tr>
</tbody>
</table>

#### Table 463: GPIO Pin Output Set Register 0 (GPIO_GPSR_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0 | gpsr_reg0 | W 0x0       | GPSR Reg0  
0x0 = unaffected  
0x1 = port set if GPIO is configured as output |
### 24.11.2.6 GPIO Pin Output Set Register 1 (GPIO_GPSR_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GPSR_REG1</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:0</td>
<td>gprs_reg1</td>
<td>W, 0x0</td>
<td>GPIO Reg1 0x0 = unaffected 0x1 = port set if GPIO is configured as output</td>
</tr>
</tbody>
</table>

### 24.11.2.7 GPIO Pin Output Clear Register 0 (GPIO_GPCR_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GPCR_REG0</td>
<td>0x24</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>gpcr_reg0</td>
<td>W, 0x0</td>
<td>GPIO Reg0 0x0 = unaffected 0x1 = port clear if GPIO is configured as output</td>
</tr>
</tbody>
</table>

### 24.11.2.8 GPIO Pin Output Clear Register 1 (GPIO_GPCR_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GPCR_REG1</td>
<td>0x28</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:0</td>
<td>gpcr_reg1</td>
<td>W, 0x0</td>
<td>GPIO Reg1 0x0 = unaffected 0x1 = port clear if GPIO is configured as output</td>
</tr>
</tbody>
</table>
24.11.2.9  GPIO Rising Edge Detect Enable Register 0 (GPIO_GRER_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GRER_REG0</td>
<td>0x30</td>
</tr>
</tbody>
</table>

Table 467: GPIO Rising Edge Detect Enable Register 0 (GPIO_GRER_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>grer_reg0</td>
<td>R/W</td>
<td>GRER Reg0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = disable rising edge detection</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = set corresponding GEDR status bit when rising edge is detected on GPIO input</td>
</tr>
</tbody>
</table>

24.11.2.10  GPIO Rising Edge Detect Enable Register 1 (GPIO_GRER_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GRER_REG1</td>
<td>0x34</td>
</tr>
</tbody>
</table>

Table 468: GPIO Rising Edge Detect Enable Register 1 (GPIO_GRER_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:0</td>
<td>grer_reg1</td>
<td>R/W</td>
<td>GRER Reg1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = disable rising edge detection</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = set corresponding GEDR status bit when rising edge is detected on GPIO input</td>
</tr>
</tbody>
</table>

24.11.2.11  GPIO Falling Edge Detect Enable Register 0 (GPIO_GFER_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GFER_REG0</td>
<td>0x3C</td>
</tr>
</tbody>
</table>

Table 469: GPIO Falling Edge Detect Enable Register 0 (GPIO_GFER_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>gfer_reg0</td>
<td>R/W</td>
<td>GFER Reg0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = disable falling edge detection</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = set corresponding GEDR status bit when falling edge is detected on GPIO input</td>
</tr>
</tbody>
</table>
### 24.11.2.12 GPIO Falling Edge Detect Enable Register 1 (GPIO_GFER_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GFER_REG1</td>
<td>0x40</td>
</tr>
</tbody>
</table>

**Table 470: GPIO Falling Edge Detect Enable Register 1 (GPIO_GFER_REG1)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 17:0   | gfer_reg1  | R/W 0x0      | GFER Reg1
0x0 = disable falling edge detection
0x1 = set corresponding GEDR status bit when falling edge is detected on GPIO input |

### 24.11.2.13 GPIO Edge Detect Status Register 0 (GPIO_GEDR_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GEDR_REG0</td>
<td>0x48</td>
</tr>
</tbody>
</table>

**Table 471: GPIO Edge Detect Status Register 0 (GPIO_GEDR_REG0)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0   | gedr_reg0| R/W 0x1CLR   | GEDR Reg0
0x0 = no edge detected on a port as specified by GRERx or GFERx
0x1 = edge detected on a port as specified by GRERx or GFERx |

### 24.11.2.14 GPIO Edge Detect Status Register 1 (GPIO_GEDR_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GEDR_REG1</td>
<td>0x4C</td>
</tr>
</tbody>
</table>

**Table 472: GPIO Edge Detect Status Register 1 (GPIO_GEDR_REG1)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 17:0   | gedr_reg1| R/W 0x1CLR   | GEDR Reg1
0x0 = no edge detected on a port as specified by GRERx or GFERx
0x1 = edge detected on a port as specified by GRERx or GFERx |
24.11.2.15 GPIO Pin Bitwise Set Direction Register 0 (GPIO_GSDR_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GSDR_REG0</td>
<td>0x54</td>
</tr>
</tbody>
</table>

Table 473: GPIO Pin Bitwise Set Direction Register 0 (GPIO_GSDR_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>gsdr_reg0</td>
<td>W 0x0</td>
<td>GSDR Reg0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = GPDR bit unaffected</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = GPDR bit set and GPIO pin is set as output</td>
</tr>
</tbody>
</table>

24.11.2.16 GPIO Pin Bitwise Set Direction Register 1 (GPIO_GSDR_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GSDR_REG1</td>
<td>0x58</td>
</tr>
</tbody>
</table>

Table 474: GPIO Pin Bitwise Set Direction Register 1 (GPIO_GSDR_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>Reserved. Always write 0. Ignore read value.</td>
<td></td>
</tr>
<tr>
<td>17:0</td>
<td>gsdr_reg1</td>
<td>W 0x0</td>
<td>GSDR Reg1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = GPDR bit unaffected</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = GPDR bit set and GPIO pin is set as output</td>
</tr>
</tbody>
</table>

24.11.2.17 GPIO Pin Bitwise Clear Direction Register 0 (GPIO_GCDR_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GCDR_REG0</td>
<td>0x60</td>
</tr>
</tbody>
</table>

Table 475: GPIO Pin Bitwise Clear Direction Register 0 (GPIO_GCDR_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>gcdr_reg0</td>
<td>W 0x0</td>
<td>GCDR Reg0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = GPDR bit unaffected</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = GPDR bit clear and GPIO pin is set as input</td>
</tr>
</tbody>
</table>
24.11.2.18  GPIO Pin Bitwise Clear Direction Register 1 (GPIO_GCDR_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GCDR_REG1</td>
<td>0x64</td>
</tr>
</tbody>
</table>

Table 476: GPIO Pin Bitwise Clear Direction Register 1 (GPIO_GCDR_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:0</td>
<td>gcdr_reg1</td>
<td>W 0x0</td>
<td>GCDR Reg1 0x0 = GPDR bit unaffected 0x1 = GPDR bit clear and GPIO pin is set as input</td>
</tr>
</tbody>
</table>

24.11.2.19  GPIO Bitwise Set Rising Edge Detect Enable Register 0 (GPIO_GSRER_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GSRER_REG0</td>
<td>0x6C</td>
</tr>
</tbody>
</table>

Table 477: GPIO Bitwise Set Rising Edge Detect Enable Register 0 (GPIO_GSRER_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>gsrer_reg0</td>
<td>W 0x0</td>
<td>GSERR Reg0 0x0 = GRER bit unaffected 0x1 = GRER bit set</td>
</tr>
</tbody>
</table>

24.11.2.20  GPIO Bitwise Set Rising Edge Detect Enable Register 1 (GPIO_GSRER_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GSRER_REG1</td>
<td>0x70</td>
</tr>
</tbody>
</table>

Table 478: GPIO Bitwise Set Rising Edge Detect Enable Register 1 (GPIO_GSRER_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.11.2.21 GPIO Bitwise Clear Rising Edge Detect Enable Register 0 (GPIO_GCRER_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>gcrer_reg0</td>
<td>W 0x0</td>
<td>GCRER Reg0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = GRER bit unaffected</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = GRER bit clear</td>
</tr>
</tbody>
</table>

### 24.11.22 GPIO Bitwise Clear Rising Edge Detect Enable Register 1 (GPIO_GCRER_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVĐ --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:0</td>
<td>gcrer_reg1</td>
<td>W 0x0</td>
<td>GCRER Reg1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = GRER bit unaffected</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = GRER bit clear</td>
</tr>
</tbody>
</table>
### 24.11.2.23 GPIO Bitwise Set Falling Edge Detect Enable Register 0 (GPIO_GSFER_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GSFER_REG0</td>
<td>0x84</td>
</tr>
</tbody>
</table>

**Table 481: GPIO Bitwise Set Falling Edge Detect Enable Register 0 (GPIO_GSFER_REG0)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0 | gsfer_reg0 | W 0x0       | GSFER Reg0<br>
|      |           |             | 0x0 = GFER bit unaffected<br>
|      |           |             | 0x1 = GFER bit set                               |

### 24.11.2.24 GPIO Bitwise Set Falling Edge Detect Enable Register 1 (GPIO_GSFER_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GSFER_REG1</td>
<td>0x88</td>
</tr>
</tbody>
</table>

**Table 482: GPIO Bitwise Set Falling Edge Detect Enable Register 1 (GPIO_GSFER_REG1)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 17:0 | gsfer_reg1 | W 0x0       | GSFER Reg1<br>
|      |           |             | 0x0 = GFER bit unaffected<br>
|      |           |             | 0x1 = GFER bit set                               |

### 24.11.2.25 GPIO Bitwise Clear Falling Edge Detect Enable Register 0 (GPIO_GCFER_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GCFER_REG0</td>
<td>0x90</td>
</tr>
</tbody>
</table>

**Table 483: GPIO Bitwise Clear Falling Edge Detect Enable Register 0 (GPIO_GCFER_REG0)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0 | gcfer_reg0 | W 0x0       | GCFER Reg0<br>
|      |           |             | 0x0 = GFER bit unaffected<br>
|      |           |             | 0x1 = GFER bit clear                             |
### 24.11.2.26 GPIO Bitwise Clear Falling Edge Detect Enable Register 1 (GPIO_GCFER_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_GCFER_REG1</td>
<td>0x94</td>
</tr>
</tbody>
</table>

#### Table 484: GPIO Bitwise Clear Falling Edge Detect Enable Register 1 (GPIO_GCFER_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:0</td>
<td>gcfer_reg1</td>
<td>W 0x0</td>
<td>GCFER Reg1 0x0 = GFER bit unaffected 0x1 = GFER bit clear</td>
</tr>
</tbody>
</table>

### 24.11.2.27 GPIO Bitwise Mask of Edge Detect Status Register 0 (APMASK_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>APMASK_REG0</td>
<td>0x9C</td>
</tr>
</tbody>
</table>

#### Table 485: GPIO Bitwise Mask of Edge Detect Status Register 0 (APMASK_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>apmask_reg0</td>
<td>R/W 0x0</td>
<td>APMASK Reg0 0x0 = GPIO edge detects are masked 0x1 = GPIO edge detects are not masked</td>
</tr>
</tbody>
</table>

### 24.11.2.28 GPIO Bitwise Mask of Edge Detect Status Register 1 (APMASK_REG1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>APMASK_REG1</td>
<td>0xA0</td>
</tr>
</tbody>
</table>

#### Table 486: GPIO Bitwise Mask of Edge Detect Status Register 1 (APMASK_REG1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### Table 486: GPIO Bitwise Mask of Edge Detect Status Register 1 (APMASK_REG1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 17:0 | apmask_reg1| R/W 0x0      | APMASK Reg1<br>
|      |            |              | 0x0 = GPIO edge detects are masked<br>
|      |            |              | 0x1 = GPIO edge detects are not masked          |
# 24.12 GPT Address Block

## 24.12.1 GPT Register Map

### Table 487: GPT Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x000</td>
<td>CNT_EN_REG</td>
<td>0x0000_0000</td>
<td>Counter Enable Register</td>
<td>Page: 546</td>
</tr>
<tr>
<td>0x020</td>
<td>STS_REG</td>
<td>0x0000_0000</td>
<td>Status Register</td>
<td>Page: 547</td>
</tr>
<tr>
<td>0x024</td>
<td>INT_REG</td>
<td>0x0000_0000</td>
<td>Interrupt Register</td>
<td>Page: 549</td>
</tr>
<tr>
<td>0x028</td>
<td>INT_MSK_REG</td>
<td>0x0301_3F3F</td>
<td>Interrupt Mask Register</td>
<td>Page: 550</td>
</tr>
<tr>
<td>0x040</td>
<td>CNT_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Counter Control Register</td>
<td>Page: 552</td>
</tr>
<tr>
<td>0x050</td>
<td>CNT_VAL_REG</td>
<td>0x0000_0000</td>
<td>Counter Value Register</td>
<td>Page: 552</td>
</tr>
<tr>
<td>0x060</td>
<td>CNT_UPP_VAL_REG</td>
<td>0xFFFF_FFFF</td>
<td>Counter Upper Value Register</td>
<td>Page: 553</td>
</tr>
<tr>
<td>0x080</td>
<td>CLK_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Clock Control Register</td>
<td>Page: 553</td>
</tr>
<tr>
<td>0x088</td>
<td>IC_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Input Capture Control Register</td>
<td>Page: 554</td>
</tr>
<tr>
<td>0x0A0</td>
<td>DMA_CNTL_EN_REG</td>
<td>0x0000_0000</td>
<td>DMA Control Enable Register</td>
<td>Page: 555</td>
</tr>
<tr>
<td>0x0A4</td>
<td>DMA_CNTL_CH_REG</td>
<td>0x0000_0000</td>
<td>DMA Control Channel Register</td>
<td>Page: 555</td>
</tr>
<tr>
<td>0x0D0</td>
<td>ADCT_REG</td>
<td>0x0000_0000</td>
<td>ADC Trigger Control Register</td>
<td>Page: 556</td>
</tr>
<tr>
<td>0x0D8</td>
<td>ADCT_DLY_REG</td>
<td>0x0000_0000</td>
<td>ADC Trigger Delay Register</td>
<td>Page: 556</td>
</tr>
<tr>
<td>0x0F0</td>
<td>USER_REQ_REG</td>
<td>0x0000_0000</td>
<td>User Request Register</td>
<td>Page: 557</td>
</tr>
<tr>
<td>0x200</td>
<td>CH0_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Channel 0 Control Register</td>
<td>Page: 559</td>
</tr>
<tr>
<td>0x210</td>
<td>CH0_CMR0_REG</td>
<td>0x0000_0000</td>
<td>Channel 0 Counter Match Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x214</td>
<td>CH0_STS_REG</td>
<td>0x0000_0000</td>
<td>Channel 0 Status Register</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x220</td>
<td>CH0_CMR1_REG</td>
<td>0x0000_0000</td>
<td>Channel 0 Counter Match Register 1</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x240</td>
<td>CH1_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Channel 1 Control Register</td>
<td>Page: 559</td>
</tr>
<tr>
<td>0x250</td>
<td>CH1_CMR0_REG</td>
<td>0x0000_0000</td>
<td>Channel 1 Counter Match Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x254</td>
<td>CH1_STS_REG</td>
<td>0x0000_0000</td>
<td>Channel 1 Status Register</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x260</td>
<td>CH1_CMR1_REG</td>
<td>0x0000_0000</td>
<td>Channel 1 Counter Match Register 1</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x280</td>
<td>CH2_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Channel 2 Control Register</td>
<td>Page: 559</td>
</tr>
<tr>
<td>0x290</td>
<td>CH2_CMR0_REG</td>
<td>0x0000_0000</td>
<td>Channel 2 Counter Match Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x294</td>
<td>CH2_STS_REG</td>
<td>0x0000_0000</td>
<td>Channel 2 Status Register</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x2A0</td>
<td>CH2_CMR1_REG</td>
<td>0x0000_0000</td>
<td>Channel 2 Counter Match Register 1</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x2C0</td>
<td>CH3_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Channel 3 Control Register</td>
<td>Page: 559</td>
</tr>
</tbody>
</table>
24.12.2 GPT Registers

24.12.2.1 Counter Enable Register (CNT_EN_REG)

Table 487: GPT Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x2D0</td>
<td>CH3_CMR0_REG</td>
<td>0x0000_0000</td>
<td>Channel 3 Counter Match Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x2D4</td>
<td>CH3_STS_REG</td>
<td>0x0000_0000</td>
<td>Channel 3 Status Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x2E0</td>
<td>CH3_CMR1_REG</td>
<td>0x0000_0000</td>
<td>Channel 3 Counter Match Register 1</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x300</td>
<td>CH4_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Channel 4 Control Register</td>
<td>Page: 559</td>
</tr>
<tr>
<td>0x310</td>
<td>CH4_CMR0_REG</td>
<td>0x0000_0000</td>
<td>Channel 4 Counter Match Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x314</td>
<td>CH4_STS_REG</td>
<td>0x0000_0000</td>
<td>Channel 4 Status Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x320</td>
<td>CH4_CMR1_REG</td>
<td>0x0000_0000</td>
<td>Channel 4 Counter Match Register 1</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x340</td>
<td>CH5_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Channel 5 Control Register</td>
<td>Page: 559</td>
</tr>
<tr>
<td>0x350</td>
<td>CH5_CMR0_REG</td>
<td>0x0000_0000</td>
<td>Channel 5 Counter Match Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x354</td>
<td>CH5_STS_REG</td>
<td>0x0000_0000</td>
<td>Channel 5 Status Register 0</td>
<td>Page: 560</td>
</tr>
<tr>
<td>0x360</td>
<td>CH5_CMR1_REG</td>
<td>0x0000_0000</td>
<td>Channel 5 Counter Match Register 1</td>
<td>Page: 560</td>
</tr>
</tbody>
</table>

Instance Name          Offset
CNT_EN_REG             0x000

Table 488: Counter Enable Register (CNT_EN_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:19</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>18</td>
<td>sts_resetn</td>
<td>R 0x0</td>
<td>System Reset Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>CPU must poll this bit for a 1 before accessing any other registers.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = indicates that the system reset is still asserted</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = indicates that the system reset is deasserted</td>
</tr>
<tr>
<td>17</td>
<td>cnt_rst_done</td>
<td>R 0x0</td>
<td>Counter Reset Done Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Writing 1 to CNT_RESET will set this bit to 0 until the counter finishes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>resetting.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = indicates that the counter is still resetting</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = indicates that the counter has been reset</td>
</tr>
<tr>
<td>16</td>
<td>cnt_run</td>
<td>R 0x0</td>
<td>Counter Enabled Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit can be polled to see when the counter is really enabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = counter is disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = counter is enabled</td>
</tr>
</tbody>
</table>
Table 488: Counter Enable Register (CNT_EN_REG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15:3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2</td>
<td>cnt_reset</td>
<td>W 0x0</td>
<td>Counter Reset&lt;br&gt;0x0 = no action&lt;br&gt;0x1 = reset the counter (counter is reset to 0; channel output states are reset to 0; poll CNT_RST_DONE for 1 before writing to any other registers)</td>
</tr>
<tr>
<td>1</td>
<td>cnt_stop</td>
<td>W 0x0</td>
<td>Counter Stop&lt;br&gt;0x0 = no action&lt;br&gt;0x1 = disable the counter (poll CNT_RUN for 0 to confirm that the counter is disabled internally)</td>
</tr>
<tr>
<td>0</td>
<td>cnt_start</td>
<td>W 0x0</td>
<td>Counter Start&lt;br&gt;0x0 = no action&lt;br&gt;0x1 = enable the counter (poll CNT_RUN for 1 to confirm that the counter is enabled internally)</td>
</tr>
</tbody>
</table>

24.12.2.2 Status Register (STS_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS_REG</td>
<td>0x020</td>
</tr>
</tbody>
</table>

Table 489: Status Register (STS_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:26</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>25</td>
<td>dma1_of_sts.</td>
<td>R/W1CLR 0x0</td>
<td>See DMA0_OF_STS</td>
</tr>
<tr>
<td>24</td>
<td>dma0_of_sts.</td>
<td>R/W1CLR 0x0</td>
<td>DMA Overflow Status&lt;br&gt;0x0 = status cleared&lt;br&gt;0x1 = indicates that there has been a new input capture before this DMA channel could transfer the captured data away</td>
</tr>
<tr>
<td>23:17</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>16</td>
<td>cnt_upp_sts</td>
<td>R/W1CLR 0x0</td>
<td>Counter-Reach-Upper Status&lt;br&gt;Indicates that the counter has reached UPP_VAL when incrementing.</td>
</tr>
<tr>
<td>15:14</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### Table 489: Status Register (STS_REG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13</td>
<td>ch5_err_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 5 Error Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = an error has occurred in this channel</td>
</tr>
<tr>
<td>12</td>
<td>ch4_err_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 4 Error Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = an error has occurred in this channel</td>
</tr>
<tr>
<td>11</td>
<td>ch3_err_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 3 Error Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = an error has occurred in this channel</td>
</tr>
<tr>
<td>10</td>
<td>ch2_err_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 2 Error Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = an error has occurred in this channel</td>
</tr>
<tr>
<td>9</td>
<td>ch1_err_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 1 Error Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = an error has occurred in this channel</td>
</tr>
<tr>
<td>8</td>
<td>ch0_err_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 0 Error Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = an error has occurred in this channel</td>
</tr>
<tr>
<td>7:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>ch5_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 5 Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = status bit for this channel has been set</td>
</tr>
<tr>
<td>4</td>
<td>ch4_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 4 Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = status bit for this channel has been set</td>
</tr>
<tr>
<td>3</td>
<td>ch3_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 3 Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = status bit for this channel has been set</td>
</tr>
<tr>
<td>2</td>
<td>ch2_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 2 Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = status bit for this channel has been set</td>
</tr>
<tr>
<td>1</td>
<td>ch1_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 1 Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = status bit for this channel has been set</td>
</tr>
<tr>
<td>0</td>
<td>ch0_sts</td>
<td>R/W1CLR 0x0</td>
<td>Channel 0 Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = status cleared</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = status bit for this channel has been set</td>
</tr>
</tbody>
</table>
24.12.2.3 Interrupt Register (INT_REG)

INT_MSK_REG is combined with STS_REG to form this register. Masked bits will be 0 while unmasked bits will be the same value as the ones in STS_REG.

If any bits in this register is 1, an interrupt will be generated.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_REG</td>
<td>0x024</td>
</tr>
</tbody>
</table>

Table 490: Interrupt Register (INT_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:26</td>
<td>Reserved</td>
<td>RSV</td>
<td>D --</td>
</tr>
<tr>
<td>25</td>
<td>dma1_of_intr</td>
<td>R 0x0</td>
<td>Masked Signal of DMA1_OF_STS</td>
</tr>
<tr>
<td>24</td>
<td>dma0_of_intr</td>
<td>R 0x0</td>
<td>Masked Signal of DMA0_OF_STS</td>
</tr>
<tr>
<td>23:17</td>
<td>Reserved</td>
<td>RSV</td>
<td>D --</td>
</tr>
<tr>
<td>16</td>
<td>cnt_upp_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CNT_UPP_STS</td>
</tr>
<tr>
<td>15:14</td>
<td>Reserved</td>
<td>RSV</td>
<td>D --</td>
</tr>
<tr>
<td>13</td>
<td>ch5_err_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH5_ERR_STS</td>
</tr>
<tr>
<td>12</td>
<td>ch4_err_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH4_ERR_STS</td>
</tr>
<tr>
<td>11</td>
<td>ch3_err_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH3_ERR_STS</td>
</tr>
<tr>
<td>10</td>
<td>ch2_err_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH2_ERR_STS</td>
</tr>
<tr>
<td>9</td>
<td>ch1_err_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH1_ERR_STS</td>
</tr>
<tr>
<td>8</td>
<td>ch0_err_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH0_ERR_STS</td>
</tr>
<tr>
<td>7:6</td>
<td>Reserved</td>
<td>RSV</td>
<td>D --</td>
</tr>
<tr>
<td>5</td>
<td>ch5_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH5_STS</td>
</tr>
<tr>
<td>4</td>
<td>ch4_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CH4_STS</td>
</tr>
</tbody>
</table>
24.12.2.4 Interrupt Mask Register (INT_MSK_REG)

INT_MSK_REG is combined with STS_REG to form INT_REG. Masked bits will be 0 while unmasked bits will be the same value as the ones in STS_REG.

### Table 491: Interrupt Mask Register (INT_MSK_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:26</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>25</td>
<td>dma1_of_msk</td>
<td>R/W 0x1</td>
<td>See DMA0_OF_MSK</td>
</tr>
<tr>
<td>24</td>
<td>dma0_of_msk</td>
<td>R/W 0x1</td>
<td>DMA Channel Overflow Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask DMA0_OF_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask DMA0_OF_STS</td>
</tr>
<tr>
<td>23:17</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>16</td>
<td>cnt_upp_msk</td>
<td>R/W 0x1</td>
<td>Upper Value Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CNT_UPP_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CNT_UPP_STS</td>
</tr>
<tr>
<td>15:14</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>13</td>
<td>ch5_err_msk</td>
<td>R/W 0x1</td>
<td>Channel Error Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH5_ERR_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH5_ERR_STS</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>------</td>
<td>-------------</td>
<td>-------------</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td>12</td>
<td>ch4_err_msk</td>
<td>R/W 0x1</td>
<td>Channel Error Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH4_ERR_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH4_ERR_STS</td>
</tr>
<tr>
<td>11</td>
<td>ch3_err_msk</td>
<td>R/W 0x1</td>
<td>Channel Error Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH3_ERR_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH3_ERR_STS</td>
</tr>
<tr>
<td>10</td>
<td>ch2_err_msk</td>
<td>R/W 0x1</td>
<td>Channel Error Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH2_ERR_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH2_ERR_STS</td>
</tr>
<tr>
<td>9</td>
<td>ch1_err_msk</td>
<td>R/W 0x1</td>
<td>Channel Error Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH1_ERR_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH1_ERR_STS</td>
</tr>
<tr>
<td>8</td>
<td>ch0_err_msk</td>
<td>R/W 0x1</td>
<td>Channel Error Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH0_ERR_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH0_ERR_STS</td>
</tr>
<tr>
<td>7:6</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>ch5_msk</td>
<td>R/W 0x1</td>
<td>Channel Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH5_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH5_STS</td>
</tr>
<tr>
<td>4</td>
<td>ch4_msk</td>
<td>R/W 0x1</td>
<td>Channel Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH4_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH4_STS</td>
</tr>
<tr>
<td>3</td>
<td>ch3_msk</td>
<td>R/W 0x1</td>
<td>Channel Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH3_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH3_STS</td>
</tr>
<tr>
<td>2</td>
<td>ch2_msk</td>
<td>R/W 0x1</td>
<td>Channel Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH2_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH2_STS</td>
</tr>
<tr>
<td>1</td>
<td>ch1_msk</td>
<td>R/W 0x1</td>
<td>Channel Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH1_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH1_STS</td>
</tr>
<tr>
<td>0</td>
<td>ch0_msk</td>
<td>R/W 0x1</td>
<td>Channel Interrupt Mask</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not mask CH0_STS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = mask CH0_STS</td>
</tr>
</tbody>
</table>
24.12.2.5 Counter Control Register (CNT_CNTL_REG)

Table 492: Counter Control Register (CNT_CNTL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 9:8    | cnt_updt_mod  | R/W 0x0      | Counter Value Update Mode  
0x0 = Auto-update normal (can be used for any clock relationship between the counter clock and the APB clock; only every 3-4 counter ticks are updated to CNT_VAL)  
0x1 = Auto-update fast (use when counter clock is at least 5 times slower than the APB clock; every counter tick is updated to CNT_VAL)  
0x2 = reserved  
0x3 = update off (of CNT_VAL does not need to be read, CNT_UPDT_MOD can be set to off to save power) |
| 7:5    | Reserved      | RSVD         | Reserved. Always write 0. Ignore read value.                                |
| 4      | cnt_dbg_act   | R/W 0x0      | Counter Debug Mode Action Mask  
0x0 = in debug mode, stop the counter  
0x1 = in debug mode, the counter is not affected |
| 3:0    | Reserved      | RSVD         | Reserved. Always write 0. Ignore read value.                                |

24.12.2.6 Counter Value Register (CNT_VAL_REG)

Table 493: Counter Value Register (CNT_VAL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0 | cnt_val| R 0x0        | Counter Value  
This register is used to view the current value of the main counter.  
The update of this register is based on CNT_UPDT_MOD. |
24.12.2.7 Counter Upper Value Register (CNT_UPP_VAL_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CNT_UPP_VAL_REG</td>
<td>0x060</td>
</tr>
</tbody>
</table>

Table 494: Counter Upper Value Register (CNT_UPP_VAL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0 | upp_val | R/W 0xFFFF_ FFFF | Counter Upper Value  
Do not set to 0. The reset value is the maximum value of the counter, where all bits are 1.  
In the event that the counter reaches this value (counter-reach-upper), the counter will overflow to 0. Setting this value to all 1s is equivalent to a free running up-counter.  
Writing to this register will shadow it and start the internal shadow register update. The update finishes during the next counter-reach-upper event and will continue to update if it detects a new UPP_VAL. To guarantee an immediate update with the current UPP_VAL, write 1 to CNT_RESET. |

24.12.2.8 Clock Control Register (CLK_CNTL_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK_CNTL_REG</td>
<td>0x080</td>
</tr>
</tbody>
</table>

Table 495: Clock Control Register (CLK_CNTL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 23:16 | clk_pre | R/W 0x0 | Clock Pre-Scalar  
This can be used together with CLK_DIV. The frequency of the prescaled clock (f_pre) is calculated from the frequency of the counter clock (f_clk) using this formula:  
f_pre = f_clk / (CLK_PRE + 1) |
| 15:12 | Reserved | RSVD -- | Reserved. Always write 0. Ignore read value. |
| 11:8 | clk_div | R/W 0x0 | Clock Divider  
This can be used together with CLK_PRE. The frequency of the divided clock (f_div) is calculated from the frequency of the counter clock (f_clk) using this formula:  
f_div = f_clk / (2 ^ CLK_DIV) |
| 7:1 | Reserved | RSVD -- | Reserved. Always write 0. Ignore read value. |
### Input Capture Control Register (IC_CNTL_REG)

#### Table 495: Clock Control Register (CLK_CNTL_REG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>clk_src</td>
<td>R/W 0x0</td>
<td>Counter Clock Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = select clock 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = select clock 1</td>
</tr>
</tbody>
</table>

#### Table 496: Input Capture Control Register (IC_CNTL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6:4</td>
<td>chx_ic_div</td>
<td>R/W 0x0</td>
<td>Input Capture Sampling Clock Divider</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This field divides the sampling clock used to sample the input trigger.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The frequency of the divided sampling clock( f_sdiv) is calculated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>from the frequency of the sampling clock (f_sclk) using the following formula:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>( f_{sdiv} = f_{sclk} / (2^{CHx_IC_DIV}) )</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2:0</td>
<td>chx_ic_width</td>
<td>R/W 0x0</td>
<td>Input Capture Filter Width</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The input trigger must be sampled for this many consecutive cycles before it is considered a valid edge. Any glitch pulse shorter than this many cycles will be filtered.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no filtering (1 cycle)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 2 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 3 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 4 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = 5 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = 6 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = 7 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = reserved</td>
</tr>
</tbody>
</table>
24.12.2.10 DMA Control Enable Register (DMA_CNTL_EN_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMA_CNTL_EN_REG</td>
<td>0x0A0</td>
</tr>
</tbody>
</table>

Table 497: DMA Control Enable Register (DMA_CNTL_EN_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>dma1_en</td>
<td>R/W 0x0</td>
<td>See DMA0_EN</td>
</tr>
<tr>
<td>0</td>
<td>dma0_en</td>
<td>R/W 0x0</td>
<td>DMA Channel Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable this DMA channel</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable this DMA channel. In input capture mode, DMA controller will</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>be notified when a value is captured.</td>
</tr>
</tbody>
</table>

24.12.2.11 DMA Control Channel Register (DMA_CNTL_CH_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMA_CNTL_CH_REG</td>
<td>0x0A4</td>
</tr>
</tbody>
</table>

Table 498: DMA Control Channel Register (DMA_CNTL_CH_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6:4</td>
<td>dma1_ch</td>
<td>R/W 0x0</td>
<td>See DMA0_CH</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2:0</td>
<td>dma0_ch</td>
<td>R/W 0x0</td>
<td>DMA Channel Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Select the counter channel to which this DMA channel is connected.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = connect to channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = connect to channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = connect to channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = connect to channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = connect to channel 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = connect to channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
</tbody>
</table>
24.12.2.12 ADC Trigger Control Register (ADCT_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADCT_REG</td>
<td>0x0D0</td>
</tr>
</tbody>
</table>

Table 499: ADC Trigger Control Register (ADCT_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:9</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>8</td>
<td>adct_en</td>
<td>R/W 0x0</td>
<td>ADC Trigger Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable the ADC trigger</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable the ADC trigger</td>
</tr>
<tr>
<td>7:3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2:0</td>
<td>adct_chsel</td>
<td>R/W 0x0</td>
<td>ADC Trigger Channel Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Select which counter channel to multiplex to the ADC trigger.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = connect to channel 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = connect to channel 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = connect to channel 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = connect to channel 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = connect to channel 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = connect to channel 5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
</tbody>
</table>

24.12.2.13 ADC Trigger Delay Register (ADCT_DLY_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADCT_DLY_REG</td>
<td>0x0D8</td>
</tr>
</tbody>
</table>

Table 500: ADC Trigger Delay Register (ADCT_DLY_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>adct_dly</td>
<td>R/W 0x0</td>
<td>ADC Trigger Delay</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>At the end of each PWM period, after the effective ADC trigger delay (adly_eff), a trigger will be generated to signal the ADC to begin a conversion.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>adly_eff is 4 times ADCT_DLY, as shown below:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>adly_eff = ADCT_DLY x 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>For the ADC trigger to work properly, adly_eff must be shorter than the PWM period. The PWM period must be longer than the ADC conversion period, with appropriate margins.</td>
</tr>
</tbody>
</table>
### 24.12.2.14 User Request Register (USER_REQ_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>USER_REQ_REG</td>
<td>0x0F0</td>
</tr>
</tbody>
</table>

Table 501: User Request Register (USER_REQ_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:22</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>21</td>
<td>ch5_cmr_updt</td>
<td>W 0x0</td>
<td>See CH0_CMR_UPDT</td>
</tr>
<tr>
<td>20</td>
<td>ch4_cmr_updt</td>
<td>W 0x0</td>
<td>See CH0_CMR_UPDT</td>
</tr>
<tr>
<td>19</td>
<td>ch3_cmr_updt</td>
<td>W 0x0</td>
<td>See CH0_CMR_UPDT</td>
</tr>
<tr>
<td>18</td>
<td>ch2_cmr_updt</td>
<td>W 0x0</td>
<td>See CH0_CMR_UPDT</td>
</tr>
<tr>
<td>17</td>
<td>ch1_cmr_updt</td>
<td>W 0x0</td>
<td>See CH0_CMR_UPDT</td>
</tr>
</tbody>
</table>
| 16   | ch0_cmr_updt | W 0x0        | Channel CMR Update
Write to this field to update CMR0 and CMR1 to the internal shadow registers. Writing to this field before the internal update is done will cause the second update to be discarded, and CH0_ERR_STS will be set.
In PWM or One-shot mode, the internal update occurs at the end of period or when idle.
In any other channel mode, the CMR update completes immediately.
In any channel mode, the CMR update completes immediately if there is a counter or channel reset.
0x0 = no action
0x1 = update CMR0 and CMR1 to the internal shadow registers |
| 15:14| Reserved     | RSVD --      | Reserved. Always write 0. Ignore read value.                                |
| 13   | ch5_rst      | W 0x0        | See CH0_RST                                                                |
| 12   | ch4_rst      | W 0x0        | See CH0_RST                                                                |
| 11   | ch3_rst      | W 0x0        | See CH0_RST                                                                |
| 10   | ch2_rst      | W 0x0        | See CH0_RST                                                                |
| 9    | ch1_rst      | W 0x0        | See CH0_RST                                                                |
### 24.12.2.15 Channel X Control Register (CHx_CNTL_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CH0_CNTL_REG</td>
<td>0x200</td>
</tr>
<tr>
<td>CH1_CNTL_REG</td>
<td>0x240</td>
</tr>
<tr>
<td>CH2_CNTL_REG</td>
<td>0x280</td>
</tr>
<tr>
<td>CH3_CNTL_REG</td>
<td>0x2C0</td>
</tr>
<tr>
<td>CH4_CNTL_REG</td>
<td>0x300</td>
</tr>
<tr>
<td>CH5_CNTL_REG</td>
<td>0x340</td>
</tr>
</tbody>
</table>

---

Table 501: User Request Register (USER_REQ_REG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/W Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 8    | ch0_rst       | W 0x0      | Channel Reset
|      |               |            | Writing 1 to this register will reset the channel and kick start the corresponding mode determined by CHx_IO. Only write to this field when CNT_RUN is set.   |
|      |               |            | In One-shot pulse mode, the output state will be reset, and a pulse will occur.                                                                                                                           |
|      |               |            | In One-shot edge mode, an edge transition will occur, but the output state will NOT be reset.                                                                                                            |
|      |               |            | In all other modes, the output state will be reset. Resetting multiple channels in the same APB write will synchronize the start periods of the PWM and One-shot outputs. |
|      |               |            | 0x0 = no action                                                                                                                                          |
|      |               |            | 0x1 = reset this channel                                                                                                                                    |
| 7:6 | Reserved      | RSVD --    | Reserved. Always write 0. Ignore read value.                                                                                                                     |
| 5   | ch5_user_itrig| W 0x0      | See CH0_USER_ITRIG                                                                                                                                 |
| 4   | ch4_user_itrig| W 0x0      | See CH0_USER_ITRIG                                                                                                                                 |
| 3   | ch3_user_itrig| W 0x0      | See CH0_USER_ITRIG                                                                                                                                 |
| 2   | ch2_user_itrig| W 0x0      | See CH0_USER_ITRIG                                                                                                                                 |
| 1   | ch1_user_itrig| W 0x0      | See CH0_USER_ITRIG                                                                                                                                 |
| 0   | ch0_user_itrig| W 0x0      | User Input Trigger
|      |               |            | 0x0 = no action                                                                                                                                          |
|      |               |            | 0x1 = if this channel (channel 0) is configured to input-capture mode, generate a manual input trigger to capture the current counter value (this trigger bypasses the input capture control settings) |
### Table 502: Channel X Control Register (CHx_CNTL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:17</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>16</td>
<td>pol</td>
<td>R/W 0x0</td>
<td>Channel Polarity&lt;br&gt;Default output state of this channel after reset. This field determines the waveform polarity in PWM mode and one-shot mode,&lt;br&gt;0x0 = reset to 0&lt;br&gt;0x1 = reset to 1</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>14:12</td>
<td>ic_edge</td>
<td>R/W 0x0</td>
<td>Channel Input Capture Edge&lt;br&gt;Determines which edge of the input trigger to capture.&lt;br&gt;0x0 = capture rising edge in CMR0&lt;br&gt;0x1 = capture falling edge in CMR0</td>
</tr>
<tr>
<td>11:3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2:0</td>
<td>chx_io</td>
<td>R/W 0x0</td>
<td>Channel Mode&lt;br&gt;0x0 = no function&lt;br&gt;0x1 = input capture mode&lt;br&gt;0x4 = One-shot mode (pulse)&lt;br&gt;0x5 = One-shot mode (edge)&lt;br&gt;0x6 = PWM mode (edge-aligned)&lt;br&gt;0x7 = PWM mode (center-aligned)&lt;br&gt;others = reserved</td>
</tr>
</tbody>
</table>

### 24.12.2.16 Channel Counter Match Register 0 (CHx_CMR0_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CH0_CMR0_REG</td>
<td>0x210</td>
</tr>
<tr>
<td>CH1_CMR0_REG</td>
<td>0x250</td>
</tr>
<tr>
<td>CH2_CMR0_REG</td>
<td>0x290</td>
</tr>
<tr>
<td>CH3_CMR0_REG</td>
<td>0x2D0</td>
</tr>
<tr>
<td>CH4_CMR0_REG</td>
<td>0x310</td>
</tr>
<tr>
<td>CH5_CMR0_REG</td>
<td>0x350</td>
</tr>
</tbody>
</table>
### 24.12.2.17 Channel Status Register 0 (CHx_STS_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CH0_STS_REG</td>
<td>0x214</td>
</tr>
<tr>
<td>CH1_STS_REG</td>
<td>0x254</td>
</tr>
<tr>
<td>CH2_STS_REG</td>
<td>0x294</td>
</tr>
<tr>
<td>CH3_STS_REG</td>
<td>0x2D4</td>
</tr>
<tr>
<td>CH4_STS_REG</td>
<td>0x314</td>
</tr>
<tr>
<td>CH5_STS_REG</td>
<td>0x354</td>
</tr>
</tbody>
</table>

#### Table 504: Channel Status Register 0 (CHx_STS_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>out_st</td>
<td>R 0x0</td>
<td>Channel Output State Displays the current output state of this channel.</td>
</tr>
</tbody>
</table>

### 24.12.2.18 Channel Counter Match Register 1 (CHx_CMR1_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CH0_CMR1_REG</td>
<td>0x220</td>
</tr>
<tr>
<td>CH1_CMR1_REG</td>
<td>0x260</td>
</tr>
<tr>
<td>CH2_CMR1_REG</td>
<td>0x2A0</td>
</tr>
<tr>
<td>CH3_CMR1_REG</td>
<td>0x2E0</td>
</tr>
<tr>
<td>CH4_CMR1_REG</td>
<td>0x320</td>
</tr>
<tr>
<td>CH5_CMR1_REG</td>
<td>0x360</td>
</tr>
</tbody>
</table>
### Table 505: Channel Counter Match Register 1 (CHx_CMR1_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:0  | cmr1  | R/W 0x0      | Channel Counter Match Register 1  
In order for the counter to use CMR0 and CMR1, write to CHx_CM0_UPDT to update CMR0 and CMR1 to the internal shadow registers.  
In any PWM mode, setting both CMR0 and CMR1 to 0 will result in a degenerate case that shuts off the PWM generator. To reset the PWM, set at least one of CMR0 or CMR1 to a non-zero value and write to CHx_RST. |
24.13 RC32 Address Block

24.13.1 RC32 Register Map

Table 506: RC32 Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>ctrl</td>
<td>0x0000_07F1</td>
<td>Control Register</td>
<td>Page: 562</td>
</tr>
<tr>
<td>0x04</td>
<td>status</td>
<td>0x0000_0000</td>
<td>Status Register</td>
<td>Page: 563</td>
</tr>
<tr>
<td>0x08</td>
<td>isr</td>
<td>0x0000_0000</td>
<td>Interrupt Status Register</td>
<td>Page: 563</td>
</tr>
<tr>
<td>0x0C</td>
<td>imr</td>
<td>0x0000_0003</td>
<td>Interrupt Mask Register</td>
<td>Page: 564</td>
</tr>
<tr>
<td>0x10</td>
<td>isr</td>
<td>0x0000_0000</td>
<td>Interrupt Raw Status Register</td>
<td>Page: 564</td>
</tr>
<tr>
<td>0x14</td>
<td>icr</td>
<td>0x0000_0000</td>
<td>Interrupt Clear Register</td>
<td>Page: 565</td>
</tr>
<tr>
<td>0x18</td>
<td>clk</td>
<td>0x0000_0004</td>
<td>Clock Register</td>
<td>Page: 565</td>
</tr>
<tr>
<td>0x1C</td>
<td>rst</td>
<td>0x0000_0000</td>
<td>Soft Reset Register</td>
<td>Page: 566</td>
</tr>
</tbody>
</table>

24.13.2 RC32 Registers

24.13.2.1 Control Register (ctrl)

Table 507: Control Register (ctrl)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ctrl</td>
<td>0x00</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:14</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
<td>R/W 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>4</td>
<td>code_fr_ext</td>
<td>R/W 0x7F</td>
<td>External Code Input for Calibration</td>
</tr>
<tr>
<td>3</td>
<td>pd</td>
<td>R/W 0x0</td>
<td>Clock Power Down 0x0 = power up 0x1 = power down</td>
</tr>
<tr>
<td>2</td>
<td>ext_code_en</td>
<td>R/W 0x0</td>
<td>Calibration Code from External Enable 0x0 = calibration code from internal 0x1 = calibration code from external</td>
</tr>
</tbody>
</table>
Table 507: Control Register (ctrl) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 1    | cal_en | R/W 0x0      | Calibration Enable  
0x0 = disable  
0x1 = enable |
| 0    | en     | R/W 0x1      | Calibration Reference Clock Enable  
0x0 = disable  
0x1 = enable |

24.13.2.2 Status Register (status)

Table 508: Status Register (status)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9:2</td>
<td>code_fr_cal</td>
<td>R 0x0</td>
<td>Calibration Code</td>
</tr>
</tbody>
</table>
| 1    | cal_done    | R 0x0        | Calibration Finish Flag  
0x0 = calibration not done  
0x1 = calibration done |
| 0    | clk_rdy     | R 0x0        | Clock Ready  
1 indicates whether HFRC clock is ready. |

24.13.2.3 Interrupt Status Register (isr)

Table 509: Interrupt Status Register (isr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.13.2.4 Interrupt Mask Register (imr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>ckrdy_int</td>
<td>R 0x0</td>
<td>Clock Ready Interrupt 1 indicates clock out ready interrupt flag if ckrdy_int_raw is not masked.</td>
</tr>
<tr>
<td>0</td>
<td>caldon_int</td>
<td>R 0x0</td>
<td>Calibration Done Interrupt 1 indicates calibration done interrupt flag if caldon_int_raw is not masked.</td>
</tr>
</tbody>
</table>

### 24.13.2.5 Interrupt Raw Status Register (irsr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>ckrdy_int</td>
<td>R/W 0x1</td>
<td>Clock Ready Interrupt Raw Set to 1 to mask off clock ready interrupt.</td>
</tr>
<tr>
<td>0</td>
<td>caldon_int</td>
<td>R/W 0x1</td>
<td>Calibration Done Interrupt Raw Set to 1 to mask off calibration done interrupt.</td>
</tr>
</tbody>
</table>
24.13.2.6  Interrupt Clear Register (icr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>icr</td>
<td>0x14</td>
</tr>
</tbody>
</table>

Table 512: Interrupt Clear Register (icr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>ckrdy_int_clr</td>
<td>R/W 0x0</td>
<td>Clock Ready Interrupt Clear</td>
</tr>
<tr>
<td>0</td>
<td>caldon_int_clr</td>
<td>R/W 0x0</td>
<td>Calibration Done Interrupt Raw</td>
</tr>
</tbody>
</table>

24.13.2.7  Clock Register (clk)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>clk</td>
<td>0x18</td>
</tr>
</tbody>
</table>

Table 513: Clock Register (clk)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3</td>
<td>soft_clk_rst</td>
<td>R/W 0x0</td>
<td>Soft Reset for Clock Divider</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no action</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = Reset</td>
</tr>
<tr>
<td>2</td>
<td>ref_sel</td>
<td>R/W 0x1</td>
<td>Reference Clock Frequency Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = half-divided reference clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = original reference clock</td>
</tr>
<tr>
<td>1:0</td>
<td>Reserved</td>
<td>R/W 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
</tbody>
</table>

24.13.2.8  Soft Reset Register (rst)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>rst</td>
<td>0x1C</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
</tr>
<tr>
<td>---------</td>
<td>-------</td>
</tr>
<tr>
<td>31:1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>soft_rst</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Table 515: ADC Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>adc_reg_cmd</td>
<td>0x0000_0000</td>
<td>ADC Command Register</td>
<td>Page: 568</td>
</tr>
<tr>
<td>0x04</td>
<td>adc_reg_general</td>
<td>0x0000_0001</td>
<td>ADC General Register</td>
<td>Page: 568</td>
</tr>
<tr>
<td>0x08</td>
<td>adc_reg_config</td>
<td>0x0000_0100</td>
<td>ADC Configuration Register</td>
<td>Page: 569</td>
</tr>
<tr>
<td>0x0C</td>
<td>adc_reg_interval</td>
<td>0x0000_00F</td>
<td>ADC Interval Register</td>
<td>Page: 571</td>
</tr>
<tr>
<td>0x10</td>
<td>adc_reg_ana</td>
<td>0x0000_A810</td>
<td>ADC ANA Register</td>
<td>Page: 571</td>
</tr>
<tr>
<td>0x18</td>
<td>adc_reg_scn1</td>
<td>0x0000_0000</td>
<td>ADC Conversion Sequence 1 Register</td>
<td>Page: 573</td>
</tr>
<tr>
<td>0x1C</td>
<td>adc_reg_scn2</td>
<td>0x0000_0000</td>
<td>ADC Conversion Sequence 2 Register</td>
<td>Page: 574</td>
</tr>
<tr>
<td>0x20</td>
<td>adc_reg_result_buf</td>
<td>0x0000_0000</td>
<td>ADC Result Buffer Register</td>
<td>Page: 574</td>
</tr>
<tr>
<td>0x28</td>
<td>adc_reg_dmar</td>
<td>0x0000_0000</td>
<td>ADC DMAR Register</td>
<td>Page: 575</td>
</tr>
<tr>
<td>0x2C</td>
<td>adc_reg_status</td>
<td>0x0000_0000</td>
<td>ADC Status Register</td>
<td>Page: 575</td>
</tr>
<tr>
<td>0x30</td>
<td>adc_reg_isr</td>
<td>0x0000_0000</td>
<td>ADC ISR Register</td>
<td>Page: 576</td>
</tr>
<tr>
<td>0x34</td>
<td>adc_reg_imr</td>
<td>0x0000_007F</td>
<td>ADC IMR Register</td>
<td>Page: 576</td>
</tr>
<tr>
<td>0x38</td>
<td>adc_reg_isr</td>
<td>0x0000_0000</td>
<td>ADC IRSR Register</td>
<td>Page: 577</td>
</tr>
<tr>
<td>0x3C</td>
<td>adc_reg_icr</td>
<td>0x0000_0000</td>
<td>ADC ICR Register</td>
<td>Page: 578</td>
</tr>
<tr>
<td>0x44</td>
<td>adc_reg_result</td>
<td>0x0000_0000</td>
<td>ADC Result Register</td>
<td>Page: 579</td>
</tr>
<tr>
<td>0x48</td>
<td>adc_reg_raw_result</td>
<td>0x0000_0000</td>
<td>ADC Raw Result Register</td>
<td>Page: 579</td>
</tr>
<tr>
<td>0x4C</td>
<td>adc_reg_offset_cal</td>
<td>0x0000_0000</td>
<td>ADC Offset Calibration Register</td>
<td>Page: 579</td>
</tr>
<tr>
<td>0x50</td>
<td>adc_reg_gain_cal</td>
<td>0x0000_0000</td>
<td>ADC Gain Calibration Register</td>
<td>Page: 580</td>
</tr>
<tr>
<td>0x54</td>
<td>adc_reg_test</td>
<td>0x0000_0000</td>
<td>ADC Test Register</td>
<td>Page: 580</td>
</tr>
<tr>
<td>0x58</td>
<td>adc_reg_audio</td>
<td>0x0000_0300</td>
<td>ADC Audio Register</td>
<td>Page: 580</td>
</tr>
<tr>
<td>0x5C</td>
<td>adc_reg_voice_det</td>
<td>0x0000_0000</td>
<td>ADC Voice Detect Register</td>
<td>Page: 581</td>
</tr>
<tr>
<td>0x60</td>
<td>adc_reg_rsvd</td>
<td>0x0000_FF00</td>
<td>ADC Reserved Register</td>
<td>Page: 582</td>
</tr>
</tbody>
</table>
24.14.2 ADC Registers

24.14.2.1 ADC Command Register (adc_reg_cmd)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_cmd</td>
<td>0x00</td>
</tr>
</tbody>
</table>

Table 516: ADC Command Register (adc_reg_cmd)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2</td>
<td>soft_clk_rst</td>
<td>R/W 0x0</td>
<td>User Reset Clock</td>
</tr>
<tr>
<td>1</td>
<td>soft_rst</td>
<td>R/W 0x0</td>
<td>User Reset the Whole Block</td>
</tr>
<tr>
<td>0</td>
<td>conv_start</td>
<td>R/W 0x0</td>
<td>Conversion Control 0x0 = stop conversion 0x1 = start conversion (this will clear the FIFO)</td>
</tr>
</tbody>
</table>

24.14.2.2 ADC General Register (adc_reg_general)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_general</td>
<td>0x04</td>
</tr>
</tbody>
</table>

Table 517: ADC General Register (adc_reg_general)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:14</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>13:8</td>
<td>clk_div_ratio</td>
<td>R/W 0x0</td>
<td>Analog 64M Clock Division Ratio 0x00 = divide by 1 0x01 = divide by 1 0x02 = divide by 2 ... 0x0F = divide by 15 ... 0x20 = divide by the 32</td>
</tr>
<tr>
<td>7:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### ADC Configuration Register (adc_reg_config)

#### Table 517: ADC General Register (adc_reg_general) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>adc_cal_en</td>
<td>R/W 0x0</td>
<td>Calibration Enable, Auto Cleared After Calibration Done</td>
</tr>
<tr>
<td>4</td>
<td>clk_an2m_inv</td>
<td>R/W 0x0</td>
<td>Analog Clock 2M Inverted</td>
</tr>
<tr>
<td>3</td>
<td>clk_an64m_inv</td>
<td>R/W 0x0</td>
<td>Analog Clock 64M Inverted</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td>R/W 0x0</td>
<td>Reserved. Always write 1. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>global_en</td>
<td>R/W 0x0</td>
<td>ADC Enable/disable</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td>R/W 0x1</td>
<td>Reserved. Always write 1. Ignore read value.</td>
</tr>
</tbody>
</table>

#### Table 518: ADC Configuration Register (adc_reg_config)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_config</td>
<td>0x08</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:21</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>20</td>
<td>pwr_mode</td>
<td>R/W 0x0</td>
<td>ADC Power Mode Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = power mode 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Analog biasing and reference block are powered up when both global_en and</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>gpadc_conv_start is 1.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = power mode 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Analog biasing and reference block are powered up once gpadc_global_en is 1.</td>
</tr>
<tr>
<td>19:16</td>
<td>scan_length</td>
<td>R/W 0x0</td>
<td>Scan Conversion Length (actual Length Is scan_length+1)</td>
</tr>
<tr>
<td>15:13</td>
<td>avg_sel</td>
<td>R/W 0x0</td>
<td>Moving Average Length</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no average</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = average by 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = average by 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = average by 8</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = average by 16</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
</tbody>
</table>

24.14.2.3 ADC Configuration Register (adc_reg_config)
### Table 518: ADC Configuration Register (adc_reg_config) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12</td>
<td>cal_data_sel</td>
<td>R/W 0x0</td>
<td>Select Calibration Data Source</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = use self calibration data</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = user defined calibration data</td>
</tr>
<tr>
<td>11</td>
<td>cal_data_rst</td>
<td>R/W 0x0</td>
<td>Reset the Self Calibration Data</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no reset</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = reset</td>
</tr>
<tr>
<td>10</td>
<td>cal_vref_sel</td>
<td>R/W 0x0</td>
<td>Select Input Reference Channel for Gain Calibration</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = select internal vref as input for calibration</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = select external vref as input for calibration</td>
</tr>
<tr>
<td>9</td>
<td>data_format_sel</td>
<td>R/W 0x0</td>
<td>Set Data Format for the Final Data</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = signed differential code in 2’s complement</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = unsigned single-end code</td>
</tr>
<tr>
<td>8</td>
<td>cont_conv_en</td>
<td>R/W 0x1</td>
<td>To Enable Continuous Conversion</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 1-shot conversion</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = continuous conversion</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td>RSV0</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6:5</td>
<td>Reserved</td>
<td>R/W 0x0</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>trigger_en</td>
<td>R/W 0x0</td>
<td>External Level Trigger Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Supports gpadc_trigger/gpadc_data_valid handshake.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = conversion start further controlled by external level signal</td>
</tr>
<tr>
<td>3:0</td>
<td>trigger_sel</td>
<td>R/W 0x0</td>
<td>External Trigger Source Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = gpadc_trigger[0] . gpt 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = gpadc_trigger[1] . acomparator out</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = gpadc_trigger[2] . gpio 40</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = gpadc_trigger[3] . gpio 41</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
</tbody>
</table>

#### 24.14.2.4 ADC Interval Register (adc_reg_interval)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_interval</td>
<td>0x0C</td>
</tr>
</tbody>
</table>
### ADC Interval Register (adc_reg_interval)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>bypass_warmup</td>
<td>R/W 0x0</td>
<td>Bypass Warm-Up State Inside ADC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = ADC warm-up state enabled (warm-up period is controlled by warm-up time)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = ADC warm-up state bypassed</td>
</tr>
<tr>
<td>4:0</td>
<td>warmup_time</td>
<td>R/W 0xF</td>
<td>Warm-Up Time</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Should be set equal to or higher than 1 us. ADC warm-up time is set to Warmup_time+1 us, for example:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x00 = ADC warm-up is 1 us</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1F = ADC warm-up is 32 us</td>
</tr>
</tbody>
</table>

### ADC ANA Register (adc_reg_ana)

#### Instance Name

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_ana</td>
<td>0x10</td>
</tr>
</tbody>
</table>

#### Table 520: ADC ANA Register (adc_reg_ana)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:19</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>18:17</td>
<td>res_sel</td>
<td>R/W 0x0</td>
<td>ADC Resolution/data Rate Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 12-bit 2 ms/s pipelined-sar mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 14-bit 181.8 ks/s extended-counting mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 16-bit 57.1 ks/s extended-counting mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 16-bit 16 ks/s extended-counting mode</td>
</tr>
<tr>
<td>16</td>
<td>bias_sel</td>
<td>R/W 0x0</td>
<td>ADC Analog Portion Low-Power Mode Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Half the biasing current for modulator when enabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = full biasing current</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = half biasing current</td>
</tr>
<tr>
<td>15</td>
<td>chop_en</td>
<td>R/W 0x1</td>
<td>ADC Chopper/Auto-Zero (only in 12-bit mode) Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable chopper</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable chopper</td>
</tr>
<tr>
<td>14</td>
<td>inbuf_en</td>
<td>R/W 0x0</td>
<td>GPADC Input Gain Buffer Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = input gain buffer disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = input gain buffer enabled</td>
</tr>
</tbody>
</table>
Table 520: ADC ANA Register (adc_reg_ana) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13</td>
<td>inbuf_chop_en</td>
<td>R/W 0x1</td>
<td>Input Buffer Chopper Enable&lt;br&gt;0x0 = disable chopper&lt;br&gt;0x1 = enable chopper</td>
</tr>
<tr>
<td>12:11</td>
<td>inbuf_gain</td>
<td>R/W 0x1</td>
<td>ADC Gain Control&lt;br&gt;Also selects input voltage range.&lt;br&gt;0x0 = PGA gain is 0.5 (input voltage range is 2<em>vref)&lt;br&gt;0x1 = PGA gain is 1 (input voltage range is vref)&lt;br&gt;0x2 = PGA gain is 2 (input voltage range is 0.5</em>vref)&lt;br&gt;0x3 = reserved</td>
</tr>
<tr>
<td>10</td>
<td>singlediff</td>
<td>R/W 0x0</td>
<td>Select Single Ended or Differential Input&lt;br&gt;0x0 = single-ended input&lt;br&gt;0x1 = differential input</td>
</tr>
<tr>
<td>9:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5:4</td>
<td>vref_sel</td>
<td>R/W 0x1</td>
<td>ADC Reference Voltage Select&lt;br&gt;0x0 = internal 1.8V AVDD18&lt;br&gt;0x1 = internal 1.2V bandgap&lt;br&gt;0x2 = external single-ended reference (gpadc_ch[3])&lt;br&gt;0x3 = internal 1.2V bandgap with external bypass pin (gpadc_ch[3])</td>
</tr>
<tr>
<td>3</td>
<td>vref_chop_en</td>
<td>R/W 0x0</td>
<td>ADC Voltage Reference Buffer Chopper Enable&lt;br&gt;0x0 = disable chopper&lt;br&gt;0x1 = enable chopper</td>
</tr>
<tr>
<td>2</td>
<td>vref_scf_bypass</td>
<td>R/W 0x0</td>
<td>ADC Voltage Reference Buffer sc-filter Bypass&lt;br&gt;0x0 = not bypass sc-filter&lt;br&gt;0x1 = bypass sc-filter</td>
</tr>
<tr>
<td>1</td>
<td>ts_en</td>
<td>R/W 0x0</td>
<td>Temperature Sensor Enable&lt;br&gt;Only enable when channel source is temperature sensor.&lt;br&gt;0x0 = disable&lt;br&gt;0x1 = enable</td>
</tr>
<tr>
<td>0</td>
<td>tsext_sel</td>
<td>R/W 0x0</td>
<td>Temperature Sensor Diode Select&lt;br&gt;0x0 = internal diode mode&lt;br&gt;0x1 = external diode mode</td>
</tr>
</tbody>
</table>

24.14.2.6   ADC Conversion Sequence 1 Register (adc_reg_scn1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_scn1</td>
<td>0x18</td>
</tr>
</tbody>
</table>
Table 521: ADC Conversion Sequence 1 Register (adc_reg_scn1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:28</td>
<td>scan_ch_7</td>
<td>R/W 0x0</td>
<td>Amux Source 7</td>
</tr>
<tr>
<td>27:24</td>
<td>scan_ch_6</td>
<td>R/W 0x0</td>
<td>Amux Source 6</td>
</tr>
<tr>
<td>23:20</td>
<td>scan_ch_5</td>
<td>R/W 0x0</td>
<td>Amux Source 5</td>
</tr>
<tr>
<td>19:16</td>
<td>scan_ch_4</td>
<td>R/W 0x0</td>
<td>Amux Source 4</td>
</tr>
<tr>
<td>15:12</td>
<td>scan_ch_3</td>
<td>R/W 0x0</td>
<td>Amux Source 3</td>
</tr>
<tr>
<td>11:8</td>
<td>scan_ch_2</td>
<td>R/W 0x0</td>
<td>Amux Source 2</td>
</tr>
<tr>
<td>7:4</td>
<td>scan_ch_1</td>
<td>R/W 0x0</td>
<td>Amux Source 1</td>
</tr>
</tbody>
</table>
| 3:0   | scan_ch_0 | R/W 0x0 | Amux Source 0  
When singlediff=0 (positive and negative):  
0x0 = gpadc_ch[0] and vssa  
0x1 = gpadc_ch[1] and vssa  
0x2 = gpadc_ch[2] and vssa  
0x3 = gpadc_ch[3] and vssa  
0x4 = gpadc_ch[4] and vssa  
0x5 = gpadc_ch[5] and vssa  
0x6 = gpadc_ch[6] and vssa  
0x7 = gpadc_ch[7] and vssa  
0x8 = vbat_s and vssa  
0x9 = vref(1.2V) and vssa  
0xA = daca and vssa  
0xB = dacb and vssa  
0xC = vssa and vssa  
0xF = temp_p and vssa  
others = reserved  
When singlediff=1 (positive and negative):  
0x0 = gpadc_ch[0] and gpadc_ch[1]  
0x1 = gpadc_ch[2] and gpadc_ch[3]  
0x2 = gpadc_ch[4] and gpadc_ch[5]  
0x3 = gpadc_ch[6] and gpadc_ch[7]  
0x4 = daca and dacb  
0x5 = PGA positive (gpadc_ch[0]) and PGA negative(gpadc_ch[1])  
0xF = temp_p and temp_n  
others = reserved |
24.14.2.7 ADC Conversion Sequence 2 Register (adc_reg_scn2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_scn2</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

Table 522: ADC Conversion Sequence 2 Register (adc_reg_scn2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:28</td>
<td>scan_ch_15</td>
<td>R/W 0x0</td>
<td>Amux Source 15</td>
</tr>
<tr>
<td>27:24</td>
<td>scan_ch_14</td>
<td>R/W 0x0</td>
<td>Amux Source 14</td>
</tr>
<tr>
<td>23:20</td>
<td>scan_ch_13</td>
<td>R/W 0x0</td>
<td>Amux Source 13</td>
</tr>
<tr>
<td>19:16</td>
<td>scan_ch_12</td>
<td>R/W 0x0</td>
<td>Amux Source 12</td>
</tr>
<tr>
<td>15:12</td>
<td>scan_ch_11</td>
<td>R/W 0x0</td>
<td>Amux Source 11</td>
</tr>
<tr>
<td>11:8</td>
<td>scan_ch_10</td>
<td>R/W 0x0</td>
<td>Amux Source 10</td>
</tr>
<tr>
<td>7:4</td>
<td>scan_ch_9</td>
<td>R/W 0x0</td>
<td>Amux Source 9</td>
</tr>
<tr>
<td>3:0</td>
<td>scan_ch_8</td>
<td>R/W 0x0</td>
<td>Amux Source 8</td>
</tr>
</tbody>
</table>

24.14.2.8 ADC Result Buffer Register (adc_reg_result_buf)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_result_buf</td>
<td>0x20</td>
</tr>
</tbody>
</table>

Table 523: ADC Result Buffer Register (adc_reg_result_buf)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>width_sel</td>
<td>R/W 0x0</td>
<td>ADC Final Result FIFO Data Packed Format Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Must set scan_length as even when choosing 32 bits.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 16-bits and adc_reg_result FIFO is lower 16-bits effective</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 32-bits and adc_reg_result FIFO is 32-bits effective</td>
</tr>
</tbody>
</table>
### 24.14.2.9 ADC DMAR Register (adc_reg_dmar)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_dmar</td>
<td>0x28</td>
</tr>
</tbody>
</table>

**Table 524: ADC DMAR Register (adc_reg_dmar)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2:1</td>
<td>fifo_thl</td>
<td>R/W 0x0</td>
<td>FIFO Threshold&lt;br&gt;0x0 = 1 data&lt;br&gt;0x1 = 4 data&lt;br&gt;0x2 = 8 data&lt;br&gt;0x3 = 16 data</td>
</tr>
<tr>
<td>0</td>
<td>dma_en</td>
<td>R/W 0x0</td>
<td>DMA Enable&lt;br&gt;0x0 = disable DMA handshake (this will also clear remaining DMA request to system DMAC)&lt;br&gt;0x1 = enable DMA handshake (must enable after conv_start is asserted to ensure FIFO is cleared)</td>
</tr>
</tbody>
</table>

### 24.14.2.10 ADC Status Register (adc_reg_status)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_status</td>
<td>0x2C</td>
</tr>
</tbody>
</table>

**Table 525: ADC Status Register (adc_reg_status)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:9</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>8:3</td>
<td>fifo_data_count</td>
<td>R 0x0</td>
<td>FIFO Data Number</td>
</tr>
<tr>
<td>2</td>
<td>fifo_full</td>
<td>R 0x0</td>
<td>FIFO Full Status</td>
</tr>
<tr>
<td>1</td>
<td>fifo_ne</td>
<td>R 0x0</td>
<td>FIFO Not Empty Status</td>
</tr>
<tr>
<td>0</td>
<td>act</td>
<td>R 0x0</td>
<td>ADC Status&lt;br&gt;0x0 = ADC conversion inactive status&lt;br&gt;0x1 = ADC conversion active status</td>
</tr>
</tbody>
</table>
24.14.2.11 ADC ISR Register (adc_reg_isr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_isr</td>
<td>0x30</td>
</tr>
</tbody>
</table>

Table 526: ADC ISR Register (adc_reg_isr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6</td>
<td>fifo_underrun</td>
<td>R 0x0</td>
<td>FIFO Underrun Interrupt Flag</td>
</tr>
<tr>
<td>5</td>
<td>fifo_overrun</td>
<td>R 0x0</td>
<td>FIFO Overrun Interrupt Flag</td>
</tr>
<tr>
<td>4</td>
<td>datasat_pos</td>
<td>R 0x0</td>
<td>ADC Data Positive Side Saturation Interrupt Flag</td>
</tr>
<tr>
<td>3</td>
<td>datasat_neg</td>
<td>R 0x0</td>
<td>ADC Data Negative Side Saturation Interrupt Flag</td>
</tr>
<tr>
<td>2</td>
<td>offfsat</td>
<td>R 0x0</td>
<td>Offset Correction Saturation Interrupt Flag</td>
</tr>
<tr>
<td>1</td>
<td>gainsat</td>
<td>R 0x0</td>
<td>Gain Correction Saturation Interrupt Flag</td>
</tr>
<tr>
<td>0</td>
<td>rdy</td>
<td>R 0x0</td>
<td>Conversion Data Ready Interrupt Flag</td>
</tr>
</tbody>
</table>

24.14.2.12 ADC IMR Register (adc_reg_imr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_imr</td>
<td>0x34</td>
</tr>
</tbody>
</table>

Table 527: ADC IMR Register (adc_reg_imr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6</td>
<td>fifo_underrun_mask</td>
<td>R/W 0x1</td>
<td>Write 1 Mask</td>
</tr>
<tr>
<td>5</td>
<td>fifo_overrun_mask</td>
<td>R/W 0x1</td>
<td>Write 1 Mask</td>
</tr>
<tr>
<td>4</td>
<td>datasat_pos_mask</td>
<td>R/W 0x1</td>
<td>Write 1 Mask</td>
</tr>
</tbody>
</table>
### 24.14.2.13 ADC IRSR Register (adc_reg_irsr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_irsr</td>
<td>0x38</td>
</tr>
</tbody>
</table>

#### Table 528: ADC IRSR Register (adc_reg_irsr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td></td>
<td>fifo_underrun_raw</td>
<td>R 0x0</td>
<td>FIFO Underrun Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The corresponding flag will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
<tr>
<td>5</td>
<td>fifo_overrun_raw</td>
<td>R 0x0</td>
<td>FIFO Underrun Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The corresponding flag will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
<tr>
<td>4</td>
<td>datasat_pos_raw</td>
<td>R 0x0</td>
<td>Datasat Positive Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The corresponding flag will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
<tr>
<td>3</td>
<td>datasat_neg_raw</td>
<td>R 0x0</td>
<td>Datasat Negative Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The corresponding flag will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
<tr>
<td>2</td>
<td>offsat_raw</td>
<td>R 0x0</td>
<td>Offsat Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The corresponding flag will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
<tr>
<td>1</td>
<td>gainsat_raw</td>
<td>R 0x0</td>
<td>Gainsat Raw</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The corresponding flag will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
</tbody>
</table>
24.14.2.14 ADC ICR Register (adc_reg_icr)

Table 529: ADC ICR Register (adc_reg_icr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6</td>
<td>fifo_underrun_clr</td>
<td>R/W 0x0</td>
<td>Write 1 to Clear Both adc_reg_irsr and adc_reg_isr</td>
</tr>
<tr>
<td>5</td>
<td>fifo_overrun_clr</td>
<td>R/W 0x0</td>
<td>Write 1 to Clear Both adc_reg_irsr and adc_reg_isr</td>
</tr>
<tr>
<td>4</td>
<td>datasat_pos_clr</td>
<td>R/W 0x0</td>
<td>Write 1 to Clear Both adc_reg_irsr and adc_reg_isr</td>
</tr>
<tr>
<td>3</td>
<td>datasat_neg_clr</td>
<td>R/W 0x0</td>
<td>Write 1 to Clear Both adc_reg_irsr and adc_reg_isr</td>
</tr>
<tr>
<td>2</td>
<td>offsat_clr</td>
<td>R/W 0x0</td>
<td>Write 1 to Clear Both adc_reg_irsr and adc_reg_isr</td>
</tr>
<tr>
<td>1</td>
<td>gainsat_clr</td>
<td>R/W 0x0</td>
<td>Write 1 to Clear Both adc_reg_irsr and adc_reg_isr</td>
</tr>
<tr>
<td>0</td>
<td>rdy_clr</td>
<td>R/W 0x0</td>
<td>Write 1 to Clear Both adc_reg_irsr and adc_reg_isr</td>
</tr>
</tbody>
</table>

24.14.2.15 ADC Result Register (adc_reg_result)

Table 528: ADC IRSR Register (adc_reg_irsr) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>rdy_raw</td>
<td>R 0x0</td>
<td>Ready Raw. The corresponding flag will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
</tbody>
</table>

Instance Name | Offset |
-------------|--------|
adc_reg_icr  | 0x3C   |

Instance Name | Offset |
-------------|--------|
adc_reg_result | 0x44   |
24.14.2.16 ADC Raw Result Register (adc_reg_raw_result)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:22</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>21:0</td>
<td>raw_data</td>
<td>R 0x0</td>
<td>ADC Raw Data in Signed 22-Bit Format</td>
</tr>
</tbody>
</table>

24.14.2.17 ADC Offset Calibration Register (adc_reg_offset_cal)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>offset_cal_usr</td>
<td>R/W 0x0</td>
<td>User Offset Calibration Data (16-bit signed)</td>
</tr>
<tr>
<td>15:0</td>
<td>offset_cal</td>
<td>R 0x0</td>
<td>ADC Self Offset Calibration Value (16-bit signed)</td>
</tr>
</tbody>
</table>

24.14.2.18 ADC Gain Calibration Register (adc_reg_gain_cal)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_gain_cal</td>
<td>0x50</td>
</tr>
</tbody>
</table>

Table 530: ADC Result Register (adc_reg_result)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R 0x0</td>
<td>ADC Final Conversion Result Data After calibration and signed/unsigned process.</td>
</tr>
</tbody>
</table>

Table 531: ADC Raw Result Register (adc_reg_raw_result)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_raw_result</td>
<td>0x48</td>
</tr>
</tbody>
</table>

Table 532: ADC Offset Calibration Register (adc_reg_offset_cal)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_offset_cal</td>
<td>0x4C</td>
</tr>
</tbody>
</table>

Table 533: ADC Gain Calibration Register (adc_reg_gain_cal)
Table 533: ADC Gain Calibration Register (adc_reg_gain_cal)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>gain_cal_usr</td>
<td>R/W 0x0</td>
<td>ADC User Gain Calibration Value (16-bit signed)</td>
</tr>
<tr>
<td>15:0</td>
<td>gain_cal</td>
<td>R 0x0</td>
<td>ADC Self Gain Calibration Value (16-bit signed)</td>
</tr>
</tbody>
</table>

24.14.2.19 ADC Test Register (adc_reg_test)

Table 534: ADC Test Register (adc_reg_test)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:1</td>
<td>test_sel</td>
<td>R/W 0x0</td>
<td>Test Select</td>
</tr>
<tr>
<td>0</td>
<td>test_en</td>
<td>R/W 0x0</td>
<td>Analog Test Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable analog test (adc_atest=Hi-Z)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable analog test</td>
</tr>
</tbody>
</table>

24.14.2.20 ADC Audio Register (adc_reg_audio)

Table 535: ADC Audio Register (adc_reg_audio)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9</td>
<td>pga_chop_en</td>
<td>R/W 0x1</td>
<td>Audio PGA Chopper Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable audio PGA chopper</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable audio PGA chopper</td>
</tr>
</tbody>
</table>
### Table 535: ADC Audio Register (adc_reg_audio) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8:6</td>
<td>pga_cm</td>
<td>R/W 0x4</td>
<td>Audio PGA Output Common Mode Control</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = common mode is 0.82V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = common mode is 0.84V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = common mode is 0.86V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = common mode is 0.88V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = common mode is 0.90V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = common mode is 0.92V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = common mode is 0.94V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = common mode is 0.96V</td>
</tr>
<tr>
<td>5:3</td>
<td>pga_gain</td>
<td>R/W 0x0</td>
<td>Audio PGA Voltage Gain Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = PGA gain is 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = PGA gain is 8</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = PGA gain is 16</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = PGA gain is 32</td>
</tr>
<tr>
<td>2:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>en</td>
<td>R/W 0x0</td>
<td>Audio Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable audio PGA and decimation rate select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable audio PGA and decimation rate select</td>
</tr>
</tbody>
</table>

### 24.14.2.21 ADC Voice Detect Register (adc_reg_voice_det)

**Instance Name**
- adc_reg_voice_det

**Offset**
- 0x5C

### Table 536: ADC Voice Detect Register (adc_reg_voice_det)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:1</td>
<td>level_sel</td>
<td>R/W 0x0</td>
<td>Voice Level Selection</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = input voice level is greater than +255LSbB or smaller than -256LSb</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = input voice level is greater than +511LSbB or smaller than -512LSb</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = input voice level is greater than +1023LSbB or smaller than -1024LSb</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = input voice level is greater than +2047LSbB or smaller than -2048LSb</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
</tbody>
</table>
### Table 536: ADC Voice Detect Register (adc_reg_voice_det) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>det_en</td>
<td>R/W 0x0</td>
<td>Voice Level Detection Enable Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable level detection</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable level detection</td>
</tr>
</tbody>
</table>

### 24.14.2.22 ADC Reserved Register (adc_reg_rsvd)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adc_reg_rsvd</td>
<td>0x60</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:0</td>
<td>unused_adc</td>
<td>R/W 0xFF00</td>
<td>Unused ADC Control Bits Do not change the reset value.</td>
</tr>
</tbody>
</table>
24.15 DAC Address Block

24.15.1 DAC Register Map

Table 538: DAC Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>ctrl</td>
<td>0x0000_0000</td>
<td>DAC Control Register</td>
<td>Page: 583</td>
</tr>
<tr>
<td>0x04</td>
<td>status</td>
<td>0x0000_0000</td>
<td>DAC Status Register</td>
<td>Page: 584</td>
</tr>
<tr>
<td>0x08</td>
<td>acrl</td>
<td>0x0000_038</td>
<td>Channel A Control Register</td>
<td>Page: 584</td>
</tr>
<tr>
<td>0x0C</td>
<td>bctrl</td>
<td>0x0000_1838</td>
<td>Channel B Control Register</td>
<td>Page: 586</td>
</tr>
<tr>
<td>0x10</td>
<td>adat</td>
<td>0x0000_0000</td>
<td>Channel A Data Register</td>
<td>Page: 587</td>
</tr>
<tr>
<td>0x14</td>
<td>ddat</td>
<td>0x0000_0000</td>
<td>Channel B Data Register</td>
<td>Page: 588</td>
</tr>
<tr>
<td>0x18</td>
<td>isr</td>
<td>0x0000_0000</td>
<td>Interrupt Status Register</td>
<td>Page: 588</td>
</tr>
<tr>
<td>0x1C</td>
<td>imr</td>
<td>0x0000_001F</td>
<td>Interrupt Mask Register</td>
<td>Page: 589</td>
</tr>
<tr>
<td>0x20</td>
<td>isr</td>
<td>0x0000_0000</td>
<td>Interrupt Raw Status Register</td>
<td>Page: 589</td>
</tr>
<tr>
<td>0x24</td>
<td>icr</td>
<td>0x0000_0000</td>
<td>Interrupt Clear Register</td>
<td>Page: 590</td>
</tr>
<tr>
<td>0x28</td>
<td>clk</td>
<td>0x0000_0000</td>
<td>Clock Register</td>
<td>Page: 590</td>
</tr>
<tr>
<td>0x2C</td>
<td>rst</td>
<td>0x0000_0000</td>
<td>Soft Reset Register</td>
<td>Page: 591</td>
</tr>
</tbody>
</table>

24.15.2 DAC Registers

24.15.2.1 DAC Control Register (ctrl)

Table 539: DAC Control Register (ctrl)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 0    | ref_sel | R/W 0x0     | Reference Selector  
0x0 = internal reference 
0x1 = external reference |
24.15.2.2 DAC Status Register (status)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>status</td>
<td>0x04</td>
</tr>
</tbody>
</table>

Table 540: DAC Status Register (status)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 1    | b_dv  | R 0x0 | DACB Conversion Status
0x0 = channel b conversion is not done
0x1 = channel b conversion complete |
| 0    | a_dv  | R 0x0 | DACA Conversion Status
0x0 = channel a conversion is not done
0x1 = channel a conversion complete |

24.15.2.3 Channel A Control Register (actrl)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>actrl</td>
<td>0x08</td>
</tr>
</tbody>
</table>

Table 541: Channel A Control Register (actrl)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:20</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 19:18| a_range | R/W 0x3 | Output Voltage Range Control, with Internal/External Reference

0x0 = 0.16+(0.64*input code/1023) with ref_sel=0(internal)/0.08*Vref_ext+(0.32*Vref_ext*input code/1023) with ref_sel=1(external)

0x1 = 0.19+(1.01*input code /1023) with ref_sel=0(internal)/0.095*Vref_ext+(0.505*Vref_ext*input_code/1023) with ref_sel=1(external)

0x2 = 0.19+(1.01*input code /1023) with ref_sel=0(internal)/0.095*Vref_ext+(0.505*Vref_ext*input_code/1023) with ref_sel=1(external)

0x3 = 0.18+(1.42*input code /1023) with ref_sel=0(internal)/0.09*Vref_ext+(0.71*Vref_ext*input_code/1023) with ref_sel=1(external)
<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17:16</td>
<td>a_wave</td>
<td>R/W 0x0</td>
<td>Channel A Wave Type Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = normal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = triangle wave</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = noise</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = sine wave</td>
</tr>
<tr>
<td>15:14</td>
<td>a_tria_step_sel</td>
<td>R/W 0x0</td>
<td>Channel A Triangle Wave Step Selector</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 15</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 511</td>
</tr>
<tr>
<td>13:10</td>
<td>a_tria_mamp_sel</td>
<td>R/W 0x0</td>
<td>Channel A Triangle Wave Max Amplitude Selector</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 63</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 127</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 191</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 255</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = 319</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = 383</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = 447</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = 511</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x8 = 575</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x9 = 639</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xA = 703</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xB = 767</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xC = 831</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xD = 895</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xE = 959</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xF = 1023</td>
</tr>
<tr>
<td>9</td>
<td>a_tria_half</td>
<td>R/W 0x0</td>
<td>Channel A Triangle Wave Type Selector</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = full triangle</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = half triangle</td>
</tr>
<tr>
<td>8</td>
<td>a_time_mode</td>
<td>R/W 0x0</td>
<td>Channel A Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = non-timing related</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = timing related</td>
</tr>
<tr>
<td>7</td>
<td>a_den</td>
<td>R/W 0x0</td>
<td>Channel A DMA Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA data transfer disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA data transfer enabled</td>
</tr>
<tr>
<td>6:5</td>
<td>a_trig_typ</td>
<td>R/W 0x1</td>
<td>Channel A Trigger Type</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = rising edge trigger</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = falling edge trigger</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = both rising and falling edge trigger</td>
</tr>
</tbody>
</table>
### Table 541: Channel A Control Register (actrl) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4:3</td>
<td>a_trig_sel</td>
<td>R/W 0x3</td>
<td>Channel A Trigger Selector</td>
</tr>
<tr>
<td>2</td>
<td>a_trig_en</td>
<td>R/W 0x0</td>
<td>Channel A Trigger Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = channel a conversion triggered by external event disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = channel a conversion triggered by external event enabled</td>
</tr>
<tr>
<td>1</td>
<td>a_io_en</td>
<td>R/W 0x0</td>
<td>Channel A Conversion Output to Pad Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable channel a conversion result to GPIO</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable channel a conversion result to GPIO</td>
</tr>
<tr>
<td>0</td>
<td>a_en</td>
<td>R/W 0x0</td>
<td>Channel A Enable/Disable Signal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable channel a conversion</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable channel a conversion</td>
</tr>
</tbody>
</table>

### 24.15.2.4 Channel B Control Register (bctrl)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>bctrl</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

### Table 542: Channel B Control Register (bctrl)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:13</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>12:11</td>
<td>Reserved</td>
<td>R/W 0x3</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>10:9</td>
<td>b_wave</td>
<td>R/W 0x0</td>
<td>Channel B Wave Type Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = normal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = differential mode with channel A</td>
</tr>
<tr>
<td>8</td>
<td>b_time_mode</td>
<td>R/W 0x0</td>
<td>Channel B Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = non-timing related</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = timing related</td>
</tr>
<tr>
<td>7</td>
<td>b_den</td>
<td>R/W 0x0</td>
<td>Channel B DMA Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = DMA data transfer disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = DMA data transfer enabled</td>
</tr>
</tbody>
</table>
### Channel B Control Register (bctrl) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6:5</td>
<td>b_trig_typ</td>
<td>R/W 0x1</td>
<td>Channel B Trigger Type&lt;br&gt;0x0 = reserved&lt;br&gt;0x1 = rising edge trigger&lt;br&gt;0x2 = falling edge trigger&lt;br&gt;0x3 = both rising and falling edge trigger</td>
</tr>
<tr>
<td>4:3</td>
<td>b_trig_sel</td>
<td>R/W 0x3</td>
<td>Channel B Trigger Selector</td>
</tr>
<tr>
<td>2</td>
<td>b_trig_en</td>
<td>R/W 0x0</td>
<td>Channel B Trigger Enable&lt;br&gt;0x0 = channel B conversion triggered by external event disabled&lt;br&gt;0x1 = channel B conversion triggered by external event enabled</td>
</tr>
<tr>
<td>1</td>
<td>b_io_en</td>
<td>R/W 0x0</td>
<td>Channel B Conversion Output to Pad Enable&lt;br&gt;0x0 = disable channel B conversion result to GPIO&lt;br&gt;0x1 = enable channel B conversion result to GPIO</td>
</tr>
<tr>
<td>0</td>
<td>b_en</td>
<td>R/W 0x0</td>
<td>Channel B Enable/Disable Signal&lt;br&gt;0x0 = disable channel B conversion&lt;br&gt;0x1 = enable channel B conversion</td>
</tr>
</tbody>
</table>

#### 24.15.2.5 Channel A Data Register (adata)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>adata</td>
<td>0x10</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9:0</td>
<td>a_data</td>
<td>R/W 0x0</td>
<td>Channel A Data Input&lt;br&gt;This field is also used as base_value when choose triangle wave.</td>
</tr>
</tbody>
</table>

#### 24.15.2.6 Channel B Data Register (bdata)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>bdata</td>
<td>0x14</td>
</tr>
</tbody>
</table>
### Table 544: Channel B Data Register (bdata)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9:0</td>
<td>b_data</td>
<td>R/W 0x0</td>
<td>Channel B Data Input</td>
</tr>
</tbody>
</table>

### 24.15.2.7 Interrupt Status Register (isr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>isr</td>
<td>0x18</td>
</tr>
</tbody>
</table>

### Table 545: Interrupt Status Register (isr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>tria_ovfl_int</td>
<td>R 0x0</td>
<td>Triangle Overflow 1 indicates that triangle wave configuration overflow happened.</td>
</tr>
<tr>
<td>3</td>
<td>b_to_int</td>
<td>R 0x0</td>
<td>Channel B Timeout 1 indicates Channel B timeout interrupt flag if reg_imr[1] not masked.</td>
</tr>
<tr>
<td>2</td>
<td>a_to_int</td>
<td>R 0x0</td>
<td>Channel A Timeout 1 indicates Channel A timeout interrupt flag if reg_imr[0] not masked.</td>
</tr>
<tr>
<td>1</td>
<td>b_rdy_int</td>
<td>R 0x0</td>
<td>Channel B Data Ready 1 indicates Channel B data ready interrupt flag if reg_imr[1] not masked.</td>
</tr>
<tr>
<td>0</td>
<td>a_rdy_int</td>
<td>R 0x0</td>
<td>Channel A Data Ready 1 indicates Channel A data ready interrupt flag if reg_imr[0] not masked.</td>
</tr>
</tbody>
</table>

### 24.15.2.8 Interrupt Mask Register (imr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>imr</td>
<td>0x1C</td>
</tr>
</tbody>
</table>
## Table 546: Interrupt Mask Register (imr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 4    | tria_ovfl_int_msk| R/W 0x1     | Triangle Overflow Mask
Set to 1 to mask off triangle wave configuration overflow interrupt. |
| 3    | b_to_int_msk     | R/W 0x1     | Channel B Timeout Mask
Set to 1 to mask off Channel B timeout interrupt. |
| 2    | a_to_int_msk     | R/W 0x1     | Channel A Timeout Mask
Set to 1 to mask off Channel A timeout interrupt. |
| 1    | b_rdy_int_msk    | R/W 0x1     | Channel B Data Ready Mask
Set to 1 to mask off Channel B data ready interrupt. |
| 0    | a_rdy_int_msk    | R/W 0x1     | Channel A Data Ready Mask
Set to 1 to mask off Channel A data ready interrupt. |

## 24.15.2.9 Interrupt Raw Status Register (irsr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>irsr</td>
<td>0x20</td>
</tr>
</tbody>
</table>

## Table 547: Interrupt Raw Status Register (irsr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 4    | tria_ovfl_int_raw| R 0x0       | Triangle Overflow Raw
1 indicates triangle wave configuration overflow interrupt flag, regardless of the mask. |
| 3    | b_to_int_raw     | R 0x0       | Channel B Timeout Raw
1 indicates Channel B timeout interrupt flag, regardless the mask. |
| 2    | a_to_int_raw     | R 0x0       | Channel A Timeout Raw
1 indicates Channel A timeout interrupt flag, regardless the mask. |
| 1    | b_rdy_int_raw    | R 0x0       | Channel B Data Ready Raw
1 indicates Channel B data ready interrupt flag, regardless the mask. |
| 0    | a_rdy_int_raw    | R 0x0       | Channel A Data Ready Raw
1 indicates Channel A data ready interrupt flag, regardless the mask. |
24.15.2.10  Interrupt Clear Register (icr)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>icr</td>
<td>0x24</td>
</tr>
</tbody>
</table>

Table 548: Interrupt Clear Register (icr)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>tria_ovfl_int_clr</td>
<td>R/W 0x0</td>
<td>Triangle Overflow Clear Write 1 to clear triangle wave configuration overflow interrupt flag.</td>
</tr>
<tr>
<td>3</td>
<td>b_to_int_clr</td>
<td>R/W 0x0</td>
<td>Channel B Timeout Clear Write 1 to clear Channel B timeout interrupt flag.</td>
</tr>
<tr>
<td>2</td>
<td>a_to_int_clr</td>
<td>R/W 0x0</td>
<td>Channel A Timeout Clear Write 1 to clear Channel A timeout interrupt flag.</td>
</tr>
<tr>
<td>1</td>
<td>b_rdy_int_clr</td>
<td>R/W 0x0</td>
<td>Channel B Data Ready Clear Write 1 to clear Channel B data ready interrupt flag.</td>
</tr>
<tr>
<td>0</td>
<td>a_rdy_int_clr</td>
<td>R/W 0x0</td>
<td>Channel A Data Ready Clear Write 1 to clear Channel A data ready interrupt flag.</td>
</tr>
</tbody>
</table>

24.15.2.11  Clock Register (clk)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>clk</td>
<td>0x28</td>
</tr>
</tbody>
</table>

Table 549: Clock Register (clk)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>soft_clk_rst</td>
<td>R/W 0x0</td>
<td>Soft Reset for Clock Divider 0x0 = normal 0x1 = reset</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>R/W 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>2:1</td>
<td>clk_ctrl</td>
<td>R/W 0x0</td>
<td>DAC Conversion Rate Selector 0x0 = 62.5K 0x1 = 125K 0x2 = 250K 0x3 = 500K</td>
</tr>
</tbody>
</table>
### 24.15.2.12 Soft Reset Register (rst)

#### Table 549: Clock Register (clk) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Reserved</td>
<td>R/W 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
</tbody>
</table>

#### Table 550: Soft Reset Register (rst)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>b_soft_rst</td>
<td>R/W 0x0</td>
<td>Soft Reset for DAC Channel B, Active High 0x0 = no action 0x1 = reset</td>
</tr>
<tr>
<td>0</td>
<td>a_soft_rst</td>
<td>R/W 0x0</td>
<td>Soft Reset for DAC Channel A, Active High 0x0 = no action 0x1 = reset</td>
</tr>
</tbody>
</table>
24.16  ACOMP Address Block

24.16.1  ACOMP Register Map

Table 551: ACMOP Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>ctrl0</td>
<td>0x4000_0000</td>
<td>ACOMP0 Control Register</td>
<td>Page: 593</td>
</tr>
<tr>
<td>0x04</td>
<td>ctrl1</td>
<td>0x4000_0000</td>
<td>ACOMP1 Control Register</td>
<td>Page: 595</td>
</tr>
<tr>
<td>0x08</td>
<td>status0</td>
<td>0x0000_0000</td>
<td>ACOMP0 Status Register</td>
<td>Page: 598</td>
</tr>
<tr>
<td>0x0C</td>
<td>status1</td>
<td>0x0000_0000</td>
<td>ACOMP1 Status Register</td>
<td>Page: 598</td>
</tr>
<tr>
<td>0x10</td>
<td>route0</td>
<td>0x0000_0000</td>
<td>ACOMP0 Route Register</td>
<td>Page: 599</td>
</tr>
<tr>
<td>0x14</td>
<td>route1</td>
<td>0x0000_0000</td>
<td>ACOMP1 Route Register</td>
<td>Page: 599</td>
</tr>
<tr>
<td>0x18</td>
<td>isr0</td>
<td>0x0000_0000</td>
<td>ACOMP0 Interrupt Status Register</td>
<td>Page: 599</td>
</tr>
<tr>
<td>0x1C</td>
<td>isr1</td>
<td>0x0000_0000</td>
<td>ACOMP1 Interrupt Status Register</td>
<td>Page: 600</td>
</tr>
<tr>
<td>0x20</td>
<td>imr0</td>
<td>0x0000_0003</td>
<td>ACOMP0 Interrupt Mask Register</td>
<td>Page: 601</td>
</tr>
<tr>
<td>0x24</td>
<td>imr1</td>
<td>0x0000_0003</td>
<td>ACOMP1 Interrupt Mask Register</td>
<td>Page: 601</td>
</tr>
<tr>
<td>0x28</td>
<td>irsr0</td>
<td>0x0000_0000</td>
<td>ACOMP0 Interrupt Raw Status Register</td>
<td>Page: 601</td>
</tr>
<tr>
<td>0x2C</td>
<td>irsr1</td>
<td>0x0000_0000</td>
<td>ACOMP1 Interrupt Raw Status Register</td>
<td>Page: 602</td>
</tr>
<tr>
<td>0x30</td>
<td>icr0</td>
<td>0x0000_0000</td>
<td>ACOMP0 Interrupt Clear Register</td>
<td>Page: 602</td>
</tr>
<tr>
<td>0x34</td>
<td>icr1</td>
<td>0x0000_0000</td>
<td>ACOMP1 Interrupt Clear Register</td>
<td>Page: 603</td>
</tr>
<tr>
<td>0x38</td>
<td>rst0</td>
<td>0x0000_0000</td>
<td>ACOMP0 Soft Reset Register</td>
<td>Page: 603</td>
</tr>
<tr>
<td>0x3C</td>
<td>rst1</td>
<td>0x0000_0000</td>
<td>ACOMP1 Soft Reset Register</td>
<td>Page: 603</td>
</tr>
<tr>
<td>0x48</td>
<td>clk</td>
<td>0x0000_0000</td>
<td>Clock Register</td>
<td>Page: 604</td>
</tr>
</tbody>
</table>

24.16.2  ACOMP Registers

24.16.2.1  ACOMP0 Control Register (ctrl0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ctrl0</td>
<td>0x00</td>
</tr>
</tbody>
</table>
### Table 552: ACOMP0 Control Register (ctrl0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>edge_level_sel</td>
<td>R/W 0x0</td>
<td>ACOMP0 Interrupt Type Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = level triggered interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = edge triggered interrupt</td>
</tr>
<tr>
<td>30</td>
<td>int_act_hi</td>
<td>R/W 0x1</td>
<td>ACOMP0 Interrupt Active Mode Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = low level or falling edge triggered interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = high level or rising edge triggered interrupt</td>
</tr>
<tr>
<td>29</td>
<td>fie</td>
<td>R/W 0x0</td>
<td>ACOMP0 Enable/disable Falling Edge Triggered Edge Pulse</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
<tr>
<td>28</td>
<td>rie</td>
<td>R/W 0x0</td>
<td>ACOMP0 Enable/disable Rising Edge Triggered Edge Pulse</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
<tr>
<td>27</td>
<td>inact_val</td>
<td>R/W 0x0</td>
<td>Set Output Value When ACOMP0 Is Inactive</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = output 0 when ACOMP0 is inactive</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = output 1 when ACOMP0 is inactive</td>
</tr>
<tr>
<td>26</td>
<td>muxen</td>
<td>R/W 0x0</td>
<td>ACOMP0 Input MUX Enable Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This bit should be asserted earlier than 'en' bit.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable input mux</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable input mux</td>
</tr>
<tr>
<td>25:22</td>
<td>pos_sel</td>
<td>R/W 0x0</td>
<td>ACOMP0 Positive Input Select Bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = acomp_ch&lt;0&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = acomp_ch&lt;1&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = acomp_ch&lt;2&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = acomp_ch&lt;3&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = acomp_ch&lt;4&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = acomp_ch&lt;5&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = acomp_ch&lt;6&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = acomp_ch&lt;7&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x8 = daca</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x9 = dacb</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
</tbody>
</table>
### Table 552: ACOMP0 Control Register (ctrl0) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>21:18</td>
<td>neg_sel</td>
<td>R/W 0x0</td>
<td>ACOMP0 Negative Input Select Bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = acomp_ch&lt;0&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = acomp_ch&lt;1&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = acomp_ch&lt;2&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = acomp_ch&lt;3&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = acomp_ch&lt;4&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = acomp_ch&lt;5&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = acomp_ch&lt;6&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = acomp_ch&lt;7&gt;</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x8 = daca</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x9 = dacb</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xA = vref_1p25</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xB = vssa</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xC = VDDIO_3*scaling factor</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xD = VDDIO_3*scaling factor</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xE = VDDIO_3*scaling factor</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0xF = VDDIO_3*scaling factor</td>
</tr>
<tr>
<td>17:12</td>
<td>level_sel</td>
<td>R/W 0x0</td>
<td>Scaling Factor Select Bits for VDDIO_3 Reference Level</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0X = scaling factor=0.25</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1X = scaling factor= 0.5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2X = scaling factor= 0.75</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3X = scaling factor= 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
<tr>
<td>11:10</td>
<td>bias_prog</td>
<td>R/W 0x0</td>
<td>ACOMP0 Bias Current Control Bits or Response Time Control Bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = power mode1 (slow response mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = power mode2 (medium response mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = power mode3 (fast response mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = reserved</td>
</tr>
<tr>
<td>9:7</td>
<td>hyst_selp</td>
<td>R/W 0x0</td>
<td>Select ACOMP0 Positive Hysteresis Voltage Level</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = +10 mV hysterisis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = +20 mV hysterisis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = +30 mV hysterisis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = +40 mV hysterisis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = +50 mV hysterisis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = +60 mV hysterisis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = +70 mV hysterisis</td>
</tr>
</tbody>
</table>
24.16.2.2  ACOMP1 Control Register (ctrl1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ctrl1</td>
<td>0x04</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>edge_levl_sel</td>
<td>R/W 0x0</td>
<td>ACOMP1 Interrupt Type Select 0x0 = level triggered interrupt 0x1 = edge triggered interrupt</td>
</tr>
<tr>
<td>30</td>
<td>int_act_hi</td>
<td>R/W 0x1</td>
<td>ACOMP1 Interrupt Active Mode Select 0x0 = low level or falling edge triggered interrupt 0x1 = high level or rising edge triggered interrupt</td>
</tr>
<tr>
<td>29</td>
<td>fie</td>
<td>R/W 0x0</td>
<td>ACOMP1 Enable/disable Falling Edge Triggered Edge Pulse 0x0 = disable 0x1 = enable</td>
</tr>
</tbody>
</table>
### Table 553: ACOMP1 Control Register (ctrl1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 28   | rie      | R/W 0x0     | ACOMP1 Enable/disable Rising Edge Triggered Edge Pulse  
|      |          |             | 0x0 = disable  
|      |          |             | 0x1 = enable   |
| 27   | inact_val| R/W 0x0     | Set Output Value When ACOMP1 Is Inactive  
|      |          |             | 0x0 = output 0 when ACOMP1 is inactive  
|      |          |             | 0x1 = output 1 when ACOMP1 is inactive |
| 26   | muxen    | R/W 0x0     | ACOMP1 Input MUX Enable  
|      |          |             | This bit should be asserted earlier than 'en' bit.  
|      |          |             | 0x0 = disable input mux  
|      |          |             | 0x1 = enable input mux   |
| 25:22| pos_sel  | R/W 0x0     | ACOMP1 Positive Input Select  
|      |          |             | 0x0 = acomp_ch<0>  
|      |          |             | 0x1 = acomp_ch<1>  
|      |          |             | 0x2 = acomp_ch<2>  
|      |          |             | 0x3 = acomp_ch<3>  
|      |          |             | 0x4 = acomp_ch<4>  
|      |          |             | 0x5 = acomp_ch<5>  
|      |          |             | 0x6 = acomp_ch<6>  
|      |          |             | 0x7 = acomp_ch<7>  
|      |          |             | 0x8 = daca  
|      |          |             | 0x9 = dacb  
|      |          |             | others = reserved   |
| 21:18| neg_sel  | R/W 0x0     | ACOMP1 Negative Input Select  
|      |          |             | 0x0 = acomp_ch<0>  
|      |          |             | 0x1 = acomp_ch<1>  
|      |          |             | 0x2 = acomp_ch<2>  
|      |          |             | 0x3 = acomp_ch<3>  
|      |          |             | 0x4 = acomp_ch<4>  
|      |          |             | 0x5 = acomp_ch<5>  
|      |          |             | 0x6 = acomp_ch<6>  
|      |          |             | 0x7 = acomp_ch<7>  
|      |          |             | 0x8 = daca  
|      |          |             | 0x9 = dacb  
|      |          |             | 0xA = vref_1p25  
|      |          |             | 0xB = vssa  
|      |          |             | 0xC = VDDIO_3*scaling factor  
|      |          |             | 0xD = VDDIO_3*scaling factor  
|      |          |             | 0xE = VDDIO_3*scaling factor  
|      |          |             | 0xF = VDDIO_3*scaling factor  |
Table 553: ACOMP1 Control Register (ctrl1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17:12</td>
<td>level_sel</td>
<td>R/W 0x0</td>
<td>Scaling Factor Select Bits for VDDIO_3 Reference Level</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0X = scaling factor=0.25</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1X = scaling factor= 0.5</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2X = scaling factor= 0.75</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3X = scaling factor= 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = reserved</td>
</tr>
<tr>
<td>11:10</td>
<td>bias_prog</td>
<td>R/W 0x0</td>
<td>ACOMP1 Bias Current Control Bits Or Response Time Control Bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = power mode1 (Slow response mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = power mode2 (Medium response mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = power mode3 (Fast response mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = reserved</td>
</tr>
<tr>
<td>9:7</td>
<td>hyst_selp</td>
<td>R/W 0x0</td>
<td>Select ACOMP1 Positive Hysteresis Voltage Level</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = +10 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = +20 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = +30 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = +40 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = +50 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = +60 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = +70 mV hysteresis</td>
</tr>
<tr>
<td>6:4</td>
<td>hyst_seln</td>
<td>R/W 0x0</td>
<td>Select ACOMP1 Negative Hysteresis Voltage Level</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = -10 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = -20 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = -30 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x4 = -40 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x5 = -50 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x6 = -60 mV hysteresis</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x7 = -70 mV hysteresis</td>
</tr>
<tr>
<td>3:2</td>
<td>warmtime</td>
<td>R/W 0x0</td>
<td>Set ACOMP1 warm-up Time</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = 1 us</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = 2 us</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = 4 us</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = 8 us</td>
</tr>
<tr>
<td>1</td>
<td>gpioinv</td>
<td>R/W 0x0</td>
<td>Enable/disable Inversion of ACOMP1 Output to GPIO</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = do not invert ACOMP1 output</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = invert ACOMP1 output</td>
</tr>
<tr>
<td>0</td>
<td>en</td>
<td>R/W 0x0</td>
<td>ACOMP1 Enable Bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
</tbody>
</table>
24.16.2.3 ACOMP0 Status Register (status0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>status0</td>
<td>0x08</td>
</tr>
</tbody>
</table>

Table 554: ACOMP0 Status Register (status0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>out</td>
<td>R 0x0</td>
<td>ACOMP0 Comparison Output Value</td>
</tr>
<tr>
<td>0</td>
<td>act</td>
<td>R 0x0</td>
<td>ACOMP0 Active Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = ACOMP0 is inactive</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = ACOMP0 is active</td>
</tr>
</tbody>
</table>

24.16.2.4 ACOMP1 Status Register (status1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>status1</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

Table 555: ACOMP1 Status Register (status1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>out</td>
<td>R 0x0</td>
<td>ACOMP1 Comparison Output Value</td>
</tr>
<tr>
<td>0</td>
<td>act</td>
<td>R 0x0</td>
<td>ACOMP1 Active Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = ACOMP1 is inactive</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = ACOMP1 is active</td>
</tr>
</tbody>
</table>

24.16.2.5 ACOMP0 Route Register (route0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>route0</td>
<td>0x10</td>
</tr>
</tbody>
</table>
### Table 556: ACOMP0 Route Register (route0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>pe</td>
<td>R/W 0x0</td>
<td>Enable/disable ACOMP0 Output to Pin</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
<tr>
<td>0</td>
<td>outsel</td>
<td>R/W 0x0</td>
<td>Select ACOMP0 Synchronous or Asynchronous Output to Pin</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = synchronous output</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = asynchronous output</td>
</tr>
</tbody>
</table>

### 24.16.2.6 ACOMP1 Route Register (route1)

**Instance Name**

<table>
<thead>
<tr>
<th>Offset</th>
<th>route1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x14</td>
<td></td>
</tr>
</tbody>
</table>

**Table 557: ACOMP1 Route Register (route1)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>pe</td>
<td>R/W 0x0</td>
<td>Enable/disable ACOMP1 Output to Pin</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
<tr>
<td>0</td>
<td>outsel</td>
<td>R/W 0x0</td>
<td>Select ACOMP1 Synchronous or Asynchronous Output to Pin</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = synchronous output</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = asynchronous output</td>
</tr>
</tbody>
</table>

### 24.16.2.7 ACOMP0 Interrupt Status Register (isr0)

**Instance Name**

<table>
<thead>
<tr>
<th>Offset</th>
<th>isr0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x18</td>
<td></td>
</tr>
</tbody>
</table>

**Table 558: ACOMP0 Interrupt Status Register (isr0)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 558: ACOMP0 Interrupt Status Register (isr0) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>outa_int</td>
<td>R 0x0</td>
<td>ACOMP0 Asynchronized Output Interrupt This bit is set to 1 when ACOMP0 asynchronized output changes from 0 to 1. If corresponding mask enable bit is set, outa_int signal will not be captured in this register. Will be cleared only when outa_int_clr is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>out_int</td>
<td>R 0x0</td>
<td>ACOMP0 Synchronized Output Interrupt This bit is set to 1 when ACOMP0 synchronized output changes from 0 to 1. If corresponding mask enable bit is set, out_int signal will not be captured in this register. Will be cleared only when out_int_clr is asserted.</td>
</tr>
</tbody>
</table>

24.16.2.8 ACOMP1 Interrupt Status Register (isr1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>isr1</td>
<td>0x1C</td>
</tr>
</tbody>
</table>

Table 559: ACOMP1 Interrupt Status Register (isr1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>outa_int</td>
<td>R 0x0</td>
<td>ACOMP1 Asynchronized Output Interrupt This bit is set to 1 when ACOMP1 asynchronized output changes from 0 to 1. If corresponding mask enable bit is set, outa_int signal will not be captured in this register. Will be cleared only when outa_int_clr is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>out_int</td>
<td>R 0x0</td>
<td>ACOMP1 Synchronized Output Interrupt This bit is set to 1 when ACOMP1 synchronized output changes from 0 to 1. If corresponding mask enable bit is set, out_int signal will not be captured in this register. Will be cleared only when out_int_clr is asserted.</td>
</tr>
</tbody>
</table>

24.16.2.9 ACOMP0 Interrupt Mask Register (imr0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>imr0</td>
<td>0x20</td>
</tr>
</tbody>
</table>
### Table 560: ACOMP0 Interrupt Mask Register (imr0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVDD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>outa_int_mask</td>
<td>R/W 0x1</td>
<td>Mask Asynchronized Interrupt.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Set to 1 to mask off the ACOMP0 asynchronized output interrupt.</td>
</tr>
<tr>
<td>0</td>
<td>out_int_mask</td>
<td>R/W 0x1</td>
<td>Mask Synchronized Interrupt.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Set to 1 to mask off the ACOMP0 synchronized output interrupt.</td>
</tr>
</tbody>
</table>

### 24.16.2.10 ACOMP1 Interrupt Mask Register (imr1)

#### Instance Name Offset
- **imr1** 0x24

#### Table 561: ACOMP1 Interrupt Mask Register (imr1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVDD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>outa_int_mask</td>
<td>R/W 0x1</td>
<td>Mask Asynchronized Interrupt.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Set to 1 to mask off the ACOMP1 asynchronized output interrupt.</td>
</tr>
<tr>
<td>0</td>
<td>out_int_mask</td>
<td>R/W 0x1</td>
<td>Mask Synchronized Interrupt.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Set to 1 to mask off the ACOMP1 synchronized output interrupt.</td>
</tr>
</tbody>
</table>

### 24.16.2.11 ACOMP0 Interrupt Raw Status Register (irsr0)

#### Instance Name Offset
- **irsr0** 0x28

#### Table 562: ACOMP0 Interrupt Raw Status Register (irsr0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVDD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>outa_int_raw</td>
<td>R 0x0</td>
<td>Raw Mask Asynchronized Interrupt. ACOMP0 asynchronized output will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
</tbody>
</table>
Table 562: ACOMP0 Interrupt Raw Status Register (irsr0) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>out_int_raw</td>
<td>R 0x0</td>
<td>Raw Mask Synchronized Interrupt ACOMP0 synchronized output will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
</tbody>
</table>

24.16.2.12 ACOMP1 Interrupt Raw Status Register (irsr1)

Table 563: ACOMP1 Interrupt Raw Status Register (irsr1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>outa_int_raw</td>
<td>R 0x0</td>
<td>Raw Mask Asynchronized Interrupt ACOMP1 asynchronized output will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>out_int_raw</td>
<td>R 0x0</td>
<td>Raw Mask Synchronized Interrupt ACOMP1 synchronized output will be captured into this register regardless the interrupt mask. Will be cleared only when int_clr is asserted.</td>
</tr>
</tbody>
</table>

24.16.2.13 ACOMP0 Interrupt Clear Register (icr0)

Table 564: ACOMP0 Interrupt Clear Register (icr0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>outa_int_clr</td>
<td>R/W 0x0</td>
<td>ACOMP0 Asynchronous Output Interrupt Flag Clear Signal Write 1 to clear ACOMP0 outa_int and outa_int_raw.</td>
</tr>
<tr>
<td>0</td>
<td>out_int_clr</td>
<td>R/W 0x0</td>
<td>ACOMP0 Synchronized Output Interrupt Flag Clear Signal Write 1 to clear ACOMP0 outa_int and outa_int_raw.</td>
</tr>
</tbody>
</table>
24.16.2.14  ACOMP1 Interrupt Clear Register (icr1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>icr1</td>
<td>0x34</td>
</tr>
</tbody>
</table>

Table 565: ACOMP1 Interrupt Clear Register (icr1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>outa_int_clr</td>
<td>R/W 0x0</td>
<td>ACOMP1 Asynchronous Output Interrupt Flag Clear Signal Write 1 to clear ACOMP1 outa_int and outa_int_raw.</td>
</tr>
<tr>
<td>0</td>
<td>out_int_clr</td>
<td>R/W 0x0</td>
<td>ACOMP1 Synchronous Output Interrupt Flag Clear Signal Write 1 to clear ACOMP1 outa_int and outa_int_raw.</td>
</tr>
</tbody>
</table>

24.16.2.15  ACOMP0 Soft Reset Register (rst0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>rst0</td>
<td>0x38</td>
</tr>
</tbody>
</table>

Table 566: ACOMP0 Soft Reset Register (rst0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>soft_rst</td>
<td>R/W 0x0</td>
<td>Soft Reset for ACOMP0 (active high)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no action</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = reset</td>
</tr>
</tbody>
</table>

24.16.2.16  ACOMP1 Soft Reset Register (rst1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>rst1</td>
<td>0x3C</td>
</tr>
</tbody>
</table>

Table 567: ACOMP1 Soft Reset Register (rst1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 567: ACOMP1 Soft Reset Register (rst1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>soft_rst</td>
<td>R/W 0x0</td>
<td>Soft Reset for ACOMP1 (active high)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no action</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = reset</td>
</tr>
</tbody>
</table>

24.16.2.17 Clock Register (clk)

Table 568: Clock Register (clk)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>clk</td>
<td>0x48</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>R/SVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>soft_clk_rst</td>
<td>R/W 0x0</td>
<td>Soft Reset for Clock Divider</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = no action</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = reset</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td>R/W 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
</tbody>
</table>
## 24.17 PINMUX Address Block

### 24.17.1 PINMUX Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0</td>
<td>_GPIO0</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x04</td>
<td>_GPIO1</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x08</td>
<td>_GPIO2</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x0C</td>
<td>_GPIO3</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x10</td>
<td>_GPIO4</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x14</td>
<td>_GPIO5</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x18</td>
<td>_GPIO6</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x1C</td>
<td>_GPIO7</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x20</td>
<td>_GPIO8</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x24</td>
<td>_GPIO9</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x28</td>
<td>_GPIO10</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x2C</td>
<td>_GPIO11</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x30</td>
<td>_GPIO12</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x34</td>
<td>_GPIO13</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x38</td>
<td>_GPIO14</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x3C</td>
<td>_GPIO15</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x40</td>
<td>_GPIO16</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x44</td>
<td>_GPIO17</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x48</td>
<td>_GPIO18</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x4C</td>
<td>_GPIO19</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x50</td>
<td>_GPIO20</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x54</td>
<td>_GPIO21</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x58</td>
<td>_GPIO22</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x5C</td>
<td>_GPIO23</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x60</td>
<td>_GPIO24</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x64</td>
<td>_GPIO25</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x68</td>
<td>_GPIO26</td>
<td>0x0000_0000</td>
<td>Padrning Pin Register</td>
<td>Page: 607</td>
</tr>
</tbody>
</table>
Table 569: PINMUX Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x6C</td>
<td>_GPIO27</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x70</td>
<td>_GPIO28</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x74</td>
<td>_GPIO29</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x78</td>
<td>_GPIO30</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x7C</td>
<td>_GPIO31</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x80</td>
<td>_GPIO32</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x84</td>
<td>_GPIO33</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x88</td>
<td>_GPIO34</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x8C</td>
<td>_GPIO35</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x90</td>
<td>_GPIO36</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x94</td>
<td>_GPIO37</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x98</td>
<td>_GPIO38</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0x9C</td>
<td>_GPIO39</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xA0</td>
<td>_GPIO40</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xA4</td>
<td>_GPIO41</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xA8</td>
<td>_GPIO42</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xAC</td>
<td>_GPIO43</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xB0</td>
<td>_GPIO44</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xB4</td>
<td>_GPIO45</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xB8</td>
<td>_GPIO46</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xBC</td>
<td>_GPIO47</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xC0</td>
<td>_GPIO48</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
<tr>
<td>0xC4</td>
<td>_GPIO49</td>
<td>0x0000_0000</td>
<td>Padr ing Pin Register</td>
<td>Page: 607</td>
</tr>
</tbody>
</table>

24.17.2 PINMUX Registers (_GPIO)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
<th>Count</th>
</tr>
</thead>
<tbody>
<tr>
<td>_GPIO[0:49]</td>
<td>0x00 to 0xC4</td>
<td>50</td>
</tr>
</tbody>
</table>
### Table 570: Padring Pin Registers (_GPIO)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>pio_pull_sel</td>
<td>R/W 0x0</td>
<td>Custom Pull-up and Pull-down Configuration Control</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = pulled up by default 50 kΩ internal pull-up</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = pull-up and pull-down by software from bits[14:13]</td>
</tr>
<tr>
<td>14</td>
<td>pio_pull_up</td>
<td>R/W 0x0</td>
<td>Pull-up Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = pull-up disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = pull-up enabled</td>
</tr>
<tr>
<td>13</td>
<td>pio_pull_dn</td>
<td>R/W 0x0</td>
<td>Pull-down Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = pull-down disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = pull-down enabled</td>
</tr>
<tr>
<td>12:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>slp_oe</td>
<td>R/W 0x0</td>
<td>Reserved for Test Purpose</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Output enable.</td>
</tr>
<tr>
<td>4</td>
<td>slp_val</td>
<td>R/W 0x0</td>
<td>Reserved for Test Purpose</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Output data.</td>
</tr>
<tr>
<td>3</td>
<td>di_en</td>
<td>R/W 0x0</td>
<td>Input Enable Control</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = receiver will be tri-stated</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = receive data from PAD</td>
</tr>
<tr>
<td>2:0</td>
<td>fsel</td>
<td>R/W 0x0</td>
<td>Padring Function Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bits[2:0] selects function[7]...function[0].</td>
</tr>
</tbody>
</table>
24.18  WDT Address Block

24.18.1  WDT Register Map

Table 571: WDT Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>WDT_CR</td>
<td>0x0000_000A</td>
<td>WDT Control Register</td>
<td>Page: 608</td>
</tr>
<tr>
<td>0x04</td>
<td>WDT_TORR</td>
<td>0x0000_0000</td>
<td>WDT Timeout Range Register</td>
<td>Page: 609</td>
</tr>
<tr>
<td>0x08</td>
<td>WDT_CCVR</td>
<td>0x0000_FFFF</td>
<td>WDT Current Counter Value Register</td>
<td>Page: 611</td>
</tr>
<tr>
<td>0x0C</td>
<td>WDT_CRR</td>
<td>0x0000_0000</td>
<td>WDT Counter Restart Register</td>
<td>Page: 611</td>
</tr>
<tr>
<td>0x10</td>
<td>WDT_STAT</td>
<td>0x0000_0000</td>
<td>WDT Interrupt Status Register</td>
<td>Page: 611</td>
</tr>
<tr>
<td>0x14</td>
<td>WDT_EOI</td>
<td>0x0000_0000</td>
<td>WDT Interrupt Clear Register</td>
<td>Page: 612</td>
</tr>
<tr>
<td>0xE4</td>
<td>WDT_COMP_PARAM_5</td>
<td>0x0000_0000</td>
<td>WDT Component Parameters Register 5</td>
<td>Page: 612</td>
</tr>
<tr>
<td>0xE8</td>
<td>WDT_COMP_PARAM_4</td>
<td>0x0000_0000</td>
<td>WDT Component Parameters Register 4</td>
<td>Page: 612</td>
</tr>
<tr>
<td>0xEC</td>
<td>WDT_COMP_PARAM_3</td>
<td>0x0000_0000</td>
<td>WDT Component Parameters Register 3</td>
<td>Page: 613</td>
</tr>
<tr>
<td>0xF0</td>
<td>WDT_COMP_PARAM_2</td>
<td>0x0000_FFFF</td>
<td>WDT Component Parameters Register 2</td>
<td>Page: 613</td>
</tr>
<tr>
<td>0xF4</td>
<td>WDT_COMP_PARAM_1</td>
<td>0x0000_0000</td>
<td>WDT Component Parameters Register 1</td>
<td>Page: 613</td>
</tr>
<tr>
<td>0xF8</td>
<td>WDT_COMP_VERSION</td>
<td>0x3130_372A</td>
<td>WDT Component Version Register</td>
<td>Page: 614</td>
</tr>
<tr>
<td>0xFC</td>
<td>WDT_COMP_TYPE</td>
<td>0x4457_0120</td>
<td>WDT Component Type Register</td>
<td>Page: 615</td>
</tr>
</tbody>
</table>

24.18.2  WDT Registers

24.18.2.1  WDT_CR Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_CR</td>
<td>0x00</td>
</tr>
</tbody>
</table>

Table 572: WDT Control Register (WDT_CR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.18.2.2  WDT_TORR Register

Table 572: WDT Control Register (WDT_CR) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 4:2  | rpl   | R/W          | Reset Pulse Length  
        |       | 0x2          | Writes have no effect when the configuration parameter WDT_HC_RPL is 1, making the register bits read-only. This is used to select the number of pclk cycles for which the system reset stays asserted. The range of values available is 2 to 256 pclk cycles.  
        |       |              | 0x0 = 2 pclk cycles  
        |       |              | 0x1 = 4 pclk cycles  
        |       |              | 0x2 = 8 pclk cycles  
        |       |              | 0x3 = 16 pclk cycles  
        |       |              | 0x4 = 32 pclk cycles  
        |       |              | 0x5 = 64 pclk cycles  
        |       |              | 0x6 = 128 pclk cycles  
        |       |              | 0x7 = 256 pclk cycles |
| 1    | rmod  | R/W          | Response Mode  
        |       | 0x1          | Writes have no effect when the parameter WDT_HC_RMOD = 1, thus this register becomes read-only. Selects the output response generated to a timeout.  
        |       |              | 0x0 = generate a system reset  
        |       |              | 0x1 = first generate an interrupt and if it is not cleared by the time a second timeout occurs then generate a system reset |
| 0    | wdt_en| R/W          | WDT Enable  
        |       | 0x0          | Writable when the configuration parameter WDT ALWAYS_EN = 1, otherwise, it is readable. This bit is used to enable and disable the DW_apb_wdt. When disabled, the counter does not decrement. Thus, no interrupts or system resets are generated. Once this bit has been enabled, it can be cleared only by a system reset.  
        |       |              | 0x0 = WDT disabled  
        |       |              | 0x1 = WDT enabled |

Table 573: WDT Timeout Range Register (WDT_TORR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31:8 | reserved | R            | Reserved and read as 0.  
        |       | 0x0          | |
24.18.2.3  WDT_CCVR Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_CCVR</td>
<td>0x08</td>
</tr>
</tbody>
</table>
### 24.18.2.4 WDT_CRR Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_CRR</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

#### Table 575: WDT Counter Restart Register (WDT_CRR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7:0</td>
<td>wdt_crr</td>
<td>W 0x0</td>
<td>This register is used to restart the WDT counter. As a safety feature to prevent accidental restarts, the value 0x76 must be written. A restart also clears the WDT interrupt. Reading this register returns zero.</td>
</tr>
</tbody>
</table>

### 24.18.2.5 WDT_STAT Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_STAT</td>
<td>0x10</td>
</tr>
</tbody>
</table>

#### Table 576: WDT Interrupt Status Register (WDT_STAT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>wdt_stat</td>
<td>R 0x0</td>
<td>This register shows the interrupt status of the WDT. 0x0 = interrupt is inactive 0x1 = interrupt is active regardless of polarity</td>
</tr>
</tbody>
</table>
24.18.2.6 WDT_EOI Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_EOI</td>
<td>0x14</td>
</tr>
</tbody>
</table>

Table 577: WDT Interrupt Clear Register (WDT_EOI)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>wdt_eoi</td>
<td>R 0x0</td>
<td>Clears the watchdog interrupt. This can be used to clear the interrupt without restarting the watchdog counter.</td>
</tr>
</tbody>
</table>

24.18.2.7 WDT_COMP_PARAM_5 Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_COMP_PARAM_5</td>
<td>0xE4</td>
</tr>
</tbody>
</table>

Table 578: WDT Component Parameters Register 5 (WDT_COMP_PARAM_5)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R 0x0</td>
<td>Data</td>
</tr>
</tbody>
</table>

24.18.2.8 WDT_COMP_PARAM_4 Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_COMP_PARAM_4</td>
<td>0xE8</td>
</tr>
</tbody>
</table>

Table 579: WDT Component Parameters Register 4 (WDT_COMP_PARAM_4)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R 0x0</td>
<td>Data</td>
</tr>
</tbody>
</table>
### 24.18.2.9  WDT_COMP_PARAM_3 Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_COMP_PARAM_3</td>
<td>0xEC</td>
</tr>
</tbody>
</table>

#### Table 580: WDT Component Parameters Register 3 (WDT_COMP_PARAM_3)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R 0x0</td>
<td>Data</td>
</tr>
</tbody>
</table>

### 24.18.2.10  WDT_COMP_PARAM_2 Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_COMP_PARAM_2</td>
<td>0xF0</td>
</tr>
</tbody>
</table>

#### Table 581: WDT Component Parameters Register 2 (WDT_COMP_PARAM_2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>data</td>
<td>R 0xFFFF</td>
<td>Data</td>
</tr>
</tbody>
</table>

### 24.18.2.11  WDT_COMP_PARAM_1 Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_COMP_PARAM_1</td>
<td>0xF4</td>
</tr>
</tbody>
</table>

#### Table 582: WDT Component Parameters Register 1 (WDT_COMP_PARAM_1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:29</td>
<td>Reserved</td>
<td>RSVVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>28:24</td>
<td>wdt_cnt_width</td>
<td>R 0x0</td>
<td>Count Width</td>
</tr>
<tr>
<td>23:20</td>
<td>wdt_dflt_top_init</td>
<td>R 0x0</td>
<td>Dflt Top Init</td>
</tr>
<tr>
<td>19:16</td>
<td>wdt_dflt_top</td>
<td>R 0x0</td>
<td>Dflt Top</td>
</tr>
</tbody>
</table>
### 24.18.2.12 WDT_COMP_VERSION Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_COMP_VERSION</td>
<td>0xF8</td>
</tr>
</tbody>
</table>

#### Table 583: WDT Component Version Register (WDT_COMP_VERSION)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>wdt_comp_version</td>
<td>R 0x3130_372A</td>
<td>ASCII value for each number in the version, followed by <em>. For example, 32_30_31_2A represents the version 2.01</em>. Reset Value: See the Releases table in the DW_apb_rtc Release Notes.</td>
</tr>
</tbody>
</table>
24.18.2.13 WDT_COMP_TYPE Register

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDT_COMP_TYPE</td>
<td>0xFC</td>
</tr>
</tbody>
</table>

Table 584: WDT Component Type Register (WDT_COMP_TYPE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>wdt_comp_type</td>
<td>R 0x4457_0120</td>
<td>Component Type</td>
</tr>
</tbody>
</table>
24.19    RTC Address Block

24.19.1    RTC Register Map

Table 585: RTC Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>CNT_EN_REG</td>
<td>0x0000_0000</td>
<td>Counter Enable Register</td>
<td>Page: 616</td>
</tr>
<tr>
<td>0x20</td>
<td>INT_RAW_REG</td>
<td>0x0000_0000</td>
<td>Interrupt Raw Register</td>
<td>Page: 617</td>
</tr>
<tr>
<td>0x24</td>
<td>INT_REG</td>
<td>0x0000_0000</td>
<td>Interrupt Register</td>
<td>Page: 618</td>
</tr>
<tr>
<td>0x28</td>
<td>INT_MSK_REG</td>
<td>0x0001_8000</td>
<td>Interrupt Mask Register</td>
<td>Page: 618</td>
</tr>
<tr>
<td>0x40</td>
<td>CNT_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Counter Control Register</td>
<td>Page: 619</td>
</tr>
<tr>
<td>0x50</td>
<td>CNT_VAL_REG</td>
<td>0x0000_0000</td>
<td>Counter Value Register</td>
<td>Page: 620</td>
</tr>
<tr>
<td>0x60</td>
<td>CNT_UPP_VAL_REG</td>
<td>0xFFFF_FFFF</td>
<td>Counter Upper Value Register</td>
<td>Page: 620</td>
</tr>
<tr>
<td>0x70</td>
<td>CNT_ALARM_VAL_REG</td>
<td>0xFFFF_FFFF</td>
<td>Counter Alarm Value Register</td>
<td>Page: 621</td>
</tr>
<tr>
<td>0x80</td>
<td>CLK_CNTL_REG</td>
<td>0x0000_0000</td>
<td>Clock Control Register</td>
<td>Page: 621</td>
</tr>
</tbody>
</table>

24.19.2    RTC Registers

24.19.2.1    Counter Enable Register (CNT_EN_REG)

Table 586: Counter Enable Register (CNT_EN_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:19</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>18</td>
<td>sts_resetn</td>
<td>R 0x0</td>
<td>System Reset Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>CPU must poll this bit for a 1 before accessing any other registers.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = indicates that the system reset is still asserted</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = indicates that the system reset is deasserted</td>
</tr>
<tr>
<td>17</td>
<td>cnt_rst_done</td>
<td>R 0x0</td>
<td>Counter Reset Done Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Writing 1 to CNT_RESET will set this bit to 0 until the counter finishes resetting.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = indicates that the counter is still resetting</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = indicates that the counter has been reset</td>
</tr>
</tbody>
</table>
### Table 586: Counter Enable Register (CNT_EN_REG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 16   | cnt_run   | R 0x0       | Counter Enabled Status  
This bit can be polled to see when the counter is really enabled.  
0x0 = counter is disabled  
0x1 = counter is enabled |
| 15:3 | Reserved  | RSVD        | Reserved. Always write 0. Ignore read value. |
| 2    | cnt_reset | W 0x0       | Counter Reset  
0x0 = no action  
0x1 = reset the counter (counter is reset to 0; channel output states are reset to 0; poll CNT_RST_DONE for 1 before writing to any other registers) |
| 1    | cnt_stop  | W 0x0       | Counter Disable  
0x0 = no action  
0x1 = disable the counter (poll CNT_RUN for 0 to confirm that the counter is disabled internally) |
| 0    | cnt_start | W 0x0       | Counter Enable  
0x0 = no action  
0x1 = enable the counter (poll CNT_RUN for 1 to confirm that the counter is enabled internally) |

### 24.19.2.2 Interrupt Raw Register (INT_RAW_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_RAW_REG</td>
<td>0x20</td>
</tr>
</tbody>
</table>

#### Table 587: Interrupt Raw Register (INT_RAW_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:17</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 16      | cnt_upp_int | R/W1CLR 0x0 | Counter-Reach-Upper Interrupt Status  
If UPP_VAL is set to the maximum value, then this bit is equivalent to an overflow status.  
0x0 = status cleared  
0x1 = counter has reached UPP_VAL |
| 15      | cnt_alarm_int | R/W1CLR 0x0 | Counter-Reach-Alarm Interrupt Status  
If ALARM_VAL is set to the maximum value, then this bit is equivalent to an overflow status.  
0x0 = status cleared  
0x1 = counter has reached ALARM_VAL |
**24.19.2.3 Interrupt Register (INT_REG)**

INT_MSK_REG is combined with STS_REG to form this register. Masked bits will be 0 while unmasked bits will be the same value as the ones in STS_REG.

If any bits in this register is 1, an interrupt will be generated.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:17</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>16</td>
<td>cnt_upp_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CNT_UPP_INT</td>
</tr>
<tr>
<td>15</td>
<td>cnt_alarm_intr</td>
<td>R 0x0</td>
<td>Masked Signal of CNT_ALARM_INT</td>
</tr>
<tr>
<td>14:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

**24.19.2.4 Interrupt Mask Register (INT_MSK_REG)**

INT_MSK_REG is combined with STS_REG to form INT_REG. Masked bits will be 0 while unmasked bits will be the same value as the ones in STS_REG.

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_MSK_REG</td>
<td>0x28</td>
</tr>
</tbody>
</table>

**Table 589: Interrupt Mask Register (INT_MSK_REG)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:17</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### Counter Control Register (CNT_CNTL_REG)

**Instance Name**
- CNT_CNTL_REG

**Offset**
- 0x40

#### Table 590: Counter Control Register (CNT_CNTL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9:8</td>
<td>cnt_updt_mod</td>
<td>R/W 0x0</td>
<td>Counter Update Mode&lt;br&gt;0x0 = update off&lt;br&gt;0x1 = reserved&lt;br&gt;0x2 = Auto-update (use when counter clock is at least 5 times slower than the register bus clock)&lt;br&gt;0x3 = reserved</td>
</tr>
<tr>
<td>7:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>cnt_dbg_act</td>
<td>R/W 0x0</td>
<td>Counter Debug Mode Action Mask&lt;br&gt;0x0 = in debug mode, stop the counters&lt;br&gt;0x1 = in debug mode, counters are not affected</td>
</tr>
<tr>
<td>3:0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.19.2.6 Counter Value Register (CNT_VAL_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CNT_VAL_REG</td>
<td>0x50</td>
</tr>
</tbody>
</table>

**Table 591: Counter Value Register (CNT_VAL_REG)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>cnt_val</td>
<td>R 0x0</td>
<td>Counter Value&lt;br&gt;This register displays the current counter value. The update method for CNT_VAL is chosen in CNT_UPDT_MOD.</td>
</tr>
</tbody>
</table>

### 24.19.2.7 Counter Upper Value Register (CNT_UPP_VAL_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CNT_UPP_VAL_REG</td>
<td>0x60</td>
</tr>
</tbody>
</table>

**Table 592: Counter Upper Value Register (CNT_UPP_VAL_REG)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>upp_val</td>
<td>R/W 0xFFFF_ FFFF</td>
<td>Counter Upper Value&lt;br&gt;Do not set to 0. The reset value is the maximum value of the counter, where all bits are 1.&lt;br&gt;In the event that the counter reaches this value (counter-reach-upper), the counter will overflow to 0. Setting this value to all 1s is equivalent to a free running up-counter.&lt;br&gt;Writing to this register will shadow it and start the internal shadow register update. The update finishes during the next counter-reach-upper event and will continue to update if it detects a new UPP_VAL. To guarantee an immediate update with the current UPP_VAL, write 1 to CNT_RESET.</td>
</tr>
</tbody>
</table>

### 24.19.2.8 Counter Alarm Value Register (CNT_ALARM_VAL_REG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CNT_ALARM_VAL_REG</td>
<td>0x70</td>
</tr>
</tbody>
</table>

Product Data Sheet  All information in this document is subject to legal disclaimers.  © NXP B.V. 2020. All rights reserved.
Rev. 3 - July 14, 2020
### 24.19.2.9 Clock Control Register (CLK_CNTL_REG)

#### Table 594: Clock Control Register (CLK_CNTL_REG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 11:8  | clk_div | R/W 0x0 | Clock Divider  
The frequency of the divided clock \( f_{\text{div}} \) is calculated from the frequency of the counter clock \( f_{\text{clk}} \) using this formula:  
\[ f_{\text{div}} = \frac{f_{\text{clk}}}{2^{\text{CLK_DIV}}} \] |
| 7:0   | Reserved | RSVD | Reserved. Always write 0. Ignore read value. |
# 24.20 PMU Address Block

## 24.20.1 PMU Register Map

Table 595: PMU Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x000</td>
<td>PWR_MODE</td>
<td>0x0000_0000</td>
<td>Power Mode Control Register</td>
<td>Page: 624</td>
</tr>
<tr>
<td>0x004</td>
<td>BOOT_JTAG</td>
<td>0x0000_000E</td>
<td>BOOT_JTAG Register</td>
<td>Page: 624</td>
</tr>
<tr>
<td>0x008</td>
<td>LAST_RST_CAUSE</td>
<td>0x0000_0000</td>
<td>Last Reset Cause Register</td>
<td>Page: 625</td>
</tr>
<tr>
<td>0x00C</td>
<td>LAST_RST_CLR</td>
<td>0x0000_0000</td>
<td>Last Reset Cause Clear Register</td>
<td>Page: 625</td>
</tr>
<tr>
<td>0x010</td>
<td>WAKE_SRC_CLR</td>
<td>0x0000_0000</td>
<td>Wake up Source Clear Register</td>
<td>Page: 626</td>
</tr>
<tr>
<td>0x014</td>
<td>PWR_MODE_STATUS</td>
<td>0x0000_0000</td>
<td>Power Mode Status Register</td>
<td>Page: 627</td>
</tr>
<tr>
<td>0x018</td>
<td>CLK_SRC</td>
<td>0x0000_0001</td>
<td>Clock Source Selection Register</td>
<td>Page: 627</td>
</tr>
<tr>
<td>0x01C</td>
<td>WAKEUP_STATUS</td>
<td>0x0000_0000</td>
<td>Wakeup Status Register</td>
<td>Page: 627</td>
</tr>
<tr>
<td>0x020</td>
<td>PMIP_BRN_INT_SEL</td>
<td>0x0000_0000</td>
<td>PMIP Brown Interrupt Select</td>
<td>Page: 628</td>
</tr>
<tr>
<td>0x028</td>
<td>CLK_RDY</td>
<td>0x0000_0000</td>
<td>Clock Ready Register</td>
<td>Page: 628</td>
</tr>
<tr>
<td>0x02C</td>
<td>RC32M_CTRL</td>
<td>0x0000_0000</td>
<td>RC 32M Control Register</td>
<td>Page: 629</td>
</tr>
<tr>
<td>0x034</td>
<td>SFLL_CTRL1</td>
<td>0x0000_0060</td>
<td>SFLL Control Register 1</td>
<td>Page: 630</td>
</tr>
<tr>
<td>0x038</td>
<td>ANA_GRP_CTRL0</td>
<td>0x0000_0004</td>
<td>Analog Group Control Register</td>
<td>Page: 630</td>
</tr>
<tr>
<td>0x03C</td>
<td>SFLL_CTRL0</td>
<td>0x0210_7800</td>
<td>SFLL Control Register 2</td>
<td>Page: 631</td>
</tr>
<tr>
<td>0x040</td>
<td>PWR_CFG</td>
<td>0x0000_07F0</td>
<td>Power Configuration Register</td>
<td>Page: 632</td>
</tr>
<tr>
<td>0x044</td>
<td>PWR_STAT</td>
<td>0x0000_0000</td>
<td>Power Status Register</td>
<td>Page: 632</td>
</tr>
<tr>
<td>0x048</td>
<td>WF_OPT0</td>
<td>0x0000_0000</td>
<td>WF OPT Power-Saving Register 0</td>
<td>Page: 632</td>
</tr>
<tr>
<td>0x04C</td>
<td>WF_OPT1</td>
<td>0x0000_0000</td>
<td>WF OPT Power-Saving Register 1</td>
<td>Page: 633</td>
</tr>
<tr>
<td>0x054</td>
<td>PMIP_BRN_CFG</td>
<td>0x0000_0000</td>
<td>Brown-out Configuration Register</td>
<td>Page: 633</td>
</tr>
<tr>
<td>0x058</td>
<td>AUPPLL_LOCK</td>
<td>0x0000_0000</td>
<td>AUPPLL Lock Status Register</td>
<td>Page: 634</td>
</tr>
<tr>
<td>0x05C</td>
<td>ANA_GRP_CTRL1</td>
<td>0x0000_0024</td>
<td>BG Control Register</td>
<td>Page: 634</td>
</tr>
<tr>
<td>0x060</td>
<td>PMIP_PWR_CONFIG</td>
<td>0x0000_0003</td>
<td>Power Configuration Register</td>
<td>Page: 635</td>
</tr>
<tr>
<td>0x06C</td>
<td>PMIP_TEST</td>
<td>0x0000_0000</td>
<td>PMIP Test Register</td>
<td>Page: 635</td>
</tr>
<tr>
<td>0x078</td>
<td>AUPPLL_CTRL0</td>
<td>0x0000_AABAB</td>
<td>Audio PLL Control Register</td>
<td>Page: 636</td>
</tr>
<tr>
<td>0x07C</td>
<td>PERI_CLK_EN</td>
<td>0x04FA_0F90</td>
<td>Peripheral Clock Enable Register</td>
<td>Page: 636</td>
</tr>
<tr>
<td>0x080</td>
<td>UART_FAST_CLK_DIV</td>
<td>0x0083_94E3</td>
<td>UART Fast Clock Div Register</td>
<td>Page: 638</td>
</tr>
<tr>
<td>0x084</td>
<td>UART_SLOW_CLK_DIV</td>
<td>0x003D_0890</td>
<td>UART Slow Clock Div Register</td>
<td>Page: 638</td>
</tr>
</tbody>
</table>
### Table 595: PMU Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x088</td>
<td>UART_CLK_SEL</td>
<td>0x0000_0000</td>
<td>UART Clock Select Register</td>
<td>Page: 639</td>
</tr>
<tr>
<td>0x08C</td>
<td>MCU_CORE_CLK_DIV</td>
<td>0x0000_0001</td>
<td>MCU CORE Clock Divider Ratio Register</td>
<td>Page: 640</td>
</tr>
<tr>
<td>0x090</td>
<td>PERI0_CLK_DIV</td>
<td>0x0821_0842</td>
<td>Peripheral0 Clock Divider Ratio Register</td>
<td>Page: 640</td>
</tr>
<tr>
<td>0x094</td>
<td>PERI1_CLK_DIV</td>
<td>0x0020_1110</td>
<td>Peripheral1 Clock Divider Ratio Register</td>
<td>Page: 640</td>
</tr>
<tr>
<td>0x098</td>
<td>PERI2_CLK_DIV</td>
<td>0x0010_0001</td>
<td>Peripheral2 Clock Divider Ratio Register</td>
<td>Page: 641</td>
</tr>
<tr>
<td>0x09C</td>
<td>GAU_CLK_SEL</td>
<td>0x0000_0000</td>
<td>Select Signal for GAU MCLK Register</td>
<td>Page: 642</td>
</tr>
<tr>
<td>0x0A0</td>
<td>LOW_PWR_CTRL</td>
<td>0x0000_0002</td>
<td>Low Power Control in PM3/PM4 Mode Register</td>
<td>Page: 643</td>
</tr>
<tr>
<td>0x0A4</td>
<td>IO_PAD_PWR_CFG</td>
<td>0x0009_F00F</td>
<td>I/O Pad Power Configuration Register</td>
<td>Page: 643</td>
</tr>
<tr>
<td>0x0A8</td>
<td>EXT_SEL_REG0</td>
<td>0x0000_0000</td>
<td>Extra Interrupt Select Register 0</td>
<td>Page: 645</td>
</tr>
<tr>
<td>0x0B0</td>
<td>AUPLL_CTRL1</td>
<td>0x2000_CC12</td>
<td>USB and Audio PLL Control Register</td>
<td>Page: 647</td>
</tr>
<tr>
<td>0x0B4</td>
<td>GAU_CTRL</td>
<td>0x0000_001F</td>
<td>CAU Control Register</td>
<td>Page: 648</td>
</tr>
<tr>
<td>0x0B8</td>
<td>RC32K_CTRL0</td>
<td>0x0000_0000</td>
<td>RC32k Control 0 Register</td>
<td>Page: 649</td>
</tr>
<tr>
<td>0x0BC</td>
<td>RC32K_CTRL1</td>
<td>0x0018_0000</td>
<td>RC32k Control 1 Register</td>
<td>Page: 649</td>
</tr>
<tr>
<td>0x0C0</td>
<td>XTAL32K_CTRL</td>
<td>0x0000_0204</td>
<td>XTAL32k Control Register</td>
<td>Page: 650</td>
</tr>
<tr>
<td>0x0C4</td>
<td>PMIP_CMP_CTRL</td>
<td>0x0000_0100</td>
<td>PMIP Comparator Control Register</td>
<td>Page: 651</td>
</tr>
<tr>
<td>0x0C8</td>
<td>PMIP_BRNDET_AV18</td>
<td>0x0001_28C3</td>
<td>PMIP Brown-out AV18 Register</td>
<td>Page: 652</td>
</tr>
<tr>
<td>0x0D0</td>
<td>PMIP_BRNDET_VBAT</td>
<td>0x0004_A328</td>
<td>PMIP Brown-out VBAT Register</td>
<td>Page: 653</td>
</tr>
<tr>
<td>0x0D4</td>
<td>PMIP_BRNDET_V12</td>
<td>0x0000_2510</td>
<td>PMIP Brown-out V12 Register</td>
<td>Page: 653</td>
</tr>
<tr>
<td>0x0D8</td>
<td>PMIP_LDO_CTRL</td>
<td>0x0000_0CB3</td>
<td>PMIP LDO Control Register</td>
<td>Page: 654</td>
</tr>
<tr>
<td>0x0DC</td>
<td>PERI_CLK_SRC</td>
<td>0x0000_0000</td>
<td>PERI Clock Source Register</td>
<td>Page: 655</td>
</tr>
<tr>
<td>0x0E0</td>
<td>PMIP_RSVD</td>
<td>0x0000_0000</td>
<td>Unused Register</td>
<td>Page: 655</td>
</tr>
<tr>
<td>0x0E4</td>
<td>GPT0_CTRL</td>
<td>0x0000_0001</td>
<td>GPT0 Control Register</td>
<td>Page: 656</td>
</tr>
<tr>
<td>0x0E8</td>
<td>GPT1_CTRL</td>
<td>0x0000_0001</td>
<td>GPT1 Control Register</td>
<td>Page: 656</td>
</tr>
<tr>
<td>0x0EC</td>
<td>GPT2_CTRL</td>
<td>0x0000_0001</td>
<td>GPT2 Control Register</td>
<td>Page: 657</td>
</tr>
<tr>
<td>0x0F0</td>
<td>GPT3_CTRL</td>
<td>0x0000_0001</td>
<td>GPT3 Control Register</td>
<td>Page: 657</td>
</tr>
<tr>
<td>0x0F4</td>
<td>WAKEUP_EDGE_DETECT</td>
<td>0x0000_0003</td>
<td>Wakeup Edge Detect Register</td>
<td>Page: 658</td>
</tr>
<tr>
<td>0x0F8</td>
<td>AON_CLK_CTRL</td>
<td>0x0000_0012</td>
<td>AON Clock Control Register</td>
<td>Page: 658</td>
</tr>
<tr>
<td>0x0FC</td>
<td>PERI3_CTRL</td>
<td>0x0004_C304</td>
<td>PERI3 Control Register</td>
<td>Page: 659</td>
</tr>
</tbody>
</table>
24.20.2 PMU Registers

24.20.2.1 Power Mode Control Register (PWR_MODE)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x114</td>
<td>wakeup_mask</td>
<td>0x0000_0000</td>
<td>Wakeup Mask Interrupt Register</td>
<td>Page: 659</td>
</tr>
<tr>
<td>0x118</td>
<td>wlan Ctrl</td>
<td>0x0001_2000</td>
<td>WLAN Control Register</td>
<td>Page: 660</td>
</tr>
<tr>
<td>0x11C</td>
<td>wlan Ctrl1</td>
<td>0x0000_0000</td>
<td>WLAN Control 1 Register</td>
<td>Page: 661</td>
</tr>
</tbody>
</table>

Table 595: PMU Register Map (Continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x114</td>
<td>wakeup_mask</td>
<td>0x0000_0000</td>
<td>Wakeup Mask Interrupt Register</td>
<td>Page: 659</td>
</tr>
<tr>
<td>0x118</td>
<td>wlan Ctrl</td>
<td>0x0001_2000</td>
<td>WLAN Control Register</td>
<td>Page: 660</td>
</tr>
<tr>
<td>0x11C</td>
<td>wlan Ctrl1</td>
<td>0x0000_0000</td>
<td>WLAN Control 1 Register</td>
<td>Page: 661</td>
</tr>
</tbody>
</table>

Table 596: Power Mode Control Register (PWR_MODE)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1:0</td>
<td>pwr_mode</td>
<td>W 0x0</td>
<td>Power Mode Switch</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = PM0 or PM1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = PM2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = PM3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = PM4</td>
</tr>
</tbody>
</table>

24.20.2.2 BOOT_JTAG Register (BOOT_JTAG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BOOT_JTAG</td>
<td>0x004</td>
</tr>
</tbody>
</table>

Table 597: BOOT_JTAG Register (BOOT_JTAG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>jtag_en</td>
<td>R/W 0x0</td>
<td>JTAG Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable JTAG</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable JTAG</td>
</tr>
</tbody>
</table>
### 24.20.2.3 Last Reset Cause Register (LAST_RST_CAUSE)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LAST_RST_CAUSE</td>
<td>0x008</td>
</tr>
</tbody>
</table>

**Table 598: Last Reset Cause Register (LAST_RST_CAUSE)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>wdt_rst</td>
<td>R 0x0</td>
<td>WDT Reset&lt;br&gt;0x0 = reset cause is not watchdog timer&lt;br&gt;0x1 = reset cause is watchdog timer</td>
</tr>
<tr>
<td>4</td>
<td>cm4_lockup</td>
<td>R 0x0</td>
<td>CM4 Lockup&lt;br&gt;0x0 = reset cause is not lockup&lt;br&gt;0x1 = reset cause is lockup</td>
</tr>
<tr>
<td>3</td>
<td>cm4_sysresetreq</td>
<td>R 0x0</td>
<td>CM4 System Software Reset Request&lt;br&gt;0x0 = reset cause is not system software reset request&lt;br&gt;0x1 = reset cause is system software reset request</td>
</tr>
<tr>
<td>2</td>
<td>brownout_av18</td>
<td>R 0x0</td>
<td>AV18 Power Brown-out&lt;br&gt;0x0 = AV18 power brown-out not detected&lt;br&gt;0x1 = AV18 power brown-out detected</td>
</tr>
<tr>
<td>1</td>
<td>brownout_v12</td>
<td>R 0x0</td>
<td>AV12 Power Brown-out&lt;br&gt;0x0 = AV12 power brown-out not detected&lt;br&gt;0x1 = AV12 power brown-out detected</td>
</tr>
<tr>
<td>0</td>
<td>brownout_vbat</td>
<td>R 0x0</td>
<td>VBAT Power Brown-out&lt;br&gt;0x0 = VBAT power brown-out not detected&lt;br&gt;0x1 = VBAT power brown-out detected</td>
</tr>
</tbody>
</table>

### 24.20.2.4 Last Reset Cause Clear Register (LAST_RST_CLR)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LAST_RST_CLR</td>
<td>0x00C</td>
</tr>
</tbody>
</table>

**Table 599: Last Reset Cause Clear Register (LAST_RST_CLR)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>wdt_rst_clr</td>
<td>R/W 0x0</td>
<td>Clear Watchdog Timer Reset Request</td>
</tr>
</tbody>
</table>
24.20.2.5  Wake-up Source Clear Register (WAKE_SRC_CLR)

Table 600: Wake-up Source Clear Register (WAKE_SRC_CLR)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>clr_comp_int</td>
<td>R/W 0x0</td>
<td>Clear PMIP Comp Interrupt Request</td>
</tr>
<tr>
<td>3</td>
<td>clr_RTC_int</td>
<td>R/W 0x0</td>
<td>Clear RTC Interrupt Request</td>
</tr>
<tr>
<td>2</td>
<td>clr_wl_int</td>
<td>R/W 0x0</td>
<td>Clear WL Interrupt Request</td>
</tr>
<tr>
<td>1</td>
<td>clr_pin1_int</td>
<td>R/W 0x0</td>
<td>Clear Pin1 Interrupt Request</td>
</tr>
<tr>
<td>0</td>
<td>clr_pin0_int</td>
<td>R/W 0x0</td>
<td>Clear Pin0 Interrupt Request</td>
</tr>
</tbody>
</table>

24.20.2.6  Power Mode Status Register (PWR_MODE_STATUS)

Table 601: Power Mode Status Register (PWR_MODE_STATUS)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWR_MODE_STATUS</td>
<td>0x014</td>
</tr>
</tbody>
</table>
### Table 601: Power Mode Status Register (PWR_MODE_STATUS)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1:0</td>
<td>pwr_mode_status</td>
<td>R</td>
<td>Power Mode Status</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = wake up from PM2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = wake up from PM3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = wake up from PM4</td>
</tr>
</tbody>
</table>

### 24.20.2.7 Clock Source Selection Register (CLK_SRC)

**Table 602: Clock Source Selection Register (CLK_SRC)**

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK_SRC</td>
<td>0x018</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1:0</td>
<td>sys_clkSel</td>
<td>R/W</td>
<td>System Clock Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x1</td>
<td>0x0 = SFLL 200 MHz clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = RC 32 MHz clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = XTAL 32 MHz clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = RC 32 MHz clock</td>
</tr>
</tbody>
</table>

### 24.20.2.8 Wakeup Status Register (WAKEUP_STATUS)

**Table 603: Wakeup Status Register (WAKEUP_STATUS)**

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WAKEUP_STATUS</td>
<td>0x01C</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>pmip_comp_wakeup_status</td>
<td>R</td>
<td>pmip_comp Wakeup Status</td>
</tr>
</tbody>
</table>
Table 603: Wakeup Status Register (WAKEUP_STATUS) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>rtc_wakeup_status</td>
<td>R 0x0</td>
<td>RTC Wakeup Status</td>
</tr>
<tr>
<td>2</td>
<td>wlint_wakeup_status</td>
<td>R 0x0</td>
<td>WLAN Interrupt Wakeup Status</td>
</tr>
<tr>
<td>1</td>
<td>pin1_wakeup_status</td>
<td>R 0x0</td>
<td>External Pin1 Wakeup Status</td>
</tr>
<tr>
<td>0</td>
<td>pin0_wakeup_status</td>
<td>R 0x0</td>
<td>External Pin0 Wakeup Status</td>
</tr>
</tbody>
</table>

24.20.2.9 PMIP Brown Interrupt Select (PMIP_BRN_INT_SEL)

Table 604: PMIP Brown Interrupt Select (PMIP_BRN_INT_SEL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>pmip_brn_int_sel</td>
<td>R/W 0x0</td>
<td>PMIP Brown-out Interrupt Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = generate an interrupt when VBAT brown-out</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = reset chip when VBAT brown-out</td>
</tr>
</tbody>
</table>

24.20.2.10 Clock Ready Register (CLK_RDY)

Table 605: Clock Ready Register (CLK_RDY)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>6</td>
<td>xtal32m_clk_rdy</td>
<td>R 0x0</td>
<td>XTAL32M Clock Ready</td>
</tr>
</tbody>
</table>
### 24.20.2.11 RC 32M Control Register (RC32M_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RC32M_CTRL</td>
<td>0x02C</td>
</tr>
</tbody>
</table>

#### Table 606: RC 32M Control Register (RC32M_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>cal_allow</td>
<td>R/W 0x0</td>
<td>Allow Calibration Command from PMU</td>
</tr>
<tr>
<td>0</td>
<td>cal_in_progress</td>
<td>R 0x0</td>
<td>Asserts High When Calibration in Progress</td>
</tr>
</tbody>
</table>

### 24.20.2.12 SFLL Control Register 1 (SFLL_CTRL1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SFLL_CTRL1</td>
<td>0x034</td>
</tr>
</tbody>
</table>

---

**Table 605: Clock Ready Register (CLK_RDY) (Continued)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>pll_audio_rdy</td>
<td>R 0x0</td>
<td>PLL Audio Ready 0x0 = PLL audio clock not ready for use 0x1 = PLL audio clock ready for use</td>
</tr>
<tr>
<td>3</td>
<td>x32k_rdy</td>
<td>R 0x0</td>
<td>XTAL 32k Ready 0x0 = XTAL 32k clock not ready for use 0x1 = XTAL 32k clock ready for use</td>
</tr>
<tr>
<td>2</td>
<td>rc32m_rdy</td>
<td>R 0x0</td>
<td>RC 32M Ready 0x0 = RC 32M clock not ready for use 0x1 = RC 32M clock ready for use</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>pll_clk_rdy</td>
<td>R 0x0</td>
<td>PLL Clock Ready 0x0 = PLL clock not ready for use 0x1 = PLL clock ready for use</td>
</tr>
</tbody>
</table>
Table 607: SFLL Control Register 1 (SFLL_CTRL1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>reg_pll_pu_int</td>
<td>R/W 0x0</td>
<td>PLL PU Int</td>
</tr>
<tr>
<td>30:23</td>
<td>sfll_reserve_in</td>
<td>R/W 0x0</td>
<td>SFLL Reserved Input</td>
</tr>
<tr>
<td>22:21</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>20:19</td>
<td>sfll_div_sel</td>
<td>R/W 0x0</td>
<td>Post Divider</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = divide by 1 (bypass)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = divide by 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x2 = divide by 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x3 = divide by 8</td>
</tr>
<tr>
<td>18:12</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11:9</td>
<td>sfll_test_ana</td>
<td>R/W 0x0</td>
<td>DC Points Testing Control</td>
</tr>
<tr>
<td>8:0</td>
<td>sfll_refdiv</td>
<td>R/W 0x60</td>
<td>Reference Clock Divider Select</td>
</tr>
</tbody>
</table>

24.20.2.13 Analog Group Control Register (ANA_GRP_CTRL0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ANA_GRP_CTRL0</td>
<td>0x038</td>
</tr>
</tbody>
</table>

Table 608: Analog Group Control Register (ANA_GRP_CTRL0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2</td>
<td>pu</td>
<td>R/W 0x1</td>
<td>Power-up Signal for Whole Block</td>
</tr>
<tr>
<td>1</td>
<td>pu_xtal</td>
<td>R/W 0x0</td>
<td>Power-up Signal for XTAL Circuit</td>
</tr>
<tr>
<td>0</td>
<td>pu_osc</td>
<td>R/W 0x0</td>
<td>Power-up Signal for OSC Circuit</td>
</tr>
</tbody>
</table>
### 24.20.2.14 SFLL Control Register 2 (SFLL_CTRL0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SFLL_CTRL0</td>
<td>0x03C</td>
</tr>
</tbody>
</table>

#### Table 609: SFLL Control Register 2 (SFLL_CTRL0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:27</td>
<td>Reserved</td>
<td>--</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 26   | sfll_lock      | R 0x0        | SFLL Lock  
0x0 = PLL module unlocked  
0x1 = PLL module locked |
| 25   | sfll_refclk_sel| R/W 0x1      | Reference Clock Source Select  
0x0 = RC 32M  
0x1 = XTAL 32M from WLAN |
| 24:22| Reserved       | RSVD --      | Reserved. Always write 0. Ignore read value. |
| 21:20| sfll_kvco      | R/W 0x1      | Select VCO Running Range Default Value for Output clock=200M  
0x0 = 150 MHz to 177 MHz  
0x1 = 177 MHz to 212 MHz  
0x2 = 212 MHz to 240 MHz  
0x3 = 240 MHz to 300 MHz |
| 19:16| Reserved       | RSVD --      | Reserved. Always write 0. Ignore read value. |
| 15:7 | sfll_fbddiv    | R/W 0xF0     | Feedback Clock Divider Select |
| 6:1  | Reserved       | RSVD --      | Reserved. Always write 0. Ignore read value. |
| 0    | sfll_pu        | R/W 0x0      | Power-up Signal for the Flock  
0x0 = power down  
0x1 = power up |

### 24.20.2.15 Power Configuration Register (PWR_CFG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWR_CFG</td>
<td>0x040</td>
</tr>
</tbody>
</table>
### Table 610: Power Configuration Register (PWR_CFG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>10:4</td>
<td>pm3_ret_mem_cfg</td>
<td>R/W 0x7F</td>
<td>Retention Memory Enable Register in PM3 Mode</td>
</tr>
<tr>
<td>3:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

### 24.20.2.16 Power Status Register (PWR_STAT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWR_STAT</td>
<td>0x044</td>
</tr>
</tbody>
</table>

#### Table 611: Power Status Register (PWR_STAT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>7</td>
<td>av18_rdy</td>
<td>R 0x0</td>
<td>av18_rdy</td>
</tr>
<tr>
<td>6:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>v12_lido_rdy</td>
<td>R 0x0</td>
<td>v12_lido_rdy</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

### 24.20.2.17 WF OPT Power-Saving Register 0 (WF_OPT0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WF_OPT0</td>
<td>0x048</td>
</tr>
</tbody>
</table>

#### Table 612: WF OPT Power-Saving Register 0 (WF_OPT0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.20.2.18 WF OPT Power-Saving Register 1 (WF_OPT1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WF_OPT1</td>
<td>0x04C</td>
</tr>
</tbody>
</table>

#### Table 613: WF OPT Power-Saving Register 1 (WF_OPT1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:2</td>
<td>spare</td>
<td>R/W 0x0</td>
<td>Spare</td>
</tr>
<tr>
<td>1:0</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

### 24.20.2.19 Brown-out Configuration Register (PMIP_BRN_CFG)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PMIP_BRN_CFG</td>
<td>0x054</td>
</tr>
</tbody>
</table>

#### Table 614: Brown-out Configuration Register (PMIP_BRN_CFG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVRD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3</td>
<td>brndet_av18_rst_en</td>
<td>R/W 0x0</td>
<td>Brown-out AV18 Reset Enable</td>
</tr>
</tbody>
</table>
Table 614: Brown-out Configuration Register (PMIP_BRN_CFG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>brndet_vbat_rst_en</td>
<td>R/W 0x0</td>
<td>Brown-out VBAT Reset Enable</td>
</tr>
<tr>
<td>0</td>
<td>brndet_v12_rst_en</td>
<td>R/W 0x0</td>
<td>Brown-out AV12 Reset Enable</td>
</tr>
</tbody>
</table>

24.20.2.20 AUPLL Lock Status Register (AUPLL_LOCK)

**Instance Name**
- AUPLL_LOCK

**Offset**
- 0x058

Table 615: AUPLL Lock Status Register (AUPLL_LOCK)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>reserved_out_1</td>
<td>R/W 0x0</td>
<td>Reserved Out 1</td>
</tr>
<tr>
<td>2</td>
<td>aupll_lock</td>
<td>R 0x0</td>
<td>AUPLL Lock</td>
</tr>
<tr>
<td>1:0</td>
<td>reserved_out_0</td>
<td>R/W 0x0</td>
<td>Reserved Out 0</td>
</tr>
</tbody>
</table>

24.20.2.21 BG Control Register (ANA_GRP_CTRL1)

**Instance Name**
- ANA_GRP_CTRL1

**Offset**
- 0x05C

Table 616: BG Control Register (ANA_GRP_CTRL1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>10</td>
<td>bypass</td>
<td>R/W 0x0</td>
<td>XTAL OSC Bypass Control Signal</td>
</tr>
<tr>
<td>9:7</td>
<td>test</td>
<td>R/W 0x0</td>
<td>Analog Test Control Bits</td>
</tr>
</tbody>
</table>
Table 616: BG Control Register (ANA_GRP_CTRL1) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6:5</td>
<td>bg_sel</td>
<td>R/W 0x1</td>
<td>Selects the Bandgap Voltage</td>
</tr>
<tr>
<td>4</td>
<td>r_orien_sel</td>
<td>R/W 0x0</td>
<td>RPP Resister Orientation Selection</td>
</tr>
<tr>
<td>3</td>
<td>gainx2</td>
<td>R/W 0x0</td>
<td>OSC Gain Control</td>
</tr>
<tr>
<td>2:0</td>
<td>bg_ctrl</td>
<td>R/W 0x4</td>
<td>Bandgap Control</td>
</tr>
</tbody>
</table>

24.20.2.22 Power Configuration Register (PMIP_PWR_CONFIG)

Table 617: Power Configuration Register (PMIP_PWR_CONFIG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>2</td>
<td>av18_ext</td>
<td>R/W 0x0</td>
<td>AV18 External. Assert high if external DC/DC chip will provide AV18=1.8V during PM0/1 modes.</td>
</tr>
<tr>
<td>1:0</td>
<td>status_del_sel</td>
<td>R/W 0x3</td>
<td>Control Counter in Delay for Rdy/rdy&lt;0&gt; Handshaking</td>
</tr>
</tbody>
</table>

24.20.2.23 PMIP Test Register (PMIP_TEST)

Table 618: PMIP Test Register (PMIP_TEST)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### 24.20.2.24 Audio PLL Control Register (AUPLL_CTRL0)

Table 619: Audio PLL Control Register (AUPLL_CTRL0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:21</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>20</td>
<td>pu</td>
<td>R/W 0x0</td>
<td>Power-up Signal for the PLL</td>
</tr>
<tr>
<td>19:0</td>
<td>fract</td>
<td>R/W 0xAAAB</td>
<td>Fractional Part of PLL Feedback Divider</td>
</tr>
</tbody>
</table>

### 24.20.2.25 Peripheral Clock Enable Register (PERI_CLK_EN)

Table 620: Peripheral Clock Enable Register (PERI_CLK_EN)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
<td>RSVD 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>Bits</td>
<td>Field</td>
<td>Type/HW Rst</td>
<td>Description</td>
</tr>
<tr>
<td>-------</td>
<td>---------------</td>
<td>-------------</td>
<td>--------------------------------------</td>
</tr>
<tr>
<td>30</td>
<td>usbc_ahb_clk_en</td>
<td>R/W 0x0</td>
<td>AHB USBC Clock Enable</td>
</tr>
<tr>
<td>29:28</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>27</td>
<td>usbc_clk_en</td>
<td>R/W 0x0</td>
<td>USBC Clock Enable</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
<td>RSVD 0x1</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>25:24</td>
<td>Reserved</td>
<td>RSVD 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>23</td>
<td>wdt_clk_en</td>
<td>R/W 0x1</td>
<td>WDT Clock Enable</td>
</tr>
<tr>
<td>22</td>
<td>gpt3_clk_en</td>
<td>R/W 0x1</td>
<td>GPT3 Clock Enable</td>
</tr>
<tr>
<td>21</td>
<td>gpt2_clk_en</td>
<td>R/W 0x1</td>
<td>GPT2 Clock Enable</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
<td>RSVD 0x1</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>19</td>
<td>i2c1_clk_en</td>
<td>R/W 0x1</td>
<td>I2C1 Clock Enable</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17</td>
<td>ssp2_clk_en</td>
<td>R/W 0x1</td>
<td>SSP2 Clock Enable</td>
</tr>
<tr>
<td>16</td>
<td>uart3_clk_en</td>
<td>R/W 0x0</td>
<td>UART3 Clock Enable</td>
</tr>
<tr>
<td>15</td>
<td>uart2_clk_en</td>
<td>R/W 0x0</td>
<td>UART2 Clock Enable</td>
</tr>
<tr>
<td>14:12</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>gpt1_clk_en</td>
<td>R/W 0x1</td>
<td>GPT1 Clock Enable</td>
</tr>
<tr>
<td>10</td>
<td>gpt0_clk_en</td>
<td>R/W 0x1</td>
<td>GPT0 Clock Enable</td>
</tr>
<tr>
<td>9</td>
<td>ssp1_clk_en</td>
<td>R/W 0x1</td>
<td>SSP1 Clock Enable</td>
</tr>
<tr>
<td>8</td>
<td>ssp0_clk_en</td>
<td>R/W 0x1</td>
<td>SSP0 Clock Enable</td>
</tr>
</tbody>
</table>
Table 620: Peripheral Clock Enable Register (PERI_CLK_EN) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>i2c0_clk_en</td>
<td>R/W 0x1</td>
<td>I2C0 Clock Enable</td>
</tr>
<tr>
<td>6</td>
<td>uart1_clk_en</td>
<td>R/W 0x0</td>
<td>UART1 Clock Enable</td>
</tr>
<tr>
<td>5</td>
<td>uart0_clk_en</td>
<td>R/W 0x0</td>
<td>UART0 Clock Enable</td>
</tr>
<tr>
<td>4</td>
<td>gpio_clk_en</td>
<td>R/W 0x1</td>
<td>GPIO Clock Enable</td>
</tr>
<tr>
<td>3:0</td>
<td>Reserved</td>
<td>R/SVD 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
</tbody>
</table>

24.20.2.26 UART Fast Clock Div Register (UART_FAST_CLK_DIV)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UART_FAST_CLK_DIV</td>
<td>0x080</td>
</tr>
</tbody>
</table>

Table 621: UART Fast Clock Div Register (UART_FAST_CLK_DIV)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>Reserved</td>
<td>R/SVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>23:11</td>
<td>nominator</td>
<td>R/W 0x1072</td>
<td>13-Bit Nominator for Fractional Divider</td>
</tr>
<tr>
<td>10:0</td>
<td>denominator</td>
<td>R/W 0x4E3</td>
<td>11-Bit Denominator for Fractional Divider</td>
</tr>
</tbody>
</table>

24.20.2.27 UART Slow Clock Div Register (UART_SLOW_CLK_DIV)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UART_SLOW_CLK_DIV</td>
<td>0x084</td>
</tr>
</tbody>
</table>

Table 622: UART Slow Clock Div Register (UART_SLOW_CLK_DIV)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>Reserved</td>
<td>R/SVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 622: UART Slow Clock Div Register (UART_SLOW_CLK_DIV) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>23:11</td>
<td>nominator</td>
<td>R/W 0x7A1</td>
<td>13-Bit Nominator for Fraction Divider</td>
</tr>
<tr>
<td>10:0</td>
<td>denominator</td>
<td>R/W 0x90</td>
<td>11-Bit Denominator for Fractional Divider</td>
</tr>
</tbody>
</table>

24.20.2.28 UART Clock Select Register (UART_CLK_SEL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UART_CLK_SEL</td>
<td>0x088</td>
</tr>
</tbody>
</table>

Table 623: UART Clock Select Register (UART_CLK_SEL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3</td>
<td>uart3_clk_sel</td>
<td>R/W 0x0</td>
<td>UART3 APB1 UART Clock Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = slow</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = fast</td>
</tr>
<tr>
<td>2</td>
<td>uart2_clk_sel</td>
<td>R/W 0x0</td>
<td>UART2 APB1 UART Clock Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = slow</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = fast</td>
</tr>
<tr>
<td>1</td>
<td>uart1_clk_sel</td>
<td>R/W 0x0</td>
<td>UART1 APB0 UART Clock Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = slow</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = fast</td>
</tr>
<tr>
<td>0</td>
<td>uart0_clk_sel</td>
<td>R/W 0x0</td>
<td>UART0 APB0 UART Clock Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = slow</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = fast</td>
</tr>
</tbody>
</table>

24.20.2.29 MCU CORE Clock Divider Ratio Register (MCU_CORE_CLK_DIV)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCU_CORE_CLK_DIV</td>
<td>0x08C</td>
</tr>
</tbody>
</table>
### Table 624: MCU CORE Clock Divider Ratio Register (MCU_CORE_CLK_DIV)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:6</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5:0</td>
<td>fclk_div</td>
<td>R/W 0x1</td>
<td>FCLK Divisor</td>
</tr>
</tbody>
</table>

### 24.20.2.30 Peripheral0 Clock Divider Ratio Register (PERI0_CLK_DIV)

#### Instance Name Offset

| PERI0_CLK_DIV | 0x090 |

#### Table 625: Peripheral0 Clock Divider Ratio Register (PERI0_CLK_DIV)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>30:16</td>
<td>Reserved</td>
<td>RSVD 0x021</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>14:10</td>
<td>ssp2_clk_div</td>
<td>R/W 0x2</td>
<td>SSP2 APB1 Clock Divisor</td>
</tr>
<tr>
<td>9:5</td>
<td>ssp1_clk_div</td>
<td>R/W 0x2</td>
<td>SSP1 APB0 Clock Divisor</td>
</tr>
<tr>
<td>4:0</td>
<td>ssp0_clk_div</td>
<td>R/W 0x2</td>
<td>SSP0 APB0 Clock Divisor</td>
</tr>
</tbody>
</table>

### 24.20.2.31 Peripheral1 Clock Divider Ratio Register (PERI1_CLK_DIV)

#### Instance Name Offset

| PERI1_CLK_DIV | 0x094 |

#### Table 626: Peripheral1 Clock Divider Ratio Register (PERI1_CLK_DIV)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### Table 626: Peripheral1 Clock Divider Ratio Register (PERI1_CLK_DIV) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6:4</td>
<td>flash_clk_div</td>
<td>R/W 0x1</td>
<td>Flash QSPI Clock Divisor</td>
</tr>
<tr>
<td>3:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

### 24.20.2.32 Peripheral2 Clock Divider Ratio Register (PERI2_CLK_DIV)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PERI2_CLK_DIV</td>
<td>0x098</td>
</tr>
</tbody>
</table>

### Table 627: Peripheral2 Clock Divider Ratio Register (PERI2_CLK_DIV)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:29</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>28</td>
<td>wdt_clk_div_2_2</td>
<td>R/W 0x0</td>
<td>See bit[25:24]</td>
</tr>
<tr>
<td>27:26</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>25:24</td>
<td>wdt_clk_div_1_0</td>
<td>R/W 0x0</td>
<td>WDT Clock Divisor bit[6:4], bit[28], bit[25:24] combine to become a 6-bit WDT clock divisor.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = (divisor = 1)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = (divisor = 2^value)</td>
</tr>
<tr>
<td>23:22</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>21:20</td>
<td>i2c_clk_div</td>
<td>R/W 0x1</td>
<td>i2c Function Clock Divisor, Divisor = i2c_clk_div</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = (divisor = 1)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>others = (divisor = i2c_clk_div[21:20])</td>
</tr>
<tr>
<td>19:15</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>14:12</td>
<td>gpt3_clk_div_5_3</td>
<td>R/W 0x0</td>
<td>See bit[10:8]</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 627: Peripheral2 Clock Divider Ratio Register (PERI2_CLK_DIV) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 10:8   | gpt3_clk_div_2_0         | R/W 0x0      | GPT3 Clock divisor[2:0] bit[14:12], bit[10:8] combine to become a 6-bit GPT3 clock divisor.  
|        |                          |              | 0x0 = (divisor = 1) others = (divisor = gpt3 clock divisor[5:0])            |
| 7      | Reserved                 | RSVĐ         | Reserved. Always write 0. Ignore read value.                                |
| 6:4    | wdt_clk_div_5_3          | R/W 0x0      | See bit[25:24]                                                              |
| 3      | Reserved                 | RSVĐ         | Reserved. Always write 0. Ignore read value.                                |
| 2:0    | gpt_sample_clk_div       | R/W 0x1      | GPT Sample Clock Divisor                                                    |

24.20.2.33 Select Signal for GAU MCLK Register (CAU_CLK_SEL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GAU_CLK_SEL</td>
<td>0x09C</td>
</tr>
</tbody>
</table>

Table 628: Select Signal for GAU MCLK Register (GAU_CLK_SEL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:3</td>
<td>Reserved</td>
<td>RSVĐ</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 2      | gau_sw_gate     | R/W 0x0      | Gate Signal for GAU MCLK  
|         |                  |              | 0x0 = enable  
|         |                  |              | 0x1 = disable                                                            |
| 1:0    | gau_clk_sel     | R/W 0x0      | Select Signal for CAU MCLK  
|         |                  |              | 0x0 = PLL clock  
|         |                  |              | 0x1 = RC32M clock  
|         |                  |              | 0x2 = XTAL 38.4 MHz clock  
|         |                  |              | 0x3 = AUPLL clock                                                        |

24.20.2.34 Low Power Control in PM3/PM4 Mode Register (LOW_PWR_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOW_PWR_CTRL</td>
<td>0x0A0</td>
</tr>
</tbody>
</table>
### Table 629: Low Power Control in PM3/PM4 Mode Register (LOW_PWR_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>rc_osc_sel</td>
<td>R/W 0x0</td>
<td>RC32k and XTAL32k Output Clock Selection</td>
</tr>
<tr>
<td>3</td>
<td>slp_ctrl</td>
<td>R/W 0x0</td>
<td>32k Output Clock Enable Signal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = PU enabled while PD disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = PU disabled while PD enabled</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>1</td>
<td>cache_line_flush</td>
<td>R/W 0x1</td>
<td>Flushes the Cache</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

### 24.20.2.35 I/O Pad Power Configuration Register (IO_PAD_PWR_CFG)

#### Instance Name

<table>
<thead>
<tr>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0A4</td>
</tr>
</tbody>
</table>

#### Table 630: I/O Pad Power Configuration Register (IO_PAD_PWR_CFG)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:20</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>19</td>
<td>gpio_aon_pdb</td>
<td>R/W 0x1</td>
<td>GPIO AON Pad Group</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 = regulator operates in power-down mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 = regulator operates in normal mode</td>
</tr>
<tr>
<td>18</td>
<td>gpio_aon_v18</td>
<td>R/W 0x0</td>
<td>GPIO AON Pad Groups I/O Voltage</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Should be consistent with the actual I/O supply.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>gpio_aon_v18,gpio_aon_v25 = [0, 0] IO 3.3V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>gpio_aon_v18,gpio_aon_v25 = [0, 1] IO 2.5V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>gpio_aon_v18,gpio_aon_v25 = [1, x] IO 1.8V</td>
</tr>
<tr>
<td>17</td>
<td>gpio_aon_v25</td>
<td>RW 0x0</td>
<td>See gpio_aon_v18</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>gpio3_low_vddb</td>
<td>R/W 0x1</td>
<td>GPIO3 Pad Groups Power Configuration</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 = power off</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 = power on</td>
</tr>
</tbody>
</table>
### Table 630: I/O Pad Power Configuration Register (IO_PAD_PWR_CFG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14</td>
<td>gpio2_low_vddb</td>
<td>R/W 0x1</td>
<td>GPIO2 Pad Groups Power Configuration 0 = power off 1 = power on</td>
</tr>
<tr>
<td>13</td>
<td>gpio1_low_vddb</td>
<td>R/W 0x1</td>
<td>GPIO1 Pad Groups Power Configuration 0 = power off 1 = power on</td>
</tr>
<tr>
<td>12</td>
<td>gpio0_low_vddb</td>
<td>R/W 0x1</td>
<td>GPIO0 Pad Groups Power Configuration 0 = power off 1 = power on</td>
</tr>
<tr>
<td>11</td>
<td>gpio3_v18</td>
<td>R/W 0x0</td>
<td>GPIO3 Pad Groups I/O Voltage Should be consistent with real I/O supply.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio3_v18,gpio3_v25] = [0, 0] IO 3.3V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio3_v18,gpio3_v25] = [0, 1] IO 2.5V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio3_v18,gpio3_v25] = [1, x] IO 1.8V</td>
</tr>
<tr>
<td>10</td>
<td>gpio2_v18</td>
<td>R/W 0x0</td>
<td>GPIO2 Pad Groups I/O Voltage Should be consistent with real I/O supply.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio2_v18,gpio2_v25] = [0, 0] IO 3.3V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio2_v18,gpio2_v25] = [0, 1] IO 2.5V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio2_v18,gpio2_v25] = [1, x] IO 1.8V</td>
</tr>
<tr>
<td>9</td>
<td>gpio1_v18</td>
<td>R/W 0x0</td>
<td>GPIO1 Pad Groups I/O Voltage Should be consistent with real I/O supply.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio1_v18,gpio1_v25] = [0, 0] IO 3.3V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio1_v18,gpio1_v25] = [0, 1] IO 2.5V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio1_v18,gpio1_v25] = [1, x] IO 1.8V</td>
</tr>
<tr>
<td>8</td>
<td>gpio0_v18</td>
<td>R/W 0x0</td>
<td>GPIO0 Pad Groups I/O Voltage Should be consistent with real I/O supply.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio0_v18,gpio0_v25] = [0, 0] IO 3.3V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio0_v18,gpio0_v25] = [0, 1] IO 2.5V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[gpio0_v18,gpio0_v25] = [1, x] IO 1.8V</td>
</tr>
<tr>
<td>7</td>
<td>gpio3_v25</td>
<td>R/W 0x0</td>
<td>See gpio3_v18</td>
</tr>
<tr>
<td>6</td>
<td>gpio2_v25</td>
<td>R/W 0x0</td>
<td>See gpio2_v18</td>
</tr>
<tr>
<td>5</td>
<td>gpio1_v25</td>
<td>R/W 0x0</td>
<td>See gpio1_v18</td>
</tr>
<tr>
<td>4</td>
<td>gpio0_v25</td>
<td>R/W 0x0</td>
<td>See gpio0_v18</td>
</tr>
<tr>
<td>3</td>
<td>gpio3_pdb</td>
<td>R/W 0x1</td>
<td>GPIO3 Pad Group 0 = regulator operates in power-down mode 1 = regulator operates in normal mode</td>
</tr>
<tr>
<td>2</td>
<td>gpio2_pdb</td>
<td>R/W 0x1</td>
<td>GPIO2 Pad Group 0 = regulator operates in power-down mode 1 = regulator operates in normal mode</td>
</tr>
</tbody>
</table>
Table 630: I/O Pad Power Configuration Register (IO_PAD_PWR_CFG) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>gpio1_pdb</td>
<td>R/W 0x1</td>
<td>GPIO1 Pad Group</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 = regulator operates in power-down mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 = regulator operates in normal mode</td>
</tr>
<tr>
<td>0</td>
<td>gpio0_pdb</td>
<td>R/W 0x1</td>
<td>GPIO0 Pad Group</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 = regulator operates in power-down mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 = regulator operates in normal mode</td>
</tr>
</tbody>
</table>

24.20.2.36 Extra Interrupt Select Register 0 (EXT_SEL_REG0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>EXT_SEL_REG0</td>
<td>0x0A8</td>
</tr>
</tbody>
</table>

Table 631: Extra Interrupt Select Register 0 (EXT_SEL_REG0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:25</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>24</td>
<td>sel_58</td>
<td>R/W 0x0</td>
<td>Select Signal for Extra Interrupt 58</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = from GPIO_49</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = from GPIO_48</td>
</tr>
<tr>
<td>23</td>
<td>sel_57</td>
<td>R/W 0x0</td>
<td>Select Signal for Extra Interrupt 57</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = from GPIO_47</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = from GPIO_46</td>
</tr>
<tr>
<td>22</td>
<td>sel_56</td>
<td>R/W 0x0</td>
<td>Select Signal for Extra Interrupt 56</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = from GPIO_45</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = from GPIO_44</td>
</tr>
<tr>
<td>21</td>
<td>sel_55</td>
<td>R/W 0x0</td>
<td>Select Signal for Extra Interrupt 55</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = from GPIO_43</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = from GPIO_42</td>
</tr>
<tr>
<td>20</td>
<td>sel_54</td>
<td>R/W 0x0</td>
<td>Select Signal for Extra Interrupt 54</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = from GPIO_41</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = from GPIO_40</td>
</tr>
<tr>
<td>19</td>
<td>sel_53</td>
<td>R/W 0x0</td>
<td>Select Signal for Extra Interrupt 53</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = from GPIO_39</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = from GPIO_38</td>
</tr>
<tr>
<td>18</td>
<td>sel_52</td>
<td>R/W 0x0</td>
<td>Select Signal for Extra Interrupt 52</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = from GPIO_37</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = from GPIO_36</td>
</tr>
</tbody>
</table>
### Table 631: Extra Interrupt Select Register 0 (EXT_SEL_REG0) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 17   | sel_51 | R/W 0x0 | Select Signal for Extra Interrupt 51  
|      |        |              | 0x0 = from GPIO_35  
|      |        |              | 0x1 = from GPIO_34 |
| 16   | sel_50 | R/W 0x0 | Select Signal for Extra Interrupt 50  
|      |        |              | 0x0 = from GPIO_33  
|      |        |              | 0x1 = from GPIO_32 |
| 15   | sel_49 | R/W 0x0 | Select Signal for Extra Interrupt 49  
|      |        |              | 0x0 = from GPIO_31  
|      |        |              | 0x1 = from GPIO_30 |
| 14   | sel_48 | R/W 0x0 | Select Signal for Extra Interrupt 48  
|      |        |              | 0x0 = from GPIO_29  
|      |        |              | 0x1 = from GPIO_28 |
| 13   | sel_47 | R/W 0x0 | Select Signal for Extra Interrupt 47  
|      |        |              | 0x0 = from GPIO_27  
|      |        |              | 0x1 = from GPIO_26 |
| 12   | sel_46 | R/W 0x0 | Select Signal for Extra Interrupt 46  
|      |        |              | 0x0 = from GPIO_25  
|      |        |              | 0x1 = from GPIO_24 |
| 11   | sel_45 | R/W 0x0 | Select Signal for Extra Interrupt 45  
|      |        |              | 0x0 = from GPIO_23  
|      |        |              | 0x1 = from GPIO_22 |
| 10   | sel_44 | R/W 0x0 | Select Signal for Extra Interrupt 44  
|      |        |              | 0x0 = from GPIO_21  
|      |        |              | 0x1 = from GPIO_20 |
| 9    | sel_43 | R/W 0x0 | Select Signal for Extra Interrupt 43  
|      |        |              | 0x0 = from GPIO_19  
|      |        |              | 0x1 = from GPIO_18 |
| 8    | sel_42 | R/W 0x0 | Select Signal for Extra Interrupt 42  
|      |        |              | 0x0 = from GPIO_17  
|      |        |              | 0x1 = from GPIO_16 |
| 7    | sel_41 | R/W 0x0 | Select Signal for Extra Interrupt 41  
|      |        |              | 0x0 = from GPIO_15  
|      |        |              | 0x1 = from GPIO_14 |
| 6    | sel_40 | R/W 0x0 | Select Signal for Extra Interrupt 40  
|      |        |              | 0x0 = from GPIO_13  
|      |        |              | 0x1 = from GPIO_12 |
### Table 631: Extra Interrupt Select Register 0 (EXT_SEL_REG0) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
</table>
| 5    | sel_39 | R/W, 0x0    | Select Signal for Extra Interrupt 39  
0x0 = from GPIO_11  
0x1 = from GPIO_10 |
| 4    | sel_38 | R/W, 0x0    | Select Signal for Extra Interrupt 38  
0x0 = from GPIO_9  
0x1 = from GPIO_8 |
| 3    | sel_37 | R/W, 0x0    | Select Signal for Extra Interrupt 37  
0x0 = from GPIO_7  
0x1 = from GPIO_6 |
| 2    | sel_36 | R/W, 0x0    | Select Signal for Extra Interrupt 36  
0x0 = from GPIO_5  
0x1 = from GPIO_4 |
| 1    | sel_35 | R/W, 0x0    | Select Signal for Extra Interrupt 35  
0x0 = from GPIO_3  
0x1 = from GPIO_2 |
| 0    | sel_34 | R/W, 0x0    | Select Signal for Extra Interrupt 34  
0x0 = from GPIO_1  
0x1 = from GPIO_0 |

#### 24.20.2.37 USB and Audio PLL Control Register (AUPLL_CTRL1)

**Instance Name**  
AUPLL_CTRL1  
**Offset**  
0x0B0

### Table 632: USB and Audio PLL Control Register (AUPLL_CTRL1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>29</td>
<td>en_vcox2</td>
<td>R/W, 0x1</td>
<td>Enable or Disable VCOCLOCK_X2</td>
</tr>
<tr>
<td>28:24</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>23:22</td>
<td>dig_tstptnt</td>
<td>R/W, 0x0</td>
<td>Digital Test Select</td>
</tr>
</tbody>
</table>
### 24.20.2.38 GAU Control Register (GAU_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GAU_CTRL</td>
<td>0x0B4</td>
</tr>
</tbody>
</table>

#### Table 633: GAU Control Register (GAU_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4</td>
<td>gau_bg_mclk_en</td>
<td>R/W 0x1</td>
<td>gau_bg Module Main Clock Enable Signal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
<tr>
<td>3</td>
<td>gau_gpadc0_mclk_en</td>
<td>R/W 0x1</td>
<td>gau_gpadc0 Module Main Clock Enable Signal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### Table 633: GAU Control Register (GAU_CTRL) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>gau_gpdac_mclk_en</td>
<td>R/W 0x1</td>
<td>gau_gpdac Module Main Clock Enable Signal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
<tr>
<td>0</td>
<td>gau_acomp_mclk_en</td>
<td>R/W 0x1</td>
<td>gau_acomp Module Main Clock Enable Signal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x0 = disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0x1 = enable</td>
</tr>
</tbody>
</table>

#### 24.20.2.39 RC32k Control 0 Register (RC32K_CTRL0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RC32K_CTRL0</td>
<td>0xB8</td>
</tr>
</tbody>
</table>

**Table 634: RC32k Control 0 Register (RC32K_CTRL0)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVRD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15</td>
<td>rc32k_pd</td>
<td>R/W 0x0</td>
<td>Power down 32k Oscillator</td>
</tr>
<tr>
<td>14</td>
<td>rc32k_cal_en</td>
<td>R/W 0x0</td>
<td>Enable Calibration of 32k Oscillator</td>
</tr>
<tr>
<td>13:0</td>
<td>rc32k_code_fr_ext</td>
<td>R/W 0x0</td>
<td>External Code In for Frequency Setting</td>
</tr>
</tbody>
</table>

#### 24.20.2.40 RC32k Control 1 Register (RC32K_CTRL1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RC32K_CTRL1</td>
<td>0xBC</td>
</tr>
</tbody>
</table>

**Table 635: RC32k Control 1 Register (RC32K_CTRL1)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:24</td>
<td>Reserved</td>
<td>RSVRD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>23</td>
<td>rc32k_ext_code_en</td>
<td>R/W 0x0</td>
<td>Allow External Code in to Go into the Ckt</td>
</tr>
</tbody>
</table>
24.20.2.41 XTAL32k Control Register (XTAL32K_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>XTAL32K_CTRL</td>
<td>0x0C0</td>
</tr>
</tbody>
</table>

Table 636: XTAL32k Control Register (XTAL32K_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:15</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>14:13</td>
<td>x32k_dly_sel</td>
<td>R/W 0x0</td>
<td>32k Delay Select</td>
</tr>
<tr>
<td>12</td>
<td>x32k_en</td>
<td>R/W 0x0</td>
<td>Enable 32k Oscillator</td>
</tr>
<tr>
<td>11</td>
<td>x32k_ext_osc_en</td>
<td>R/W 0x0</td>
<td>Enable External Oscillator Mode for Outside Clock</td>
</tr>
<tr>
<td>10:9</td>
<td>x32k_vddxo_cntl</td>
<td>R/W 0x1</td>
<td>Control VDDXO Level</td>
</tr>
<tr>
<td>8:7</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
Table 636: XTAL32k Control Register (XTAL32K_CTRL) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6:5</td>
<td>x32k_tmode</td>
<td>R/W 0x0</td>
<td>Test Mode Enabling for 32k Xtal Ckt</td>
</tr>
<tr>
<td>4</td>
<td>x32k_test_en</td>
<td>R/W 0x0</td>
<td>Test Enabling for 32k Xtal Ckt</td>
</tr>
<tr>
<td>3:2</td>
<td>x32k_stup_assist</td>
<td>R/W 0x1</td>
<td>Use Startup Assist Ckt for 32 kHz Xosc</td>
</tr>
<tr>
<td>1</td>
<td>xclk32k</td>
<td>R 0x0</td>
<td>xclk32k</td>
</tr>
<tr>
<td>0</td>
<td>x32k_rdy</td>
<td>R 0x0</td>
<td>Assert High When Ready</td>
</tr>
</tbody>
</table>

24.20.2.42 PMIP Comparator Control Register (PMIP_CMP_CTRL)

Table 637: PMIP Comparator Control Register (PMIP_CMP_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:10</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>9</td>
<td>gau_ref_en</td>
<td>R/W 0x0</td>
<td>GAU Reference Enable</td>
</tr>
<tr>
<td>8:7</td>
<td>comp_hyst</td>
<td>R/W 0x2</td>
<td>Control of Comparator Hysteresis</td>
</tr>
<tr>
<td>6</td>
<td>comp_en</td>
<td>R/W 0x0</td>
<td>Enable AON Domain Comparator</td>
</tr>
<tr>
<td>5</td>
<td>comp_diff_en</td>
<td>R/W 0x0</td>
<td>Enable Differential Mode for AON Comparator</td>
</tr>
</tbody>
</table>
| 4:2   | comp_ref_sel| R/W 0x0      | Select Comparator Reference for Single-Ended Mode
|       |             |              | 0x0 = 0.2V
|       |             |              | 0x1 = 0.4V
|       |             |              | 0x2 = 0.6V
|       |             |              | 0x3 = 0.8V
|       |             |              | 0x4 = 1.0V
|       |             |              | 0x5 = 1.2V
|       |             |              | 0x6 = 1.4V
|       |             |              | 0x7 = 1.6V

Table 637: PMIP Comparator Control Register (PMIP_CMP_CTRL) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>comp_rdy</td>
<td>R 0x0</td>
<td>Ready to Use AON Domain Comparator</td>
</tr>
<tr>
<td>0</td>
<td>comp_out</td>
<td>R 0x0</td>
<td>Output of AON Domain Comparator</td>
</tr>
</tbody>
</table>

24.20.2.43  PMIP Brown-out AV18 Register (PMIP_BRNDET_AV18)

Table 638: PMIP Brown-out AV18 Register (PMIP_BRNDET_AV18)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:20</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>19:18</td>
<td>del_av18_hyst</td>
<td>R/W 0x0</td>
<td>Del av18 Hysteresis</td>
</tr>
<tr>
<td>17</td>
<td>brndet_av18_en</td>
<td>R/W 0x0</td>
<td>Enable av18 Brown-out Detector</td>
</tr>
<tr>
<td>16:14</td>
<td>brntrig_av18_cntl</td>
<td>R/W 0x4</td>
<td>Control Trigger Voltage of av18 Brndet</td>
</tr>
<tr>
<td>13:12</td>
<td>brnhyst_av18_cntl</td>
<td>R/W 0x2</td>
<td>Control of av18 Brown-out Detector Hysteresis</td>
</tr>
<tr>
<td>11:10</td>
<td>brndet_av18_filt</td>
<td>R/W 0x2</td>
<td>Select Filtering Level for av18 Pulse to av18 Brndet</td>
</tr>
<tr>
<td>9</td>
<td>brndet_av18_rdy</td>
<td>R 0x0</td>
<td>Assert High If av18 Brown-out Is Rdy --&gt; out Can Be Taken</td>
</tr>
<tr>
<td>8</td>
<td>brndet_av18_out</td>
<td>R 0x0</td>
<td>Assert High If av18 Brown-out Happened</td>
</tr>
<tr>
<td>7:0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

24.20.2.44  PMIP Brown-out VBAT Register (PMIP_BRNDET_VBAT)

Table 639: PMIP Brown-out VBAT Register (PMIP_BRNDET_VBAT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PMIP_BRNDET_VBAT</td>
<td>0x0D0</td>
</tr>
</tbody>
</table>
### Table 639: PMIP Brown-out VBAT Register (PMIP_BRNDET_VBAT)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:20</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>19</td>
<td>brndet_vbat_en</td>
<td>R/W 0x0</td>
<td>Enable Vbat Brown-out Detector</td>
</tr>
<tr>
<td>18:16</td>
<td>brntrig_vbat_cntl</td>
<td>R/W 0x4</td>
<td>Control Trigger Voltage of Vbat Brndet</td>
</tr>
<tr>
<td>15:14</td>
<td>brnhyst_vbat_cntl</td>
<td>R/W 0x2</td>
<td>Control of Vbat Brown-out Detector Hysteresis</td>
</tr>
<tr>
<td>13:12</td>
<td>brndet_vbat_filt</td>
<td>R/W 0x2</td>
<td>Select Filtering Level for Vbat Pulse to Vbat Brndet</td>
</tr>
<tr>
<td>11</td>
<td>brndet_vbat_rdy</td>
<td>R 0x0</td>
<td>Assert High If Vbat Brown-out Is rdy--&gt; out Can Be Taken</td>
</tr>
<tr>
<td>10</td>
<td>brndet_vbat_out</td>
<td>R 0x0</td>
<td>Assert High If Vbat Brown-out Happened</td>
</tr>
<tr>
<td>31:0</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

### 24.20.2.45 PMIP Brown-out V12 Register (PMIP_BRNDET_V12)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PMIP_BRNDET_V12</td>
<td>0x0D4</td>
</tr>
</tbody>
</table>

### Table 640: PMIP Brown-out V12 Register (PMIP_BRNDET_V12)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:15</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>14</td>
<td>brndet_v12_en</td>
<td>R/W 0x0</td>
<td>Enable v12 Brown-out Detector</td>
</tr>
<tr>
<td>13:11</td>
<td>brntrig_v12_cntl</td>
<td>R/W 0x4</td>
<td>Control Trigger Voltage of v12 Brndet</td>
</tr>
<tr>
<td>10:9</td>
<td>brnhyst_v12_cntl</td>
<td>R/W 0x2</td>
<td>Control of v12 Brown-out Detector Hysteresi</td>
</tr>
<tr>
<td>8:7</td>
<td>brndet_v12_filt</td>
<td>R/W 0x2</td>
<td>Select Filtering Level for v12 Pulse to v12 Brndet</td>
</tr>
<tr>
<td>6</td>
<td>brndet_v12_rdy</td>
<td>R 0x0</td>
<td>Assert High If v12 Brown-out Is rdy--&gt; out Can Be Taken</td>
</tr>
</tbody>
</table>
Table 640: PMIP Brown-out V12 Register (PMIP_BRNDET_V12) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>brndet_v12_out</td>
<td>R 0x0</td>
<td>Assert High if v12 Brown-out Happened</td>
</tr>
<tr>
<td>4:2</td>
<td>ldo_aon_v12_sel</td>
<td>R/W 0x4</td>
<td>Select Output Voltage of ldo_aon_v12</td>
</tr>
<tr>
<td>1:0</td>
<td>ldo_aon_v12_hyst</td>
<td>R/W 0x0</td>
<td>Control of ldo_aon_v12 Hysteresis</td>
</tr>
</tbody>
</table>

24.20.2.46 PMIP LDO Control Register (PMIP_LDO_CTRL)

Instance Name Offset
PMIP_LDO_CTRL 0x0D8

Table 641: PMIP LDO Control Register (PMIP_LDO_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>ldo_av18_en</td>
<td>R/W 0x1</td>
<td>Enable ldo_av18</td>
</tr>
<tr>
<td>10:6</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>5</td>
<td>ldo_v12_en</td>
<td>R/W 0x1</td>
<td>Enable ldo_v12</td>
</tr>
<tr>
<td>4:2</td>
<td>ldo_v12_vout_sel</td>
<td>R/W 0x4</td>
<td>Select Output Voltage for v12</td>
</tr>
<tr>
<td>1:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

24.20.2.47 PERI Clock Source Register (PERI_CLK_SRC)

Instance Name Offset
PERI_CLK_SRC 0x0DC
### Table 642: PERI Clock Source Register (PERI_CLK_SRC)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:14</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>13:3</td>
<td>Reserved</td>
<td>RSVD 0x0</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>2</td>
<td>ssp2_audio_sel</td>
<td>R/W 0x0</td>
<td>SSP2 Audio Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 = divided by system clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 = audio PLL clock</td>
</tr>
<tr>
<td>1</td>
<td>ssp1_audio_sel</td>
<td>R/W 0x0</td>
<td>SSP1 Audio Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 = divided by system clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 = audio PLL clock</td>
</tr>
<tr>
<td>0</td>
<td>ssp0_audio_sel</td>
<td>R/W 0x0</td>
<td>SSP0 Audio Select</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 = divided by system clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 = audio PLL clock</td>
</tr>
</tbody>
</table>

### 24.20.2.48 Unused Register (PMIP_RSVD)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PMIP_RSVD</td>
<td>0x0E0</td>
</tr>
</tbody>
</table>

### Table 643: Unused Register (PMIP_RSVD)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:16</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>15:10</td>
<td>reserve_out</td>
<td>R 0x0</td>
<td>Unused. Do Not Change the Reset Value.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This field exists, but is not connected to logic.</td>
</tr>
<tr>
<td>9:0</td>
<td>reserve_in</td>
<td>R/W 0x0</td>
<td>Unused. Do Not Change the Reset Value.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This field exists, but is not connected to logic.</td>
</tr>
</tbody>
</table>

### 24.20.2.49 GPT0 Control Register (GPT0_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPT0_CTRL</td>
<td>0x0E4</td>
</tr>
</tbody>
</table>
### 24.20.2.50 GPT1 Control Register (GPT1_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>10:9</td>
<td>gpt1_clk_sel0</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux Before Frequency Divisor</td>
</tr>
<tr>
<td>8:7</td>
<td>gpt1_clk_sel1</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux After Frequency Divisor</td>
</tr>
<tr>
<td>6</td>
<td>gpt1_freq_change</td>
<td>R/W 0x0</td>
<td>Frequency Change Enable</td>
</tr>
<tr>
<td>5:0</td>
<td>gpt1_clk_div</td>
<td>R/W 0x1</td>
<td>Clock Divisor</td>
</tr>
</tbody>
</table>

### 24.20.2.51 GPT2 Control Register (GPT2_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPT2_CTRL</td>
<td>0x0EC</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>10:9</td>
<td>gpt2_clk_sel0</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux Before Frequency Divisor</td>
</tr>
<tr>
<td>8:7</td>
<td>gpt2_clk_sel1</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux After Frequency Divisor</td>
</tr>
<tr>
<td>6</td>
<td>gpt2_freq_change</td>
<td>R/W 0x0</td>
<td>Frequency Change Enable</td>
</tr>
<tr>
<td>5:0</td>
<td>gpt2_clk_div</td>
<td>R/W 0x1</td>
<td>Clock Divisor</td>
</tr>
</tbody>
</table>
### 24.20.2.52 GPT3 Control Register (GPT3_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>10:9</td>
<td>gpt3_clk_sel0</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux Before Frequency Divisor</td>
</tr>
<tr>
<td>8:7</td>
<td>gpt3_clk_sel1</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux After Frequency Divisor</td>
</tr>
<tr>
<td>6</td>
<td>gpt3_freq_change</td>
<td>R/W 0x0</td>
<td>Frequency Change Enable</td>
</tr>
<tr>
<td>5:0</td>
<td>gpt3_clk_div</td>
<td>R/W 0x1</td>
<td>Clock Divisor</td>
</tr>
</tbody>
</table>

### 24.20.2.53 Wakeup Edge Detect Register (WAKEUP_EDGE_DETECT)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WAKEUP_EDGE_DETECT</td>
<td>0x0F4</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>10:9</td>
<td>gpt3_clk_sel0</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux Before Frequency Divisor</td>
</tr>
<tr>
<td>8:7</td>
<td>gpt3_clk_sel1</td>
<td>R/W 0x0</td>
<td>Select Signal for Mux After Frequency Divisor</td>
</tr>
<tr>
<td>6</td>
<td>gpt3_freq_change</td>
<td>R/W 0x0</td>
<td>Frequency Change Enable</td>
</tr>
<tr>
<td>5:0</td>
<td>gpt3_clk_div</td>
<td>R/W 0x1</td>
<td>Clock Divisor</td>
</tr>
</tbody>
</table>
### 24.20.2.54 AON Clock Control Register (AON_CLK_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AON_CLK_CTRL</td>
<td>0xF8</td>
</tr>
</tbody>
</table>

#### Table 649: AON Clock Control Register (AON_CLK_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:11</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>10:9</td>
<td>apb1_clk_div</td>
<td>R/W 0x0</td>
<td>APB1 Clock Divisor</td>
</tr>
<tr>
<td>8:7</td>
<td>apb0_clk_div</td>
<td>R/W 0x0</td>
<td>APB0 Clock Divisor</td>
</tr>
<tr>
<td>6</td>
<td>dma_clk_gate_en</td>
<td>R/W 0x0</td>
<td>DMA Clock Gate Enable</td>
</tr>
<tr>
<td>5</td>
<td>rtc_int_sel</td>
<td>R/W 0x0</td>
<td>RTC Interrupt Select</td>
</tr>
<tr>
<td>4</td>
<td>rtc_clk_en</td>
<td>R/W 0x1</td>
<td>RTC Clock Enable</td>
</tr>
<tr>
<td>3:0</td>
<td>pmu_clk_div</td>
<td>R/W 0x2</td>
<td>PMU Clock Divisor</td>
</tr>
</tbody>
</table>

### 24.20.2.55 PERI3 Control Register (PERI3_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PERI3_CTRL</td>
<td>0xFC</td>
</tr>
</tbody>
</table>
Table 650: PERI3 Control Register (PERI3_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:19</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>18</td>
<td>rc32m_gate</td>
<td>R/W 0x1</td>
<td>RC32M Reference Clock Gate</td>
</tr>
<tr>
<td>17:13</td>
<td>rc32m_div</td>
<td>R/W 0x6</td>
<td>RC32M Clock Div Ratio</td>
</tr>
<tr>
<td>12:8</td>
<td>gau_div</td>
<td>R/W 0x3</td>
<td>GAU Clock Div Ratio</td>
</tr>
<tr>
<td>7:0</td>
<td>Reserved</td>
<td>R/W 0x04</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
</tbody>
</table>

24.20.2.56  Wakeup Mask Interrupt Register (wakeup_mask)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>wakeup_mask</td>
<td>0x114</td>
</tr>
</tbody>
</table>

Table 651: Wakeup Mask Interrupt Register (wakeup_mask)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:8</td>
<td>Reserved</td>
<td>RSVD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
| 7     | wl_wakeup_mask      | R/W 0x0     | WLAN Wakeup Mask
0x0 = mask WLAN wakeup interrupt
0x1 = unmask WLAN wakeup interrupt |
| 6     | pmip_comp_wakeup_mask | R/W 0x0   | PMIP Comparator Wakeup Mask
0x0 = mask PMIP comparator wakeup interrupt
0x1 = unmask PMIP comparator wakeup interrupt |
| 5     | rtc_wakeup_mask     | R/W 0x0     | RTC Wakeup Mask
0x0 = mask RTC wakeup interrupt
0x1 = unmask RTC wakeup interrupt |
| 4     | pin1_wakeup_mask    | R/W 0x0     | Pin1 Wakeup Mask
0x0 = mask pin1 wakeup interrupt
0x1 = unmask pin1 wakeup interrupt |
| 3     | pin0_wakeup_mask    | R/W 0x0     | Pin0 Wakeup Mask
0x0 = mask pin0 wakeup interrupt
0x1 = unmask pin0 wakeup interrupt |
## Table 651: Wakeup Mask Interrupt Register (wakeup_mask) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>

## 24.20.2.57 WLAN Control Register (wlan_ctrl)

**Table 652: WLAN Control Register (wlan_ctrl)**

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>wlan_ctrl</td>
<td>0x118</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:18</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>17:7</td>
<td>wl_pd_del_cfg</td>
<td>R/W</td>
<td>Count for 30 ms</td>
</tr>
<tr>
<td>6</td>
<td>refclk_usb_rdy</td>
<td>R</td>
<td>WLAN Reference Clock Ready</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x3C0</td>
<td>0x0 = not ready 0x1 = ready</td>
</tr>
<tr>
<td>5</td>
<td>refclk_aud_rdy</td>
<td>R</td>
<td>WLAN Reference Clock Ready</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = not ready 0x1 = ready</td>
</tr>
<tr>
<td>4</td>
<td>refclk_sys_rdy</td>
<td>R</td>
<td>WLAN Reference Clock Ready</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = not ready 0x1 = ready</td>
</tr>
<tr>
<td>3</td>
<td>refclk_usb_req</td>
<td>R/W</td>
<td>WLAN USB Reference Clock Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = not request 0x1 = request</td>
</tr>
<tr>
<td>2</td>
<td>refclk_aud_req</td>
<td>R/W</td>
<td>WLAN AUD Reference Clock Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = not request 0x1 = request</td>
</tr>
<tr>
<td>1</td>
<td>refclk_sys_req</td>
<td>R/W</td>
<td>WLAN SYS Reference Clock Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = not request 0x1 = request</td>
</tr>
<tr>
<td>0</td>
<td>pd</td>
<td>R/W</td>
<td>WLAN Power down Function</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0x0</td>
<td>0x0 = power down 0x1 = power on</td>
</tr>
</tbody>
</table>
24.20.2.58 WLAN Control 1 Register (wlan_ctrl1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>wlan_ctrl1</td>
<td>0x11C</td>
</tr>
</tbody>
</table>

Table 653: WLAN Control 1 Register (wlan_ctrl1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:12</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>11</td>
<td>mci_wl_wakeup</td>
<td>R/W 0x0</td>
<td>MCI_WL_WAKEUP</td>
</tr>
<tr>
<td>10:0</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
24.21   System Control Address Block

24.21.1   System Control Register Map

Table 654: System Control Register Map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Name</th>
<th>HW Rst</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>REV_ID</td>
<td>0x8813_0A40</td>
<td>Chip Revision Register</td>
<td>Page: 662</td>
</tr>
<tr>
<td>0x04</td>
<td>Reserved</td>
<td>0x0000_0000</td>
<td>Reserved</td>
<td>--</td>
</tr>
<tr>
<td>0x08</td>
<td>RAM0</td>
<td>0x0000_0006</td>
<td>RAM0 Control Register</td>
<td>Page: 663</td>
</tr>
<tr>
<td>0x0C</td>
<td>RAM1</td>
<td>0x0000_0006</td>
<td>RAM1 Control Register</td>
<td>Page: 663</td>
</tr>
<tr>
<td>0x10</td>
<td>RAM2</td>
<td>0x0000_0006</td>
<td>RAM2 Control Register</td>
<td>Page: 664</td>
</tr>
<tr>
<td>0x14</td>
<td>RAM3</td>
<td>0x0000_0006</td>
<td>RAM3 Control Register</td>
<td>Page: 664</td>
</tr>
<tr>
<td>0x28</td>
<td>ROM</td>
<td>0x0000_0016</td>
<td>ROM Control Register</td>
<td>Page: 664</td>
</tr>
<tr>
<td>0x2C</td>
<td>AON_MEM</td>
<td>0x0000_0006</td>
<td>AON_MEM Control Register</td>
<td>Page: 665</td>
</tr>
<tr>
<td>0x34</td>
<td>GPT_in</td>
<td>0x0000_0000</td>
<td>GPT Pin-in Selection Register</td>
<td>Page: 665</td>
</tr>
<tr>
<td>0x38</td>
<td>CAL</td>
<td>0x0000_0001</td>
<td>Calibration Channel Selection Register</td>
<td>Page: 665</td>
</tr>
<tr>
<td>0x3C</td>
<td>PERI_SW_RST</td>
<td>0x05FF_FFFF</td>
<td>Peripheral Software Reset Register</td>
<td>Page: 666</td>
</tr>
<tr>
<td>0x40</td>
<td>USB_CTRL</td>
<td>0x0002_B300</td>
<td>USB Control Register</td>
<td>Page: 667</td>
</tr>
<tr>
<td>0x4C</td>
<td>Reserved</td>
<td>0x0000_0006</td>
<td>Reserved</td>
<td>--</td>
</tr>
</tbody>
</table>

24.21.2   System Control Registers

24.21.2.1   Chip Revision Register (REV_ID)

Table 655: Chip Revision Register (REV_ID)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:0</td>
<td>rev_id</td>
<td>R 0x8813_0A41</td>
<td>Chip Revision ID</td>
</tr>
</tbody>
</table>
24.21.2.2 RAM0 Control Register (RAM0)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAM0</td>
<td>0x08</td>
</tr>
</tbody>
</table>

Table 656: RAM0 Control Register (RAM0)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD</td>
<td>--</td>
</tr>
<tr>
<td>3:2</td>
<td>wtc</td>
<td>R/W</td>
<td>0x1</td>
</tr>
<tr>
<td>1:0</td>
<td>rtc</td>
<td>R/W</td>
<td>0x2</td>
</tr>
</tbody>
</table>

24.21.2.3 RAM1 Control Register (RAM1)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAM1</td>
<td>0x0C</td>
</tr>
</tbody>
</table>

Table 657: RAM1 Control Register (RAM1)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD</td>
<td>--</td>
</tr>
<tr>
<td>3:2</td>
<td>wtc</td>
<td>R/W</td>
<td>0x1</td>
</tr>
<tr>
<td>1:0</td>
<td>rtc</td>
<td>R/W</td>
<td>0x2</td>
</tr>
</tbody>
</table>

24.21.2.4 RAM2 Control Register (RAM2)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAM2</td>
<td>0x10</td>
</tr>
</tbody>
</table>
### Table 658: RAM2 Control Register (RAM2)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:2</td>
<td>wtc</td>
<td>R/W 0x1</td>
<td>WTC</td>
</tr>
<tr>
<td>1:0</td>
<td>rtc</td>
<td>R/W 0x2</td>
<td>RTC</td>
</tr>
</tbody>
</table>

### 24.21.2.5 RAM3 Control Register (RAM3)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAM3</td>
<td>0x14</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Table 659: RAM3 Control Register (RAM3)</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:2</td>
<td>wtc</td>
<td>R/W 0x1</td>
<td>WTC</td>
</tr>
<tr>
<td>1:0</td>
<td>rtc</td>
<td>R/W 0x2</td>
<td>RTC</td>
</tr>
</tbody>
</table>

### 24.21.2.6 ROM Control Register (ROM)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ROM</td>
<td>0x28</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Table 660: ROM Control Register (ROM)</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:5</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>4:3</td>
<td>rtc_ref</td>
<td>R/W 0x2</td>
<td>RTC Reference</td>
</tr>
<tr>
<td>2:0</td>
<td>rtc</td>
<td>R/W 0x6</td>
<td>RTC Reference</td>
</tr>
</tbody>
</table>
### 24.21.2.7 AON_MEM Control Register (AON_MEM)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AON_MEM</td>
<td>0x2C</td>
</tr>
</tbody>
</table>

#### Table 661: AON_MEM Control Register (AON_MEM)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:4</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>3:2</td>
<td>wtc</td>
<td>R/W 0x1</td>
<td>WTC</td>
</tr>
<tr>
<td>1:0</td>
<td>rtc</td>
<td>R/W 0x2</td>
<td>RTC</td>
</tr>
</tbody>
</table>

### 24.21.2.8 GPT Pin-in Selection Register (GPT_in)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPT_in</td>
<td>0x34</td>
</tr>
</tbody>
</table>

#### Table 662: GPT Pin-in Selection Register (GPT_in)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:1</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>0</td>
<td>sel</td>
<td>R/W 0x0</td>
<td>Select GPT Pin</td>
</tr>
</tbody>
</table>

### 24.21.2.9 Calibration Channel Selection Register (CAL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CAL</td>
<td>0x38</td>
</tr>
</tbody>
</table>

#### Table 663: Calibration Channel Selection Register (CAL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/ HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:2</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
</tbody>
</table>
### Peripheral Software Reset Register (PERI_SW_RST)

**Instance Name**

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PERI_SW_RST</td>
<td>0x3C</td>
</tr>
</tbody>
</table>

**Table 664: Peripheral Software Reset Register (PERI_SW_RST)**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:27</td>
<td>Reserved</td>
<td>RSVDD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>26</td>
<td>gau_rstn_en</td>
<td>R/W 0x1</td>
<td>GAU Reset_n Enable</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
<td>RSVDD</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>24:19</td>
<td>Reserved</td>
<td>RSVDD 0x7</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>18</td>
<td>flash_qspi_rstn_en</td>
<td>R/W 0x1</td>
<td>Flash QSPI Reset_n Enable</td>
</tr>
<tr>
<td>17</td>
<td>uart0_rstn_en</td>
<td>R/W 0x1</td>
<td>UART0 Reset_n Enable</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
<td>RSVDD 0x1</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>15</td>
<td>uart2_rstn_en</td>
<td>R/W 0x1</td>
<td>UART2 Reset_n Enable</td>
</tr>
<tr>
<td>14</td>
<td>uart3_rstn_en</td>
<td>R/W 0x1</td>
<td>UART3 Reset_n Enable</td>
</tr>
<tr>
<td>13</td>
<td>i2c0_rstn_en</td>
<td>R/W 0x1</td>
<td>I2C0 Reset_n Enable</td>
</tr>
<tr>
<td>12</td>
<td>i2c1_rstn_en</td>
<td>R/W 0x1</td>
<td>I2C1 Reset_n Enable</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
<td>RSVDD 0x1</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
</tbody>
</table>
### Table 664: Peripheral Software Reset Register (PERI_SW_RST) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>ssp0_rstn_en</td>
<td>R/W 0x1</td>
<td>SSP0 Reset_n Enable</td>
</tr>
<tr>
<td>9</td>
<td>ssp1_rstn_en</td>
<td>R/W 0x1</td>
<td>SSP01 Reset_n Enable</td>
</tr>
<tr>
<td>8</td>
<td>ssp2_rstn_en</td>
<td>R/W 0x1</td>
<td>SSP2 Reset_n Enable</td>
</tr>
<tr>
<td>7</td>
<td>gpt0_rstn_en</td>
<td>R/W 0x1</td>
<td>GPT0 Reset_n Enable</td>
</tr>
<tr>
<td>6</td>
<td>gpt1_rstn_en</td>
<td>R/W 0x1</td>
<td>GPT1 Reset_n Enable</td>
</tr>
<tr>
<td>5</td>
<td>gpt2_rstn_en</td>
<td>R/W 0x1</td>
<td>GPT2 Reset_n Enable</td>
</tr>
<tr>
<td>4</td>
<td>gpt3_rstn_en</td>
<td>R/W 0x1</td>
<td>GPT3 Reset_n Enable</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>RSVD 0x1</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td>RSVD 0x1</td>
<td>Reserved. Do not change the reset value.</td>
</tr>
<tr>
<td>1</td>
<td>usb_rstn_en</td>
<td>R/W 0x1</td>
<td>USB Reset_n Enable</td>
</tr>
<tr>
<td>0</td>
<td>wdt_rstn_en</td>
<td>R/W 0x1</td>
<td>WDT Reset_n Enable</td>
</tr>
</tbody>
</table>

### 24.21.2.11 USB Control Register (USB_CTRL)

<table>
<thead>
<tr>
<th>Instance Name</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB_CTRL</td>
<td>0x40</td>
</tr>
</tbody>
</table>

### Table 665: USB Control Register (USB_CTRL)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:23</td>
<td>Reserved</td>
<td>RSVD --</td>
<td>Reserved. Always write 0. Ignore read value.</td>
</tr>
<tr>
<td>22</td>
<td>mac_ctrl_sel</td>
<td>R/W 0x0</td>
<td>MAC Control Select</td>
</tr>
<tr>
<td>21</td>
<td>soft_utmi_iddig</td>
<td>R/W 0x0</td>
<td>Soft UTMI Iddig</td>
</tr>
</tbody>
</table>
## Table 665: USB Control Register (USB_CTRL) (Continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Field</th>
<th>Type/HW Rst</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>soft_utmi_xvalid</td>
<td>R/W 0x0</td>
<td>Soft UTMI Xvalid</td>
</tr>
<tr>
<td>19</td>
<td>soft_utmi_sessend</td>
<td>R/W 0x0</td>
<td>Soft UTMI Sessend</td>
</tr>
<tr>
<td>18</td>
<td>phy_reset_sel</td>
<td>R/W 0x0</td>
<td>PHY Reset Select</td>
</tr>
<tr>
<td>17</td>
<td>soft_phy_reset</td>
<td>R/W 0x1</td>
<td>Soft PHY Reset</td>
</tr>
<tr>
<td>16</td>
<td>iddq_test</td>
<td>R/W 0x0</td>
<td>Iddq Test</td>
</tr>
<tr>
<td>15</td>
<td>usb_resume</td>
<td>R 0x1</td>
<td>USB Resume</td>
</tr>
<tr>
<td>14:13</td>
<td>reg_tx_buf_wtc</td>
<td>R/W 0x1</td>
<td>reg_tx_buf_wtc</td>
</tr>
<tr>
<td>12:11</td>
<td>reg_tx_buf_rtc</td>
<td>R/W 0x2</td>
<td>reg_tx_buf_rtc</td>
</tr>
<tr>
<td>10:9</td>
<td>reg_rx_buf_wtc</td>
<td>R/W 0x1</td>
<td>reg_rx_buf_wtc</td>
</tr>
<tr>
<td>8:7</td>
<td>reg_rx_buf_rtc</td>
<td>R/W 0x2</td>
<td>reg_rx_buf_rtc</td>
</tr>
<tr>
<td>6</td>
<td>reg_tx_pdlvmc</td>
<td>R/W 0x0</td>
<td>reg_tx_pdlvmc</td>
</tr>
<tr>
<td>5</td>
<td>reg_tx_pdfvssm</td>
<td>R/W 0x0</td>
<td>reg_tx_pdfvssm</td>
</tr>
<tr>
<td>4</td>
<td>reg_rx_pdlvmc</td>
<td>R/W 0x0</td>
<td>reg_rx_pdlvmc</td>
</tr>
<tr>
<td>3</td>
<td>reg_rx_pdfvssm</td>
<td>R/W 0x0</td>
<td>reg_rx_pdfvssm</td>
</tr>
<tr>
<td>2</td>
<td>usb_pu</td>
<td>R/W 0x0</td>
<td>USB PU</td>
</tr>
<tr>
<td>1</td>
<td>usb_pu_otg</td>
<td>R/W 0x0</td>
<td>USB PU OTG</td>
</tr>
<tr>
<td>0</td>
<td>usb_pu_pll</td>
<td>R/W 0x0</td>
<td>USB PU PLL</td>
</tr>
</tbody>
</table>
## Acronyms and Abbreviation

Table 666: Acronyms and Abbreviations

<table>
<thead>
<tr>
<th>Acronym</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACK</td>
<td>Acknowledgment</td>
</tr>
<tr>
<td>ACOMP</td>
<td>Analog Comparator</td>
</tr>
<tr>
<td>ADC</td>
<td>Analog-to-Digital Converter</td>
</tr>
<tr>
<td>AES</td>
<td>Advanced Encryption Standard</td>
</tr>
<tr>
<td>AHB</td>
<td>Advanced High-performance Bus</td>
</tr>
<tr>
<td>AMUX</td>
<td>Analog Multiplexer</td>
</tr>
<tr>
<td>APB</td>
<td>Advanced Peripheral Bus</td>
</tr>
<tr>
<td>AON</td>
<td>Always ON</td>
</tr>
<tr>
<td>ARM</td>
<td>Advanced RISC Machine</td>
</tr>
<tr>
<td>CBC</td>
<td>Cipher Block Chaining</td>
</tr>
<tr>
<td>CCM</td>
<td>Carrier Controlled Modulation</td>
</tr>
<tr>
<td>CCM</td>
<td>Continuity Check Message</td>
</tr>
<tr>
<td>CPU</td>
<td>Central Processing Unit</td>
</tr>
<tr>
<td>CRC</td>
<td>Cyclic Redundancy Check</td>
</tr>
<tr>
<td>CTR</td>
<td>Counter (encryption mode)</td>
</tr>
<tr>
<td>DAC</td>
<td>Digital-to-Analog Converter</td>
</tr>
<tr>
<td>DMA</td>
<td>Direct Memory Access</td>
</tr>
<tr>
<td>DMAC</td>
<td>Direct Memory Access Controller</td>
</tr>
<tr>
<td>DSSS</td>
<td>Direct Sequence Spread Spectrum</td>
</tr>
<tr>
<td>ECB</td>
<td>Electronic Code Book</td>
</tr>
<tr>
<td>EHCI</td>
<td>Enhanced Host Controller Interface</td>
</tr>
<tr>
<td>FIFO</td>
<td>First In First Out</td>
</tr>
<tr>
<td>GAU</td>
<td>General Analog Unit</td>
</tr>
<tr>
<td>GPIO</td>
<td>General Purpose Input/Output</td>
</tr>
<tr>
<td>GPT</td>
<td>General Purpose Timer</td>
</tr>
<tr>
<td>I/O</td>
<td>Input/Output</td>
</tr>
<tr>
<td>I/F</td>
<td>Interface</td>
</tr>
<tr>
<td>IoT</td>
<td>Internet of Things</td>
</tr>
<tr>
<td>JTAG</td>
<td>Joint Test Action Group</td>
</tr>
<tr>
<td>LQFN</td>
<td>Low Quad Flat Non-leaded</td>
</tr>
<tr>
<td>LSb</td>
<td>Least Significant bit</td>
</tr>
<tr>
<td>LSB</td>
<td>Least Significant Byte</td>
</tr>
<tr>
<td>MAC</td>
<td>Media/Medium Access Controller</td>
</tr>
<tr>
<td>MCI</td>
<td>Microcontroller Subsystem</td>
</tr>
<tr>
<td>Acronym</td>
<td>Definition</td>
</tr>
<tr>
<td>---------</td>
<td>------------</td>
</tr>
<tr>
<td>MCS</td>
<td>Modulation and Coding Scheme</td>
</tr>
<tr>
<td>MIC</td>
<td>Message Integrity Code</td>
</tr>
<tr>
<td>MII</td>
<td>Media Independent Interface</td>
</tr>
<tr>
<td>MIMO</td>
<td>Multiple Input Multiple Output</td>
</tr>
<tr>
<td>MMO</td>
<td>Matyas-Meyer-Oseas (encryption algorithm)</td>
</tr>
<tr>
<td>MPU</td>
<td>Memory Protection Unit</td>
</tr>
<tr>
<td>MSb</td>
<td>Most Significant bit</td>
</tr>
<tr>
<td>MSB</td>
<td>Most Significant Byte</td>
</tr>
<tr>
<td>M2M</td>
<td>Machine to Machine</td>
</tr>
<tr>
<td>NACK</td>
<td>Negative Acknowledgment</td>
</tr>
<tr>
<td>NVIC</td>
<td>Nested Vectored Interrupt Controller</td>
</tr>
<tr>
<td>OFDM</td>
<td>Orthogonal Frequency Division Multiplexing</td>
</tr>
<tr>
<td>OTG</td>
<td>On-The-Go</td>
</tr>
<tr>
<td>OTP</td>
<td>One Time Programmable</td>
</tr>
<tr>
<td>PGA</td>
<td>Programmable Gain Amplifier</td>
</tr>
<tr>
<td>PHY</td>
<td>Physical Layer</td>
</tr>
<tr>
<td>PLL</td>
<td>Phase-Locked Loop</td>
</tr>
<tr>
<td>PMIP</td>
<td>Power Management Intellectual Property</td>
</tr>
<tr>
<td>PMU</td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>POR</td>
<td>Power-On Reset</td>
</tr>
<tr>
<td>POS</td>
<td>Point of Sale</td>
</tr>
<tr>
<td>PSP</td>
<td>Programmable Serial Protocol</td>
</tr>
<tr>
<td>PSU</td>
<td>Power Supply Unit</td>
</tr>
<tr>
<td>PWM</td>
<td>Pulse Width Modulation</td>
</tr>
<tr>
<td>QFN</td>
<td>Quad Flat Non-leaded Package</td>
</tr>
<tr>
<td>QSPI</td>
<td>Quad Serial Peripheral Interface</td>
</tr>
<tr>
<td>RAM</td>
<td>Random Access Memory</td>
</tr>
<tr>
<td>RIFS</td>
<td>Reduced Inter-Frame Spacing</td>
</tr>
<tr>
<td>ROM</td>
<td>Read Only Memory</td>
</tr>
<tr>
<td>RTC</td>
<td>Real Time Clock</td>
</tr>
<tr>
<td>SCL</td>
<td>Serial Interface Clock</td>
</tr>
<tr>
<td>SDA</td>
<td>Serial Interface Data</td>
</tr>
<tr>
<td>SoC</td>
<td>System-on-Chip</td>
</tr>
<tr>
<td>SPH</td>
<td>Serial Clock Phase or Clock Out Phase Control</td>
</tr>
<tr>
<td>SPI</td>
<td>Serial Peripheral Interface</td>
</tr>
<tr>
<td>SRAM</td>
<td>Static Random Access Memory</td>
</tr>
<tr>
<td>SSP</td>
<td>Synchronous Serial Protocol</td>
</tr>
</tbody>
</table>
### Table 666: Acronyms and Abbreviations (Continued)

<table>
<thead>
<tr>
<th>Acronym</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>SWD</td>
<td>Serial Wire Debug</td>
</tr>
<tr>
<td>UART</td>
<td>Universal Asynchronous Receiver/Transmitter</td>
</tr>
<tr>
<td>USB</td>
<td>Universal Serial Bus</td>
</tr>
<tr>
<td>UTMI</td>
<td>USB 2.0 Transceiver Macrocell Interface</td>
</tr>
<tr>
<td>VBAT</td>
<td>Voltage of Battery (Battery Voltage)</td>
</tr>
<tr>
<td>VCO</td>
<td>Voltage Controlled Oscillator</td>
</tr>
<tr>
<td>WDT</td>
<td>Watchdog Timer</td>
</tr>
<tr>
<td>WLAN</td>
<td>Wireless Local Area Network</td>
</tr>
<tr>
<td>XIP</td>
<td>eXecute In Place</td>
</tr>
<tr>
<td>XOSC</td>
<td>Crystal Oscillator</td>
</tr>
<tr>
<td>XTAL</td>
<td>Crystal</td>
</tr>
</tbody>
</table>
26 Revision History

Table 667: Revision History

<table>
<thead>
<tr>
<th>Revision</th>
<th>Date</th>
<th>Description</th>
</tr>
</thead>
</table>
| Rev. 3   | 14-Jul-2020| **Overall Document**  
• Applied NXP branding and document numbering scheme.  
• Changed the scope to public document  
**General Purpose Input Output (GPIO)**  
• Figure 33, General Purpose I/O Block Diagram: updated  
**Direct Memory Access (DMA) Controller**  
• Figure 36, Burst Transaction – hclk=2*per_clk: improved readability  
• Figure 37, Back-to-Back Burst Transaction – hclk=2*per_clk: improved readability  
• Figure 38, Single Transaction – hclk=2*per_clk: improved readability  
• Figure 39, Burst Followed by Back-to-Back Single Transactions: improved readability  
**Electrical Specifications**  
• Section 22.12.1, Receive Mode Specifications: updated the Maximum Receive Sensitivity values  
**Ordering Information**  
• Updated the part order codes |
| Rev. A   | 26-Jun-2018| **Package:**  
• Section 1.5, Configuration Pins, on page 71: changed pull-down resistor value from 100 kΩ to 10 kΩ or less  
**Power:**  
• Section 3.2.1.1, Power Supply Blocks, on page 46: clarified PSU and PMIP  
**Electrical Specifications:**  
• Section 22.2, Recommended Operating Conditions, on page 270: added note  
• Table 177, VBAT BOD Timing Data, on page 283: fixed typos in 2nd note:  
  • From Vrise(BOD) – BOD rising edge to Vrise(BOD) = BOD rising edge  
  • From Vrise(BOD) = Vtrig(BOD) – Vtrig(BOD) to Vrise(BOD) = Vtrig(BOD) + Vtrig(BOD)  
**Acronyms:**  
• Added DSSS, MAC, MCI, MCS, PMIC, PSU, RIFS  
• Fixed spelling for Acknowledgment (and throughout document) |
| Rev. -   | 17-Apr-2018| First release.                                                               |
27 Legal Information

27.1 Data sheet status

<table>
<thead>
<tr>
<th>Document status¹, ²</th>
<th>Product status³</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>Objective [short] data sheet</td>
<td>Development</td>
<td>This document contains data from the objective specification for product development.</td>
</tr>
<tr>
<td>Preliminary [short] data sheet</td>
<td>Qualification</td>
<td>This document contains data from the preliminary specification.</td>
</tr>
<tr>
<td>Product [short] data sheet</td>
<td>Production</td>
<td>This document contains the product specification.</td>
</tr>
</tbody>
</table>

¹. Please consult the most recently issued document before initiating or completing a design.
². The term 'short data sheet' is explained in section "Definitions".
³. The product status of device(s) described in this document may have changed since this document was published and may differ in case of multiple devices. The latest product status information is available on the Internet at URL http://www.nxp.com.

27.2 Definitions

Draft — The document is a draft version only. The content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included herein and shall have no liability for the consequences of use of such information.

Short data sheet — A short data sheet is an extract from a full data sheet with the same product type number(s) and title. A short data sheet is intended for quick reference only and should not be relied upon to contain detailed and full information. For detailed and full information see the relevant full data sheet, which is available on request via the local NXP Semiconductors sales office. In case of any inconsistency or conflict with the short data sheet, the full data sheet shall prevail.

Product specification — The information and data provided in a Product data sheet shall define the specification of the product as agreed between NXP Semiconductors and its customer, unless NXP Semiconductors and customer have explicitly agreed otherwise in writing. In no event however, shall an agreement be valid in which the NXP Semiconductors product is deemed to offer functions and qualities beyond those described in the Product data sheet.

27.3 Disclaimers

Limited warranty and liability — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors. In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether
or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory. Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors.

Right to make changes — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Applications — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification. Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer’s sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer’s applications and products planned, as well as for the planned application and use of customer’s third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products. NXP Semiconductors does not accept any liability related to any weakness or default in the customer’s applications or products, or the application or use by customer’s third party customer(s). Customer is responsible for doing all necessary testing for the customer’s applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer’s third party customer(s). NXP does not accept any liability in this respect.

Limiting values — Stress above one or more limiting values (as defined in the Absolute Maximum Ratings System of IEC 60134) will cause permanent damage to the device. Limiting values are stress ratings only and (proper) operation of the device at these or any other conditions above those given in the Recommended operating conditions section (if present) or the Characteristics sections of this document is not warranted. Constant or repeated exposure to limiting values will permanently and irreversibly affect the quality and reliability of the device.

Terms and conditions of commercial sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at http://www.nxp.com/profile/terms, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer’s general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

No offer to sell or license — Nothing in this document may be interpreted or construed as an offer to sell products that is open for acceptance or the grant, conveyance or implication of any license under any copyrights, patents or other industrial or intellectual property rights.

Quick reference data — The Quick reference data is an extract of the product data given in the Limiting values and Characteristics sections of this document, and as such is not complete, exhaustive or legally binding.

Export control — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities.

Translations — A non-English (translated) version of a document is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions.
Security — While NXP Semiconductors has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer’s applications and products, and NXP Semiconductors accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products.

27.4 Trademarks

Notice: All referenced brands, product names, service names and trademarks are the property of their respective owners.
List of Tables

Product Overview .................................................. 1
Table 1: Package Feature Differences .......................... 3

1 Package .............................................................. 6
Table 2: Pin Types ..................................................... 11
Table 3: WLAN RF Interface ...................................... 12
Table 4: WLAN RF Front End Interface ....................... 12
Table 5: USB 2.0 OTG Interface .................................. 12
Table 6: UART Interface .......................................... 13
Table 7: GPT Interface ............................................. 15
Table 8: SSP Interface ........................................... 16
Table 9: I2C Interface ............................................ 18
Table 10: QSPI Interface ......................................... 18
Table 11: GPIO Interface ......................................... 19
Table 12: Clock/Control Interface .............................. 29
Table 13: ADC/DAC/ACOMP Interface ....................... 30
Table 14: LDO18 Comparator Interface ....................... 31
Table 15: JTAG Interface ......................................... 31
Table 16: Power and Ground .................................... 32
Table 17: Configuration Pins .................................... 33

2 Core and System Control .................................... 34
Table 18: System Address Memory Map ....................... 38
Table 19: RAM Blocks ............................................ 40
Table 20: External Interrupts .................................... 41
Table 21: GPIO Mapping to External Interrupts ............. 43

3 Power, Reset, and Clock Control ......................... 46
Table 22: VDD_MCU Address Memory ......................... 49
Table 23: I/O Power Configuration ............................. 50
Table 24: System Power Modes ................................ 52
Table 25: MCI Subsystem Power Modes ....................... 53
Table 26: Address of Memories Available in State Retention Mode ............................................ 53
Table 27: Cortex-M4F Core Power States ..................... 57
Table 28: SRAM Memory Power States ....................... 57
Table 29: Flash Memory Power Modes ....................... 57

Table 30: Low-Power Mode Wake-Up Sources ............... 58
Table 31: Clock Sources ........................................... 60
Table 32: Clock Frequency ....................................... 62
Table 33: APB0 Bus Clock Divider Ratio ..................... 63
Table 34: APB1 Bus Clock Divider Ratio ..................... 63
Table 35: UART Slow and Fast Clock Programming ........ 64
Table 36: VCO Frequency Select ............................... 64
Table 37: AUPLL Post Divider Programming ................. 65

4 Boot ROM .......................................................... 67
Table 38: Boot Pin Configuration ............................... 68
Table 39: OTP Content ............................................ 68
Table 40: AON Data Structure .................................. 69
Table 41: Sub-Field in bootMode .............................. 69
Table 42: Sub-Field in powerMode ............................ 69
Table 43: Sub-Field in errorCode .............................. 70
Table 44: Boot ROM Memory Usage ......................... 80
Table 45: Code Image Fields .................................... 82
Table 46: Sub-Field in commonCfg0 ......................... 85
Table 47: Sub-Field in sfiCfg ................................... 85
Table 48: Sub-Field in flashCfg0 ............................. 86
Table 49: Sub-Field in flashCfg1 ............................. 87
Table 50: Sub-Field in flashCfg2 ............................. 89
Table 51: Sub-Field in bootCfg0 ............................. 89
Table 52: Sub-Field in bootCfg1 ............................. 89
Table 53: User Data Format .................................... 90
Table 54: DFU Request Type ................................... 96
Table 55: DFU Requests .......................................... 96
Table 56: Boot ROM GPIOs ................................. 97
Table 57: Flash Boot Mode, Basic Functions ................. 98
Table 58: Flash Boot Mode, Additional Functions ........... 99
Table 59: SPI Flash for Basic Flash Boot Function .......... 100

5 Flash Controller ................................................. 104

6 General Purpose Input Output (GPIO) ................. 108
<table>
<thead>
<tr>
<th>Table</th>
<th>GPIO</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>66</td>
<td>GPIO_6</td>
<td>0x18</td>
</tr>
<tr>
<td>67</td>
<td>GPIO_7</td>
<td>0x1C</td>
</tr>
<tr>
<td>68</td>
<td>GPIO_8</td>
<td>0x20</td>
</tr>
<tr>
<td>69</td>
<td>GPIO_9</td>
<td>0x24</td>
</tr>
<tr>
<td>70</td>
<td>GPIO_10</td>
<td>0x28</td>
</tr>
<tr>
<td>71</td>
<td>GPIO_11</td>
<td>0x2C</td>
</tr>
<tr>
<td>72</td>
<td>GPIO_12</td>
<td>0x30</td>
</tr>
<tr>
<td>73</td>
<td>GPIO_13</td>
<td>0x34</td>
</tr>
<tr>
<td>74</td>
<td>GPIO_14</td>
<td>0x38</td>
</tr>
<tr>
<td>75</td>
<td>GPIO_15</td>
<td>0x3C</td>
</tr>
<tr>
<td>76</td>
<td>GPIO_16</td>
<td>0x40</td>
</tr>
<tr>
<td>77</td>
<td>GPIO_17</td>
<td>0x44</td>
</tr>
<tr>
<td>78</td>
<td>GPIO_18</td>
<td>0x48</td>
</tr>
<tr>
<td>79</td>
<td>GPIO_19</td>
<td>0x4C</td>
</tr>
<tr>
<td>80</td>
<td>GPIO_20</td>
<td>0x50</td>
</tr>
<tr>
<td>81</td>
<td>GPIO_21</td>
<td>0x54</td>
</tr>
<tr>
<td>82</td>
<td>GPIO_22</td>
<td>0x58</td>
</tr>
<tr>
<td>83</td>
<td>GPIO_23</td>
<td>0x5C</td>
</tr>
<tr>
<td>84</td>
<td>GPIO_24</td>
<td>0x60</td>
</tr>
<tr>
<td>85</td>
<td>GPIO_25</td>
<td>0x64</td>
</tr>
<tr>
<td>86</td>
<td>GPIO_26</td>
<td>0x68</td>
</tr>
<tr>
<td>87</td>
<td>GPIO_27</td>
<td>0x6C</td>
</tr>
<tr>
<td>88</td>
<td>GPIO_28</td>
<td>0x70</td>
</tr>
<tr>
<td>89</td>
<td>GPIO_29</td>
<td>0x74</td>
</tr>
<tr>
<td>90</td>
<td>GPIO_30</td>
<td>0x78</td>
</tr>
<tr>
<td>91</td>
<td>GPIO_31</td>
<td>0x7C</td>
</tr>
<tr>
<td>92</td>
<td>GPIO_32</td>
<td>0x80</td>
</tr>
<tr>
<td>93</td>
<td>GPIO_33</td>
<td>0x84</td>
</tr>
<tr>
<td>94</td>
<td>GPIO_34</td>
<td>0x88</td>
</tr>
<tr>
<td>95</td>
<td>GPIO_35</td>
<td>0x8C</td>
</tr>
<tr>
<td>96</td>
<td>GPIO_36</td>
<td>0x90</td>
</tr>
<tr>
<td>97</td>
<td>GPIO_37</td>
<td>0x94</td>
</tr>
<tr>
<td>98</td>
<td>GPIO_38</td>
<td>0x98</td>
</tr>
<tr>
<td>99</td>
<td>GPIO_39</td>
<td>0x9C</td>
</tr>
<tr>
<td>100</td>
<td>GPIO_40</td>
<td>0xA0</td>
</tr>
<tr>
<td>101</td>
<td>GPIO_41</td>
<td>0xA4</td>
</tr>
<tr>
<td>102</td>
<td>GPIO_42</td>
<td>0xA8</td>
</tr>
<tr>
<td>103</td>
<td>GPIO_43</td>
<td>0xAC</td>
</tr>
<tr>
<td>104</td>
<td>GPIO_44</td>
<td>0xB0</td>
</tr>
<tr>
<td>105</td>
<td>GPIO_45</td>
<td>0xB4</td>
</tr>
<tr>
<td>106</td>
<td>GPIO_46</td>
<td>0xB8</td>
</tr>
<tr>
<td>107</td>
<td>GPIO_47</td>
<td>0xBC</td>
</tr>
<tr>
<td>108</td>
<td>GPIO_48</td>
<td>0xC0</td>
</tr>
<tr>
<td>109</td>
<td>GPIO_49</td>
<td>0xC4</td>
</tr>
</tbody>
</table>
Table 110: I/O Pin Mode Configuration ................. 123

7 WLAN ....................................................................... 127
Table 111: Channel Frequencies Supported .......... 129

8 Direct Memory Access (DMA) Controller ........ 130
Table 112: Clock Unit Interface Signals .......... 132
Table 113: Handshake Interface Signals .......... 133
Table 114: DMA Interrupt Request Interface Signals .... 133
Table 115: AHB Slave Interface Signals .......... 133
Table 116: AHB Master Interface Signals ........ 134
Table 117: Channel Priority ......................... 135
Table 118: Hardware Handshaking Interface Signals ... 137
Table 127: Error Status for Different AES Block Cipher Modes ........................................ 168
Table 128: AES Output Vector ................................. 168

13 Cyclic REDundancy Check (CRC) ................. 170

14 Universal Asynchronous Receiver Transmitter (UART) ........................................ 172
Table 129: Pad Interface Signals ......................... 173
Table 130: Internal Interface Signals ................. 173
Table 131: AMBA APB Interface Signals ............ 174
Table 138: I2C Interface Signals ......................... 192
Table 139: I2C Bus Terminology ......................... 192

16 Synchronous Serial Protocol (SSP) .......... 205
Table 140: SSP Interface Signals ......................... 206
Table 141: SSP Interrupts ................................. 211
Table 142: Programmable Protocol Parameters .... 218

Table 143: USB OTG Controller Interface Signals .. 227
Table 144: USB Host Controller Interface Signals ... 228

18 Quad Serial Peripheral Interface (QSPI) Controller ............................................... 237
Table 145: QSPI Interface Signals ......................... 237

19 Analog Digital Converter (ADC) .................. 246
Table 146: ADC Interface Signals ......................... 249
Table 147: ADC Input Configurations ................. 249
Table 148: Detailed Input Range ......................... 250
Table 149: ADC Conversion Time and Throughput Rate Lookup Table ............................... 252
Table 150: ADC Conversion Result Format (OSR[1:0]=2'b11 or =2'b10) ............... 253
Table 151: ADC Conversion Result Format (OSR[1:0]=2'b01) ................................. 253
Table 152: ADC Conversion Result Format (OSR[1:0]=2'b00) ................................. 254
Table 157: ACOMP Module Interface Signals .......... 263

9 Real Time Clock (RTC) ................................. 144
Table 119: Counter Update Mode ......................... 145

10 Watchdog Timer (WDT) ................................. 147
Table 120: GPT Interface Signals ......................... 150
Table 121: Counter Update Mode Configuration .... 153
Table 122: Available Interrupt Events ................. 154
Table 123: 1-Shot Pulse Control Registers .......... 156
Table 124: PWM Edge-Aligned Control Registers ... 157
Table 125: PWM Center-Aligned Control Registers 159

11 General Purpose Timers (GPT) .................... 150
Table 126: Padding Scheme ................................. 167
Table 132: Parity Truth Table ................................. 176
Table 133: Baud Rate Divider ............................... 178
Table 134: DMA Trigger Points for Transmit FIFO .. 183
Table 135: DMA Trigger Points for Receive FIFO ... 183
Table 136: Modem I/O Signals in DTE Mode ........ 185
Table 137: Control Bits to Enable Hardware Flow Control ........................................ 186

12 Advanced Encryption Standard (AES) ......... 164

14 UART ............................................................. 172
Table 130: Internal Interface Signals ................. 173
Table 131: AMBA APB Interface Signals ............ 174

15 Inter-Integrated Circuit (I2C) ....................... 190

17 USB OTG Interface Controller (USBC) ........ 227
Table 143: USB OTG Controller Interface Signals .. 227
Table 144: USB Host Controller Interface Signals ... 228

20 Digital Analog Converter (DAC) .................. 257
Table 154: DAC Interface Signals ......................... 257
Table 155: Output Voltage Calculation Formula ... 258
Table 156: Clock Divisor ................................. 258

21 Analog Comparator (ACOMP) ..................... 262
22 Electrical Specifications ........................................269
Table 158: Absolute Maximum Ratings ..................... 269
Table 159: Recommended Operating Conditions .......... 270
Table 160: I/O Static Ratings, 1.8V VDDIO ............... 271
Table 161: I/O Static Ratings, 2.5V VDDIO ............... 271
Table 162: I/O Static Ratings, 3.3V VDDIO ............... 272
Table 163: WLAN Tx/Rx Current Consumption .......... 273
Table 164: WLAN Estimated Tx PA Power vs. Current Consumption ...................................................... 274
Table 165: MCI VBAT Consumption .......................... 275
Table 166: LDO11 Specifications ............................. 276
Table 167: BUCK18 Specifications ............................ 276
Table 168: Efficiency vs. BUCK18 VBAT_IN @ 147 mA Output ................................................................. 277
Table 169: Thermal Conditions—68-pin QFN ............. 279
Table 170: Thermal Conditions—88-pin QFN .......... 280
Table 171: RC32K Specifications .............................. 281
Table 172: CMOS Mode Specifications ..................... 281
Table 173: Phase Noise—2.4 GHz Operation Specifications ................................................................. 281
Table 174: Crystal Specifications (38.4 MHz) ............. 282
Table 175: Crystal Specifications (32.768 kHz) ............ 282
Table 176: POR Specifications ................................ 283
Table 177: VBAT BOD Timing Data ......................... 283
Table 178: ADC Specifications .............................. 284
Table 179: ADC Temperature Sensor Specifications .... 288
Table 180: ADC Battery Voltage Monitor Specifications ................................................................. 289
Table 181: ADC Audio Mode Specifications ............. 289
Table 182: DAC Specifications .............................. 291
Table 183: ACOMP Specifications ......................... 293
Table 184: SSP Timing Data .................................. 294
Table 185: QSPI Timing Data .............................. 296
Table 186: USB Timing Data .................................. 296
Table 187: RESETn Pin Specification ....................... 298
Table 188: LNA and Rx RF Mixer Specifications—802.11n/g/b .......................................................... 298
Table 189: Tx Mode Specifications—802.11n/g/b .... 299
Table 190: Local Oscillator Specifications ............... 300
23 Ordering Information/Package Marking ............ 301
Table 191: Part Order Options ............................... 301
24 88MW320/322 Register Set ............................. 303
Table 192: Overall Memory Map ............................ 303
Table 193: DMA Channel BLOCK TRANSFER INTERRUPT MASK Register (MASK_BLOCKINT) ............. 311
Table 194: DMA Channel BLOCK TRANSFER INTERRUPT Register (STATUS_BLOCKINT) .............. 315
Table 195: DMA Channel Transfer Completion Interrupt Mask Register (MASK_TFRINT) .............. 319
Table 196: DMA Channel Transfer Completion Interrupt Register (STATUS_TFRINT) ................... 324
Table 197: DMA Channel Bus Error Interrupt Mask Register (MASK_BUSERRINT) ......................... 327
Table 198: DMA Channel Bus Error Interrupt Mask Register (STATUS_BUSERRINT) ................... 331
Table 199: DMA Channel Source/target Address Alignment Error Interrupt Mask Register (MASK_ADDRERRINT) ........................................................................... 336
Table 200: DMA Channel Source/target Address Alignment Error Interrupt Register (STATUS_ADDRERRINT) ........................................................................... 341
Table 201: DMA CHANNEL INTERRUPT REGISTER (STATUS_CHLINT) ........................................... 345
Table 202: Protection Control Signals Register (HPROT) ..................................................................... 348
Table 203: DMA Source Address Register (SADR) .............................................................................. 348
Table 204: DMA TARGET ADDRESS Register (TADR) ..................................................................... 348
Table 205: DMA CONTROL Register A (CTRLA) .............................................................................. 349
Table 206: DMA CONTROL Register B (CTRLB) .............................................................................. 350
Table 207: DMA CHANNEL ENABLE Register (CHL_EN) .............................................................. 351
Table 208: DMA CHANNEL STOP Register (CHL_STOP) ............................................................... 351
Table 209: DMA ACK DELAY CYCLE for Single Transfer in M2P Transfer Type Register (ACK_DELAY) ........................................................................... 352
Table 210: DMA ERROR INFORMATION REGISTER 0 (ERR_INFO0) .................................................. 352
Table 211: DMA ERROR INFORMATION REGISTER 1 (ERR_INFO1) .................................................. 352
<p>| Table 213: DMA DIAGNOSE INFORMATION REGISTER 0 (DIAGNOSE_INFO0) .......................... 353 |
| Table 214: DMA DIAGNOSE INFORMATION REGISTER 1 (DIAGNOSE_INFO1) .................. 353 |
| Table 215: DMA DIAGNOSE INFORMATION REGISTER 2 (DIAGNOSE_INFO2) ................. 353 |
| Table 216: DMA DIAGNOSE INFORMATION REGISTER 3 (DIAGNOSE_INFO3) ................. 354 |
| Table 217: DMA DIAGNOSE INFORMATION REGISTER 4 (DIAGNOSE_INFO4) ................. 354 |
| Table 218: DMA DIAGNOSE INFORMATION REGISTER 5 (DIAGNOSE_INFO5) ................. 354 |
| Table 219: DMA DIAGNOSE INFORMATION REGISTER 6 (DIAGNOSE_INFO6) ................. 355 |
| Table 220: DMA DIAGNOSE INFORMATION REGISTER 7 (DIAGNOSE_INFO7) ................. 356 |
| Table 222: ID Register (ID) ....................................................................................... 360 |
| Table 223: HW General Register (HWGENERAL) .......................................................... 361 |
| Table 224: HW Host Register (HWHOST) ..................................................................... 361 |
| Table 225: HW Device Register (HWDEVICE) ............................................................. 362 |
| Table 226: HW TXBUF Register (HWTXBUF) ............................................................... 362 |
| Table 227: HW RXBUF Register (HWRXBUF) ............................................................... 363 |
| Table 228: HW TXBUF0 Register (HWTXBUF0) ........................................................... 363 |
| Table 229: HW TXBUF1 Register (HWTXBUF1) ........................................................... 363 |
| Table 230: GPTIMER0LD Register (GPTIMER0LD) ...................................................... 364 |
| Table 231: GPTIMER0CTRL (GPTIMER0CTRL) .......................................................... 364 |
| Table 232: GPTIMER1LD Register (GPTIMER1LD) ...................................................... 364 |
| Table 233: GP Timer1 Control Register (GPTIMER1CTRL) .......................................... 365 |
| Table 234: SBUS Config Register (SBUSCFG) .............................................................. 365 |
| Table 235: Cap Length Register (CAPLENGTH) .......................................................... 366 |
| Table 236: HCS Params Register (HCSPARAMS) ......................................................... 366 |
| Table 237: HCC Params Register (HCCPARAMS) .......................................................... 367 |
| Table 238: DCI Version Register (DCIVERSION) ......................................................... 367 |
| Table 239: DCC Params Register (DCCPARAMS) .......................................................... 368 |
| Table 240: DevLPMCSR Register (DevLPMCSR) ......................................................... 368 |
| Table 241: USB Command Register (USBCMD) .......................................................... 370 |
| Table 242: USB STS Register (USBSTS) ....................................................................... 371 |
| Table 243: USB Interrupt Register (USBINTR) ............................................................ 372 |
| Table 244: FR Index Register (FRINDEX) ................................................................. 374 |
| Table 245: Periodic List Base Register (PERIODICLISTBASE) ................................. 374 |
| Table 246: Async List Address Register (ASYNCLISTADDR) ...................................... 375 |
| Table 247: TT Control Register (TTCTRL Register) ..................................................... 375 |
| Table 248: Burst Size Register (BURSTSIZE) ............................................................. 376 |
| Table 249: TX Fill Tuning Register (TXFILLTUNING) .................................................. 376 |
| Table 250: TX TT Fill Tuning Register (TXTTFILLTUNING) ......................................... 377 |
| Table 251: IC USB Register (IC_USB) ......................................................................... 377 |
| Table 252: ULPI Viewport Register (ULPI_VIEWPORT) .............................................. 378 |
| Table 253: Endpoint NAK Register (ENDPTNAK) ....................................................... 379 |
| Table 254: Endpoint NAKEN Register (ENDPTNAKEN) ............................................. 379 |
| Table 255: PORTSC1 Register (PORTSC1) ................................................................. 380 |
| Table 256: PORTSC2 Register (PORTSC2) ................................................................. 381 |
| Table 257: PORTSC3 Register (PORTSC3) ................................................................. 383 |</p>
<table>
<thead>
<tr>
<th>Table No.</th>
<th>Register Name</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>258</td>
<td>PORTSC4 Register (PORTSC4)</td>
<td>384</td>
</tr>
<tr>
<td>259</td>
<td>PORTSC5 Register (PORTSC5)</td>
<td>386</td>
</tr>
<tr>
<td>260</td>
<td>PORTSC6 Register (PORTSC6)</td>
<td>387</td>
</tr>
<tr>
<td>261</td>
<td>PORTSC7 Register (PORTSC7)</td>
<td>389</td>
</tr>
<tr>
<td>262</td>
<td>PORTSC8 Register (PORTSC8)</td>
<td>390</td>
</tr>
<tr>
<td>263</td>
<td>OTGSC Register (OTGSC)</td>
<td>392</td>
</tr>
<tr>
<td>264</td>
<td>USB Mode Register (USBMODE)</td>
<td>394</td>
</tr>
<tr>
<td>265</td>
<td>Endpoint Setup Stat Register (ENDPTSETUPSTAT)</td>
<td>394</td>
</tr>
<tr>
<td>266</td>
<td>Endpoint Prime Register (ENDPTPRIME)</td>
<td>395</td>
</tr>
<tr>
<td>267</td>
<td>Endpoint Flush Register (ENDPTFLUSH)</td>
<td>395</td>
</tr>
<tr>
<td>268</td>
<td>Endpoint Stat Register (ENDPTSTAT)</td>
<td>395</td>
</tr>
<tr>
<td>269</td>
<td>Endpoint Complete Register (ENDPTCOMPLETE)</td>
<td>396</td>
</tr>
<tr>
<td>270</td>
<td>Endpoint Control 0 Register (ENDPTCTRL0)</td>
<td>396</td>
</tr>
<tr>
<td>271</td>
<td>Endpoint Control 1 Register (ENDPTCTRL1)</td>
<td>397</td>
</tr>
<tr>
<td>272</td>
<td>Endpoint Control 2 Register (ENDPTCTRL2)</td>
<td>398</td>
</tr>
<tr>
<td>273</td>
<td>Endpoint Control 3 Register (ENDPTCTRL3)</td>
<td>399</td>
</tr>
<tr>
<td>274</td>
<td>Endpoint Control 4 Register (ENDPTCTRL4)</td>
<td>400</td>
</tr>
<tr>
<td>275</td>
<td>Endpoint Control 5 Register (ENDPTCTRL5)</td>
<td>401</td>
</tr>
<tr>
<td>276</td>
<td>Endpoint Control 6 Register (ENDPTCTRL6)</td>
<td>402</td>
</tr>
<tr>
<td>277</td>
<td>Endpoint Control 7 Register (ENDPTCTRL7)</td>
<td>404</td>
</tr>
<tr>
<td>278</td>
<td>Endpoint Control 8 Register (ENDPTCTRL8)</td>
<td>405</td>
</tr>
<tr>
<td>279</td>
<td>Endpoint Control 9 Register (ENDPTCTRL9)</td>
<td>406</td>
</tr>
<tr>
<td>280</td>
<td>Endpoint Control 10 Register (ENDPTCTRL10)</td>
<td>407</td>
</tr>
<tr>
<td>281</td>
<td>Endpoint Control 11 Register (ENDPTCTRL11)</td>
<td>408</td>
</tr>
<tr>
<td>282</td>
<td>Endpoint Control 12 Register (ENDPTCTRL12)</td>
<td>409</td>
</tr>
<tr>
<td>283</td>
<td>Endpoint Control 13 Register (ENDPTCTRL13)</td>
<td>410</td>
</tr>
<tr>
<td>284</td>
<td>Endpoint Control 14 Register (ENDPTCTRL14)</td>
<td>411</td>
</tr>
<tr>
<td>285</td>
<td>Endpoint Control 15 Register (ENDPTCTRL15)</td>
<td>412</td>
</tr>
<tr>
<td>286</td>
<td>PHY ID Register (PHY_ID)</td>
<td>413</td>
</tr>
<tr>
<td>287</td>
<td>PLL Control 0 Register (PLL_Control_0)</td>
<td>413</td>
</tr>
<tr>
<td>288</td>
<td>PLL Control 1 Register (PLL_Control_1)</td>
<td>413</td>
</tr>
<tr>
<td>289</td>
<td>Reserved_Addr3 Register (Reserved_Addr3)</td>
<td>414</td>
</tr>
<tr>
<td>290</td>
<td>TX Channel Control 0 Register (Tx_Channel_Ctrl_0)</td>
<td>415</td>
</tr>
<tr>
<td>291</td>
<td>TX Channel Control 1 Register (Tx_Channel_Ctrl_1)</td>
<td>415</td>
</tr>
<tr>
<td>292</td>
<td>TX Channel Control 2 Register (Tx_Channel_Ctrl_2)</td>
<td>416</td>
</tr>
<tr>
<td>293</td>
<td>Reserved_Addr7 Register (Reserved_Addr7)</td>
<td>417</td>
</tr>
<tr>
<td>294</td>
<td>RX Channel Control 0 Register (Rx_Channel_Ctrl_0)</td>
<td>417</td>
</tr>
<tr>
<td>295</td>
<td>RX Channel Control 1 Register (Rx_Channel_Ctrl_1)</td>
<td>418</td>
</tr>
<tr>
<td>296</td>
<td>RX Channel Control 2 Register (Rx_Channel_Ctrl_2)</td>
<td>418</td>
</tr>
<tr>
<td>297</td>
<td>ANA Control 0 Register (Ana_Ctrl_0)</td>
<td>419</td>
</tr>
<tr>
<td>298</td>
<td>ANA Control 1 Register (Ana_Ctrl_1)</td>
<td>420</td>
</tr>
<tr>
<td>299</td>
<td>Reserved_Addr_C Register (Reserved_Addr_C)</td>
<td>420</td>
</tr>
<tr>
<td>300</td>
<td>Digital Control 0 Register (Digital_Control_0)</td>
<td>421</td>
</tr>
<tr>
<td>301</td>
<td>Digital Control 1 Register (Digital_Control_1)</td>
<td>422</td>
</tr>
<tr>
<td>Table</td>
<td>Description</td>
<td></td>
</tr>
<tr>
<td>-------</td>
<td>-----------------------------------------------------------------------------</td>
<td></td>
</tr>
<tr>
<td>Table 302:</td>
<td>Digital Control 2 Register (Digital_Control_2)</td>
<td></td>
</tr>
<tr>
<td>Table 303:</td>
<td>Reserved_Addr_12H Register (Reserved_Addr_12H)</td>
<td></td>
</tr>
<tr>
<td>Table 304:</td>
<td>Test Control and Status 0 Register (Test_Control_and_Status_0)</td>
<td></td>
</tr>
<tr>
<td>Table 305:</td>
<td>Test Control and Status 1 Register (Test_Control_and_Status_1)</td>
<td></td>
</tr>
<tr>
<td>Table 306:</td>
<td>Reserved_Addr_15H Register (Reserved_Addr_15H)</td>
<td></td>
</tr>
<tr>
<td>Table 307:</td>
<td>PHY_REG_CHGDTC Control Register (PHY_REG_CHGDTC_CONTRL)</td>
<td></td>
</tr>
<tr>
<td>Table 308:</td>
<td>PHY_REG_OTG Control Register (PHY_REG_OTG_CONTROL)</td>
<td></td>
</tr>
<tr>
<td>Table 309:</td>
<td>USB2 PHY Monitor 0 Register (usb2_phy_mon0)</td>
<td></td>
</tr>
<tr>
<td>Table 310:</td>
<td>PHY_REG_CHGDTC Control 1 Register (PHY_REG_CHGDTC_CONTRL_1)</td>
<td></td>
</tr>
<tr>
<td>Table 311:</td>
<td>Reserved_Addr_1AH Register (Reserved_Addr_1AH)</td>
<td></td>
</tr>
<tr>
<td>Table 312:</td>
<td>Reserved_Addr_1BH Register (Reserved_Addr_1bH)</td>
<td></td>
</tr>
<tr>
<td>Table 313:</td>
<td>Reserved_Addr_1CH Register (Reserved_Addr_1cH)</td>
<td></td>
</tr>
<tr>
<td>Table 314:</td>
<td>Reserved_Addr_1DH Register (Reserved_Addr_1dH)</td>
<td></td>
</tr>
<tr>
<td>Table 315:</td>
<td>Internal CID Register (Internal_CID)</td>
<td></td>
</tr>
<tr>
<td>Table 316:</td>
<td>USB2 ICID Register 1 (usb2_icid_reg1)</td>
<td></td>
</tr>
<tr>
<td>Table 318:</td>
<td>Flash Controller Configuration Register (FCCR)</td>
<td></td>
</tr>
<tr>
<td>Table 319:</td>
<td>Flash Controller Timing Register (FCTR)</td>
<td></td>
</tr>
<tr>
<td>Table 320:</td>
<td>Flash Controller Status Register (FCSR)</td>
<td></td>
</tr>
<tr>
<td>Table 321:</td>
<td>Flash Controller Auxiliary Configuration Register (FCACR)</td>
<td></td>
</tr>
<tr>
<td>Table 322:</td>
<td>Flash Controller Hit Count Register (FCHCR)</td>
<td></td>
</tr>
<tr>
<td>Table 323:</td>
<td>Flash Controller Miss Count Register (FCMCR)</td>
<td></td>
</tr>
<tr>
<td>Table 324:</td>
<td>Flash Address Offset Register (FAOFFR)</td>
<td></td>
</tr>
<tr>
<td>Table 325:</td>
<td>Flash Address Match Register (FADDMAT)</td>
<td></td>
</tr>
<tr>
<td>Table 326:</td>
<td>Flash Wait Register (FWAITR)</td>
<td></td>
</tr>
<tr>
<td>Table 327:</td>
<td>Flash Controller Configurationb Register2 (FCCR2)</td>
<td></td>
</tr>
<tr>
<td>Table 328:</td>
<td>Flash Instruction Register (FINSTR)</td>
<td></td>
</tr>
<tr>
<td>Table 329:</td>
<td>Flash Read Mode Register (FRMR)</td>
<td></td>
</tr>
<tr>
<td>Table 331:</td>
<td>AES Control Register 1 (ctrl1)</td>
<td></td>
</tr>
<tr>
<td>Table 332:</td>
<td>AES Control Register 2 (ctrl2)</td>
<td></td>
</tr>
<tr>
<td>Table 333:</td>
<td>AES Status Register (status)</td>
<td></td>
</tr>
<tr>
<td>Table 334:</td>
<td>AES Astr Length Register (astr_len)</td>
<td></td>
</tr>
<tr>
<td>Table 335:</td>
<td>AES Mstr Length Register (mstr_len)</td>
<td></td>
</tr>
<tr>
<td>Table 336:</td>
<td>AES Stream Input Register (str_in)</td>
<td></td>
</tr>
<tr>
<td>Table 337:</td>
<td>AES Mstr Length Register 0 (iv0)</td>
<td></td>
</tr>
<tr>
<td>Table 338:</td>
<td>AES Input Vector Register 1 (iv1)</td>
<td></td>
</tr>
<tr>
<td>Table 339:</td>
<td>AES Input Vector Register 2 (iv2)</td>
<td></td>
</tr>
<tr>
<td>Table 340:</td>
<td>AES Input Vector Register 3 (iv3)</td>
<td></td>
</tr>
<tr>
<td>Table 341:</td>
<td>AES Key 0 Register (key0)</td>
<td></td>
</tr>
<tr>
<td>Table 342:</td>
<td>AES Key 1 Register (key1)</td>
<td></td>
</tr>
<tr>
<td>Table 343:</td>
<td>AES Key 2 Register (key2)</td>
<td></td>
</tr>
<tr>
<td>Table 344:</td>
<td>AES Key 3 Register (key3)</td>
<td></td>
</tr>
<tr>
<td>Table 345:</td>
<td>AES Key 4 Register (key4)</td>
<td></td>
</tr>
<tr>
<td>Table 346:</td>
<td>AES Key 5 Register (key5)</td>
<td></td>
</tr>
<tr>
<td>Table 347:</td>
<td>AES Key 6 Register (key6)</td>
<td></td>
</tr>
<tr>
<td>Table</td>
<td>Description</td>
<td>Page</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
<td>------</td>
</tr>
<tr>
<td>Table 348</td>
<td>AES Key 7 Register (key7)</td>
<td>448</td>
</tr>
<tr>
<td>Table 349</td>
<td>AES Stream Output Port Register (str_out)</td>
<td>448</td>
</tr>
<tr>
<td>Table 350</td>
<td>AES Output Vector 0 Register (ov0)</td>
<td>448</td>
</tr>
<tr>
<td>Table 351</td>
<td>AES Output Vector 1 Register (ov1)</td>
<td>449</td>
</tr>
<tr>
<td>Table 352</td>
<td>AES Output Vector 2 Register (ov2)</td>
<td>449</td>
</tr>
<tr>
<td>Table 353</td>
<td>AES Output Vector 3 Register (ov3)</td>
<td>449</td>
</tr>
<tr>
<td>Table 354</td>
<td>AES Interrupt Status Register (isr)</td>
<td>449</td>
</tr>
<tr>
<td>Table 355</td>
<td>AES Interrupt Mask Register (imr)</td>
<td>450</td>
</tr>
<tr>
<td>Table 356</td>
<td>AES Interrupt Raw Status Register (irsr)</td>
<td>451</td>
</tr>
<tr>
<td>Table 357</td>
<td>AES Interrupt Clear Register (icr)</td>
<td>451</td>
</tr>
<tr>
<td>Table 358</td>
<td>AES Revision Register (rev_id)</td>
<td>452</td>
</tr>
<tr>
<td>Table 360</td>
<td>Interrupt Status Register (isr)</td>
<td>453</td>
</tr>
<tr>
<td>Table 361</td>
<td>Interrupt Raw Status Register (irsr)</td>
<td>454</td>
</tr>
<tr>
<td>Table 362</td>
<td>Interrupt Clear Register (icr)</td>
<td>454</td>
</tr>
<tr>
<td>Table 363</td>
<td>Interrupt Mask Register (imr)</td>
<td>454</td>
</tr>
<tr>
<td>Table 364</td>
<td>CRC Module Control Register (ctrl)</td>
<td>455</td>
</tr>
<tr>
<td>Table 365</td>
<td>Stream Length Minus 1 Register (stream_len_m1)</td>
<td>455</td>
</tr>
<tr>
<td>Table 366</td>
<td>Stream Input Register (stream_in)</td>
<td>456</td>
</tr>
<tr>
<td>Table 367</td>
<td>CRC Calculation Result (result)</td>
<td>456</td>
</tr>
<tr>
<td>Table 368</td>
<td>CRC Revision ID Register (rev_id)</td>
<td>456</td>
</tr>
<tr>
<td>Table 370</td>
<td>I2C Control Register (IC_CON)</td>
<td>459</td>
</tr>
<tr>
<td>Table 371</td>
<td>I2C Target Address Register (IC_TAR)</td>
<td>461</td>
</tr>
<tr>
<td>Table 372</td>
<td>I2C Slave Address Register (IC_SAR)</td>
<td>462</td>
</tr>
<tr>
<td>Table 373</td>
<td>I2C High Speed Master Mode Code Address Register (IC_HS_MADDR)</td>
<td>462</td>
</tr>
<tr>
<td>Table 374</td>
<td>I2C Rx/Tx Data Buffer and Command Register (IC_DATA_CMD)</td>
<td>463</td>
</tr>
<tr>
<td>Table 375</td>
<td>Name: Standard Speed I2C Clock SCL High Count Register (IC_SS_SCL_HCNT)</td>
<td>463</td>
</tr>
<tr>
<td>Table 376</td>
<td>Name: Standard Speed I2C Clock SCL Low Count Register (IC_SS_SCL_LCNT)</td>
<td>464</td>
</tr>
<tr>
<td>Table 377</td>
<td>Name: Fast Speed I2C Clock SCL High Count Register (IC_FS_SCL_HCNT)</td>
<td>465</td>
</tr>
<tr>
<td>Table 378</td>
<td>Fast Speed I2C Clock SCL Low Count Register (IC_FS_SCL_LCNT)</td>
<td>466</td>
</tr>
<tr>
<td>Table 379</td>
<td>High Speed I2C Clock SCL High Count Register (IC_HS_SCL_HCNT)</td>
<td>466</td>
</tr>
<tr>
<td>Table 380</td>
<td>High Speed I2C Clock SCL Low Count Register (IC_HS_SCL_LCNT)</td>
<td>467</td>
</tr>
<tr>
<td>Table 381</td>
<td>I2C Interrupt Status Register (IC_INTR_STAT)</td>
<td>468</td>
</tr>
<tr>
<td>Table 382</td>
<td>I2C Interrupt Mask Register (IC_INTR_MASK)</td>
<td>470</td>
</tr>
<tr>
<td>Table 383</td>
<td>I2C Raw Interrupt Status Register (IC_RAW_INTR_STAT)</td>
<td>472</td>
</tr>
<tr>
<td>Table 384</td>
<td>I2C Receive FIFO Threshold Register (IC_RX_TL)</td>
<td>474</td>
</tr>
<tr>
<td>Table 385</td>
<td>I2C Transmit FIFO Threshold Register (IC_TX_TL)</td>
<td>475</td>
</tr>
<tr>
<td>Table 386</td>
<td>Clear Combined and Individual Interrupt Register (IC_CLR_INTR)</td>
<td>475</td>
</tr>
<tr>
<td>Table 387</td>
<td>Clear RX_UNDER Interrupt Register (IC_CLR_RX_UNDER)</td>
<td>476</td>
</tr>
<tr>
<td>Table 388</td>
<td>Clear RX_OVER Interrupt Register (IC_CLR_RX_OVER)</td>
<td>476</td>
</tr>
<tr>
<td>Table 389</td>
<td>Clear TX_OVER Interrupt Register (IC_CLR_TX_OVER)</td>
<td>477</td>
</tr>
<tr>
<td>Table 390</td>
<td>Clear RD_REQ Interrupt Register (IC_CLR_RD_REQ)</td>
<td>477</td>
</tr>
<tr>
<td>Table 391</td>
<td>Clear TX_ABRT Interrupt Register (IC_CLR_TX_ABRT)</td>
<td>477</td>
</tr>
<tr>
<td>Table 392</td>
<td>Clear RX_DONE Interrupt Register (IC_CLR_RXDONE)</td>
<td>478</td>
</tr>
<tr>
<td>Table 393</td>
<td>Clear ACTIVITY Interrupt Register (IC_CLR_ACTIVITY)</td>
<td>478</td>
</tr>
<tr>
<td>Table</td>
<td>Description</td>
<td>Page</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
<td>------</td>
</tr>
<tr>
<td>394</td>
<td>Clear STOP_DET Interrupt Register (IC_CLR_STOP_DET)</td>
<td>479</td>
</tr>
<tr>
<td>395</td>
<td>Clear START_DET Interrupt Register (IC_CLR_START_DET)</td>
<td>479</td>
</tr>
<tr>
<td>396</td>
<td>Clear GEN_CALL Interrupt Register (IC_CLR_GEN_CALL)</td>
<td>479</td>
</tr>
<tr>
<td>397</td>
<td>I2C Enable Register (IC_ENABLE)</td>
<td>480</td>
</tr>
<tr>
<td>398</td>
<td>I2C Status Register (IC_STATUS)</td>
<td>480</td>
</tr>
<tr>
<td>399</td>
<td>I2C Transmit FIFO Level Register (IC_TXFLR)</td>
<td>482</td>
</tr>
<tr>
<td>400</td>
<td>I2C Receive FIFO Level Register (IC_RXFLR)</td>
<td>482</td>
</tr>
<tr>
<td>401</td>
<td>I2C SDA Hold Register (IC_SDA_HOLD)</td>
<td>483</td>
</tr>
<tr>
<td>402</td>
<td>I2C Transmit Abort Source Register (IC_TX_ABRT_SOURCE)</td>
<td>483</td>
</tr>
<tr>
<td>403</td>
<td>Generate Slave Data NACK Register (IC_SLV_DATA_NACK_ONLY)</td>
<td>485</td>
</tr>
<tr>
<td>404</td>
<td>DMA Control Register (IC_DMA_CR)</td>
<td>486</td>
</tr>
<tr>
<td>405</td>
<td>DMA Transmit Data Level Register (IC_DMA_TDLR)</td>
<td>487</td>
</tr>
<tr>
<td>406</td>
<td>I2C Receive Data Level Register (IC_DMA_RDLR)</td>
<td>487</td>
</tr>
<tr>
<td>407</td>
<td>I2C SDA Setup Register (IC_SDA_SETUP)</td>
<td>488</td>
</tr>
<tr>
<td>408</td>
<td>I2C ACK General Call Register (IC_ACK_GENERAL_CALL)</td>
<td>488</td>
</tr>
<tr>
<td>409</td>
<td>I2C Enable Status Register (IC_ENABLE_STATUS)</td>
<td>489</td>
</tr>
<tr>
<td>410</td>
<td>I2C SS and FS Spike Suppression Limit Register (IC_FS_SPKLEN)</td>
<td>490</td>
</tr>
<tr>
<td>411</td>
<td>I2C HS Spike Suppression Limit Register (IC_HS_SPKLEN)</td>
<td>490</td>
</tr>
<tr>
<td>412</td>
<td>Component Parameter Register 1 (IC_COMP_PARAM_1)</td>
<td>491</td>
</tr>
<tr>
<td>413</td>
<td>I2C Component Version Register (IC_COMP_VERSION)</td>
<td>493</td>
</tr>
<tr>
<td>414</td>
<td>I2C Component Type Register (IC_COMP_TYPE)</td>
<td>493</td>
</tr>
<tr>
<td>415</td>
<td>I2C Component Version Register</td>
<td>493</td>
</tr>
<tr>
<td>416</td>
<td>Serial Interface Control Register (Cntl)</td>
<td>494</td>
</tr>
<tr>
<td>417</td>
<td>Serial Interface Configuration Register (Conf)</td>
<td>496</td>
</tr>
<tr>
<td>418</td>
<td>Serial Interface Data Out Register (Dout)</td>
<td>498</td>
</tr>
<tr>
<td>419</td>
<td>Serial Interface Data Input Register (Din)</td>
<td>498</td>
</tr>
<tr>
<td>420</td>
<td>Serial Interface Instruction Register (Instr)</td>
<td>499</td>
</tr>
<tr>
<td>421</td>
<td>Serial Interface Address Register (Addr)</td>
<td>499</td>
</tr>
<tr>
<td>422</td>
<td>Serial Interface Read Mode Register (RdMode)</td>
<td>500</td>
</tr>
<tr>
<td>423</td>
<td>Serial Interface Header Count Register (HdrCnt)</td>
<td>500</td>
</tr>
<tr>
<td>424</td>
<td>Serial Interface Data Input Count Register (DInCnt)</td>
<td>501</td>
</tr>
<tr>
<td>425</td>
<td>Serial Interface Timing Register (Timing)</td>
<td>502</td>
</tr>
<tr>
<td>426</td>
<td>Serial Interface Configuration 2 Register (Conf2)</td>
<td>502</td>
</tr>
<tr>
<td>427</td>
<td>Serial Interface Interrupt Status Register (ISR)</td>
<td>504</td>
</tr>
<tr>
<td>428</td>
<td>Serial Interface Interrupt Mask Register (IMR)</td>
<td>505</td>
</tr>
<tr>
<td>429</td>
<td>Serial Interface Interrupt Raw Status Register (IRSR)</td>
<td>506</td>
</tr>
<tr>
<td>430</td>
<td>Serial Interface Interrupt Clear Register (ISC)</td>
<td>508</td>
</tr>
<tr>
<td>432</td>
<td>SSP Control Register 0 (SSCR0)</td>
<td>509</td>
</tr>
<tr>
<td>433</td>
<td>SSP Control Register 1 (SSCR1)</td>
<td>511</td>
</tr>
<tr>
<td>434</td>
<td>SSP Status Register (SSSR)</td>
<td>514</td>
</tr>
<tr>
<td>435</td>
<td>SSP Interrupt Test Register (SSTITR)</td>
<td>516</td>
</tr>
<tr>
<td>436</td>
<td>SSP Data Register (SSDR)</td>
<td>517</td>
</tr>
<tr>
<td>437</td>
<td>SSP Programmable Serial Protocol Register (SSPSP)</td>
<td>517</td>
</tr>
<tr>
<td>438</td>
<td>SSP TX Time Slot Active Register (SSTSA)</td>
<td>519</td>
</tr>
<tr>
<td>439</td>
<td>SSP RX Time Slot Active Register (SSRSA)</td>
<td>519</td>
</tr>
</tbody>
</table>
Table 440: SSP Time Slot Status Register (SSTSS)..........................................................520
Table 442: Receive Buffer Register (RBR)........................................................................522
Table 443: Transmit Holding Register (THR).....................................................................522
Table 444: Divisor Latch Low Byte Registers (DLL)..............................................................523
Table 445: Divisor Latch High Byte Registers (DLH)..............................................................524
Table 446: Interrupt Enable Register (IER)........................................................................524
Table 447: Interrupt Identification Register (IIR).................................................................525
Table 448: FIFO Control Register (FCR)..............................................................................526
Table 449: Line Control Register (LCR)................................................................................527
Table 450: Modem Control Register (MCR)........................................................................528
Table 451: Line Status Register (LSR)..................................................................................529
Table 452: Modem Status Register (MSR)...........................................................................530
Table 453: Scratchpad Register (SCR)..................................................................................530
Table 454: Infrared Selection Register (ISR)........................................................................530
Table 455: Receive FIFO Occupancy Register (RFOR)........................................................531
Table 456: Auto-Baud Control Register (ABR)......................................................................532
Table 457: Auto-Baud Count Register (ACR).......................................................................532
Table 459: GPIO Pin Level Register0 (GPIO_GPLR_REG0)..................................................534
Table 460: GPIO Pin Level Register1 (GPIO_GPLR_REG1).....................................................534
Table 461: GPIO Pin Direction Register0 (GPIO_GPDR_REG0).............................................535
Table 462: GPIO Pin Direction Register1 (GPIO_GPDR_REG1).............................................535
Table 463: GPIO Pin Output Set Register 0 (GPIO_GPSR_REG0).........................................535
Table 464: GPIO Pin Output Set Register 1 (GPIO_GPSR_REG1).........................................536
Table 465: GPIO Pin Output Clear Register 0 (GPIO_GPCR_REG0).......................................536
Table 466: GPIO Pin Output Clear Register 1 (GPIO_GPCR_REG1).......................................536
Table 467: GPIO Rising Edge Detect Enable Register 0 (GPIO_GRER_REG0)..................537
Table 468: GPIO Rising Edge Detect Enable Register 1 (GPIO_GRER_REG1)..................537
Table 469: GPIO Falling Edge Detect Enable Register 0 (GPIO_GFER_REG0)................537
Table 470: GPIO Falling Edge Detect Enable Register 1 (GPIO_GFER_REG1)................538
Table 471: GPIO Edge Detect Status Register 0 (GPIO_GEDR_REG0)...............................538
Table 472: GPIO Edge Detect Status Register 1 (GPIO_GEDR_REG1)...............................538
Table 473: GPIO Pin Bitwise Set Direction Register 0 (GPIO_GSDR_REG0)..................539
Table 474: GPIO Pin Bitwise Set Direction Register 1 (GPIO_GSDR_REG1)..................539
Table 475: GPIO Pin Bitwise Clear Direction Register 0 (GPIO_GCDR_REG0)................539
Table 476: GPIO Pin Bitwise Clear Direction Register 1 (GPIO_GCDR_REG1)................539
Table 477: GPIO Bitwise Set Rising Edge Detect Enable Register 0 (GPIO_GSRER_REG0)540
Table 478: GPIO Bitwise Set Rising Edge Detect Enable Register 1 (GPIO_GSRER_REG1)540
Table 479: GPIO Bitwise Clear Rising Edge Detect Enable Register 0 (GPIO_GCRER_REG0)541
Table 480: GPIO Bitwise Clear Rising Edge Detect Enable Register 1 (GPIO_GCRER_REG1)541
Table 481: GPIO Bitwise Set Falling Edge Detect Enable Register 0 (GPIO_GSFER_REG0)542
Table 482: GPIO Bitwise Set Falling Edge Detect Enable Register 1 (GPIO_GSFER_REG1)542
Table 483: GPIO Bitwise Clear Falling Edge Detect Enable Register 0 (GPIO_GCFER_REG0)542
Table 484: GPIO Bitwise Clear Falling Edge Detect Enable Register 1 (GPIO_GCFER_REG1)543
Table 485: GPIO Bitwise Mask of Edge Detect Status Register 0 (APMASK_REG0).........................543
<table>
<thead>
<tr>
<th>Table</th>
<th>Description</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>486</td>
<td>GPIO Bitwise Mask of Edge Detect Status Register 1 (APMASK_REG1)</td>
<td>543</td>
</tr>
<tr>
<td>488</td>
<td>Counter Enable Register (CNT_EN_REG)</td>
<td>546</td>
</tr>
<tr>
<td>489</td>
<td>Status Register (STS_REG)</td>
<td>547</td>
</tr>
<tr>
<td>490</td>
<td>Interrupt Register (INT_REG)</td>
<td>549</td>
</tr>
<tr>
<td>491</td>
<td>Interrupt Mask Register (INT_MSK_REG)</td>
<td>550</td>
</tr>
<tr>
<td>492</td>
<td>Counter Control Register (CNT_CNTL_REG)</td>
<td>552</td>
</tr>
<tr>
<td>493</td>
<td>Counter Value Register (CNT_VAL_REG)</td>
<td>552</td>
</tr>
<tr>
<td>494</td>
<td>Counter Upper Value Register (CNT_UPP_VAL_REG)</td>
<td>553</td>
</tr>
<tr>
<td>495</td>
<td>Clock Control Register (CLK_CNTL_REG)</td>
<td>553</td>
</tr>
<tr>
<td>496</td>
<td>Input Capture Control Register (IC_CNTL_REG)</td>
<td>554</td>
</tr>
<tr>
<td>497</td>
<td>DMA Control Enable Register (DMA_CNTL_EN_REG)</td>
<td>555</td>
</tr>
<tr>
<td>498</td>
<td>DMA Control Channel Register (DMA_CNTL_CH_REG)</td>
<td>555</td>
</tr>
<tr>
<td>499</td>
<td>ADC Trigger Control Register (ADCT_REG)</td>
<td>556</td>
</tr>
<tr>
<td>500</td>
<td>ADC Trigger Delay Register (ADCT_DLY_REG)</td>
<td>556</td>
</tr>
<tr>
<td>501</td>
<td>User Request Register (USER_REQ_REG)</td>
<td>557</td>
</tr>
<tr>
<td>502</td>
<td>Channel X Control Register (CHx_CNTL_REG)</td>
<td>559</td>
</tr>
<tr>
<td>503</td>
<td>Channel Counter Match Register 0 (CHx_CMR0_REG)</td>
<td>560</td>
</tr>
<tr>
<td>504</td>
<td>Channel Status Register 0 (CHx_STS_REG)</td>
<td>560</td>
</tr>
<tr>
<td>505</td>
<td>Channel Counter Match Register 1 (CHx_CMR1_REG)</td>
<td>561</td>
</tr>
<tr>
<td>507</td>
<td>Control Register (ctrl)</td>
<td>562</td>
</tr>
<tr>
<td>508</td>
<td>Status Register (status)</td>
<td>563</td>
</tr>
<tr>
<td>509</td>
<td>Interrupt Status Register (isr)</td>
<td>563</td>
</tr>
<tr>
<td>510</td>
<td>Interrupt Mask Register (imr)</td>
<td>564</td>
</tr>
<tr>
<td>511</td>
<td>Interrupt Raw Status Register (irsr)</td>
<td>564</td>
</tr>
<tr>
<td>512</td>
<td>Interrupt Clear Register (icr)</td>
<td>565</td>
</tr>
<tr>
<td>513</td>
<td>Clock Register (clk)</td>
<td>565</td>
</tr>
<tr>
<td>514</td>
<td>Soft Reset Register (rst)</td>
<td>566</td>
</tr>
<tr>
<td>516</td>
<td>ADC Command Register (adc_reg_cmd)</td>
<td>568</td>
</tr>
<tr>
<td>517</td>
<td>ADC General Register (adc_reg_general)</td>
<td>568</td>
</tr>
<tr>
<td>518</td>
<td>ADC Configuration Register (adc_reg_config)</td>
<td>569</td>
</tr>
<tr>
<td>519</td>
<td>ADC Interval Register (adc_reg_interval)</td>
<td>571</td>
</tr>
<tr>
<td>520</td>
<td>ADC ANA Register (adc_reg_ana)</td>
<td>571</td>
</tr>
<tr>
<td>521</td>
<td>ADC Conversion Sequence 1 Register (adc_reg_scn1)</td>
<td>573</td>
</tr>
<tr>
<td>522</td>
<td>ADC Conversion Sequence 2 Register (adc_reg_scn2)</td>
<td>574</td>
</tr>
<tr>
<td>523</td>
<td>ADC Result Buffer Register (adc_reg_result_buf)</td>
<td>574</td>
</tr>
<tr>
<td>524</td>
<td>ADC DMAR Register (adc_reg_dmar)</td>
<td>575</td>
</tr>
<tr>
<td>525</td>
<td>ADC Status Register (adc_reg_status)</td>
<td>575</td>
</tr>
<tr>
<td>526</td>
<td>ADC ISR Register (adc_reg_isr)</td>
<td>576</td>
</tr>
<tr>
<td>527</td>
<td>ADC IMR Register (adc_reg_imr)</td>
<td>576</td>
</tr>
<tr>
<td>528</td>
<td>ADC IRR Register (adc_reg_irr)</td>
<td>577</td>
</tr>
<tr>
<td>529</td>
<td>ADC ICR Register (adc_reg_icr)</td>
<td>578</td>
</tr>
<tr>
<td>530</td>
<td>ADC Result Register (adc_reg_result)</td>
<td>579</td>
</tr>
<tr>
<td>531</td>
<td>ADC Raw Result Register (adc_reg_raw_result)</td>
<td>579</td>
</tr>
<tr>
<td>532</td>
<td>ADC Offset Calibration Register (adc_reg_offset_cal)</td>
<td>579</td>
</tr>
<tr>
<td>Table</td>
<td>Description</td>
<td></td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
<td></td>
</tr>
<tr>
<td>533</td>
<td>ADC Gain Calibration Register (adc_reg_gain_cal)</td>
<td></td>
</tr>
<tr>
<td>534</td>
<td>ADC Test Register (adc_reg_test)</td>
<td></td>
</tr>
<tr>
<td>535</td>
<td>ADC Audio Register (adc_reg_audio)</td>
<td></td>
</tr>
<tr>
<td>536</td>
<td>ADC Voice Detect Register (adc_reg_voice_det)</td>
<td></td>
</tr>
<tr>
<td>537</td>
<td>ADC Reserved Register (adc_reg_rsvd)</td>
<td></td>
</tr>
<tr>
<td>539</td>
<td>DAC Control Register (ctrl)</td>
<td></td>
</tr>
<tr>
<td>540</td>
<td>DAC Status Register (status)</td>
<td></td>
</tr>
<tr>
<td>541</td>
<td>Channel A Control Register (actrl)</td>
<td></td>
</tr>
<tr>
<td>542</td>
<td>Channel B Control Register (bctrl)</td>
<td></td>
</tr>
<tr>
<td>543</td>
<td>Channel A Data Register (adata)</td>
<td></td>
</tr>
<tr>
<td>544</td>
<td>Channel B Data Register (bdata)</td>
<td></td>
</tr>
<tr>
<td>545</td>
<td>Interrupt Status Register (isr)</td>
<td></td>
</tr>
<tr>
<td>546</td>
<td>Interrupt Mask Register (imr)</td>
<td></td>
</tr>
<tr>
<td>547</td>
<td>Interrupt Raw Status Register (isrr)</td>
<td></td>
</tr>
<tr>
<td>548</td>
<td>Interrupt Clear Register (icr)</td>
<td></td>
</tr>
<tr>
<td>549</td>
<td>Clock Register (clk)</td>
<td></td>
</tr>
<tr>
<td>550</td>
<td>Soft Reset Register (rst)</td>
<td></td>
</tr>
<tr>
<td>552</td>
<td>ACOMP0 Control Register (ctrl0)</td>
<td></td>
</tr>
<tr>
<td>553</td>
<td>ACOMP1 Control Register (ctrl1)</td>
<td></td>
</tr>
<tr>
<td>554</td>
<td>ACOMP0 Status Register (status0)</td>
<td></td>
</tr>
<tr>
<td>555</td>
<td>ACOMP1 Status Register (status1)</td>
<td></td>
</tr>
<tr>
<td>556</td>
<td>ACOMP0 Route Register (route0)</td>
<td></td>
</tr>
<tr>
<td>557</td>
<td>ACOMP1 Route Register (route1)</td>
<td></td>
</tr>
<tr>
<td>558</td>
<td>ACOMP0 Interrupt Status Register (isr0)</td>
<td></td>
</tr>
<tr>
<td>559</td>
<td>ACOMP1 Interrupt Status Register (isr1)</td>
<td></td>
</tr>
<tr>
<td>560</td>
<td>ACOMP0 Interrupt Mask Register (imr0)</td>
<td></td>
</tr>
<tr>
<td>561</td>
<td>ACOMP1 Interrupt Mask Register (imr1)</td>
<td></td>
</tr>
<tr>
<td>562</td>
<td>ACOMP0 Interrupt Raw Status Register (isrr0)</td>
<td></td>
</tr>
<tr>
<td>563</td>
<td>ACOMP1 Interrupt Raw Status Register (isrr1)</td>
<td></td>
</tr>
<tr>
<td>564</td>
<td>ACOMP0 Interrupt Clear Register (icr0)</td>
<td></td>
</tr>
<tr>
<td>565</td>
<td>ACOMP1 Interrupt Clear Register (icr1)</td>
<td></td>
</tr>
<tr>
<td>566</td>
<td>ACOMP0 Soft Reset Register (rst0)</td>
<td></td>
</tr>
<tr>
<td>567</td>
<td>ACOMP1 Soft Reset Register (rst1)</td>
<td></td>
</tr>
<tr>
<td>568</td>
<td>Clock Register (clk)</td>
<td></td>
</tr>
<tr>
<td>570</td>
<td>Padrng Pin Registers (_GPIO)</td>
<td></td>
</tr>
<tr>
<td>572</td>
<td>WDT Control Register (WDT_CR)</td>
<td></td>
</tr>
<tr>
<td>573</td>
<td>WDT Timeout Range Register (WDT_TORR)</td>
<td></td>
</tr>
<tr>
<td>574</td>
<td>WDT Current Counter Value Register (WDT_CCVR)</td>
<td></td>
</tr>
<tr>
<td>575</td>
<td>WDT Counter Restart Register (WDT_CRR)</td>
<td></td>
</tr>
<tr>
<td>576</td>
<td>WDT Interrupt Status Register (WDT_STAT)</td>
<td></td>
</tr>
<tr>
<td>577</td>
<td>WDT Interrupt Clear Register (WDT_EOI)</td>
<td></td>
</tr>
<tr>
<td>578</td>
<td>WDT Component Parameters Register 5 (WDT_COMP_PARAM_5)</td>
<td></td>
</tr>
<tr>
<td>579</td>
<td>WDT Component Parameters Register 4 (WDT_COMP_PARAM_4)</td>
<td></td>
</tr>
<tr>
<td>580</td>
<td>WDT Component Parameters Register 3 (WDT_COMP_PARAM_3)</td>
<td></td>
</tr>
<tr>
<td>Table</td>
<td>Description</td>
<td>Page</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
<td>------</td>
</tr>
<tr>
<td>Table 581</td>
<td>WDT Component Parameters Register 2 (WDT_COMP_PARAM_2)</td>
<td>613</td>
</tr>
<tr>
<td>Table 582</td>
<td>WDT Component Parameters Register 1 (WDT_COMP_PARAM_1)</td>
<td>613</td>
</tr>
<tr>
<td>Table 583</td>
<td>WDT Component Version Register (WDT_COMP_VERSION)</td>
<td>614</td>
</tr>
<tr>
<td>Table 584</td>
<td>WDT Component Type Register (WDT_COMP_TYPE)</td>
<td>615</td>
</tr>
<tr>
<td>Table 586</td>
<td>Counter Enable Register (CNT_EN_REG)</td>
<td>616</td>
</tr>
<tr>
<td>Table 587</td>
<td>Interrupt Raw Register (INT_RAW_REG)</td>
<td>617</td>
</tr>
<tr>
<td>Table 588</td>
<td>Interrupt Register (INT_REG)</td>
<td>618</td>
</tr>
<tr>
<td>Table 589</td>
<td>Interrupt Mask Register (INT_MSK_REG)</td>
<td>618</td>
</tr>
<tr>
<td>Table 590</td>
<td>Counter Control Register (CNT_CNTL_REG)</td>
<td>619</td>
</tr>
<tr>
<td>Table 591</td>
<td>Counter Value Register (CNT_VAL_REG)</td>
<td>620</td>
</tr>
<tr>
<td>Table 592</td>
<td>Counter Upper Value Register (CNT_UPP_VAL_REG)</td>
<td>620</td>
</tr>
<tr>
<td>Table 593</td>
<td>Counter Alarm Value Register (CNT_ALARM_VAL_REG)</td>
<td>621</td>
</tr>
<tr>
<td>Table 594</td>
<td>Clock Control Register (CLK_CNTL_REG)</td>
<td>621</td>
</tr>
<tr>
<td>Table 596</td>
<td>Power Mode Control Register (PWR_MODE)</td>
<td>624</td>
</tr>
<tr>
<td>Table 597</td>
<td>BOOT_JTAG Register (BOOT_JTAG)</td>
<td>624</td>
</tr>
<tr>
<td>Table 598</td>
<td>Last Reset Cause Register (LAST_RST_CAUSE)</td>
<td>625</td>
</tr>
<tr>
<td>Table 599</td>
<td>Last Reset Cause Clear Register (LAST_RST_CLR)</td>
<td>625</td>
</tr>
<tr>
<td>Table 600</td>
<td>Wake-up Source Clear Register (WAKE_SRC_CLR)</td>
<td>626</td>
</tr>
<tr>
<td>Table 601</td>
<td>Power Mode Status Register (PWR_MODE_STATUS)</td>
<td>627</td>
</tr>
<tr>
<td>Table 602</td>
<td>Clock Source Selection Register (CLK_SRC)</td>
<td>627</td>
</tr>
<tr>
<td>Table 603</td>
<td>Wakeup Status Register (WAKEUP_STATUS)</td>
<td>627</td>
</tr>
<tr>
<td>Table 604</td>
<td>PMIP Brown Interrupt Select (PMIP_BRN_INT_SEL)</td>
<td>628</td>
</tr>
<tr>
<td>Table 605</td>
<td>Clock Ready Register (CLK_RDY)</td>
<td>628</td>
</tr>
<tr>
<td>Table 606</td>
<td>RC 32M Control Register (RC32M_CTRL)</td>
<td>629</td>
</tr>
<tr>
<td>Table 607</td>
<td>SFLL Control Register 1 (SFLL_CTRL1)</td>
<td>630</td>
</tr>
<tr>
<td>Table 608</td>
<td>Analog Group Control Register (ANA_GRP_CTRL0)</td>
<td>630</td>
</tr>
<tr>
<td>Table 609</td>
<td>SFLL Control Register 2 (SFLL_CTRL0)</td>
<td>631</td>
</tr>
<tr>
<td>Table 610</td>
<td>Power Configuration Register (PWR_CFG)</td>
<td>632</td>
</tr>
<tr>
<td>Table 611</td>
<td>Power Status Register (PWR_STAT)</td>
<td>632</td>
</tr>
<tr>
<td>Table 612</td>
<td>WF OPT Power-Saving Register 0 (WF_OPT0)</td>
<td>632</td>
</tr>
<tr>
<td>Table 613</td>
<td>WF OPT Power-Saving Register 1 (WF_OPT1)</td>
<td>633</td>
</tr>
<tr>
<td>Table 614</td>
<td>Brown-out Configuration Register (PMIP_BRN_CFG)</td>
<td>633</td>
</tr>
<tr>
<td>Table 615</td>
<td>AUPLL Lock Status Register (AUPLL_LOCK)</td>
<td>634</td>
</tr>
<tr>
<td>Table 616</td>
<td>BG Control Register (ANA_GRP_CTRL1)</td>
<td>634</td>
</tr>
<tr>
<td>Table 617</td>
<td>Power Configuration Register (PMIP_PWR_CONFIG)</td>
<td>635</td>
</tr>
<tr>
<td>Table 618</td>
<td>PMIP Test Register (PMIP_TEST)</td>
<td>635</td>
</tr>
<tr>
<td>Table 619</td>
<td>Audio PLL Control Register (AUPLL_CTRL0)</td>
<td>636</td>
</tr>
<tr>
<td>Table 620</td>
<td>Peripheral Clock Enable Register (PERI_CLK_EN)</td>
<td>636</td>
</tr>
<tr>
<td>Table 621</td>
<td>UART Fast Clock Div Register (UART_FAST_CLK_DIV)</td>
<td>638</td>
</tr>
<tr>
<td>Table 622</td>
<td>UART Slow Clock Div Register (UART_SLOW_CLK_DIV)</td>
<td>638</td>
</tr>
<tr>
<td>Table 623</td>
<td>UART Clock Select Register (UART_CLK_SEL)</td>
<td>639</td>
</tr>
<tr>
<td>Table 624</td>
<td>MCU CORE Clock Divider Ratio Register (MCU_CORE_CLK_DIV)</td>
<td>640</td>
</tr>
<tr>
<td>Table 625</td>
<td>Peripheral0 Clock Divider Ratio Register (PERI0_CLK_DIV)</td>
<td>640</td>
</tr>
<tr>
<td>Table 626</td>
<td>Peripheral1 Clock Divider Ratio Register (PERI1_CLK_DIV)</td>
<td>640</td>
</tr>
</tbody>
</table>
Table 627: Peripheral2 Clock Divider Ratio Register (PERI2_CLK_DIV) ................................................................. 641
Table 628: Select Signal for GAU MCLK Register (GAU_CLK_SEL) ................................................................. 642
Table 629: Low Power Control in PM3/PM4 Mode Register (LOW_PWR_CTRL) ................................................................. 643
Table 630: I/O Pad Power Configuration Register (IO_PAD_PWR_CFG) ................................................................. 643
Table 631: Extra Interrupt Select Register 0 (EXT_SEL_REG0) ........................................................................... 645
Table 632: USB and Audio PLL Control Register (AUPLL_CTRL1) ................................................................. 647
Table 633: GAU Control Register (GAU_CTRL) ...................................................................................................... 648
Table 634: RC32k Control 0 Register (RC32K_CTRL0) ................................................................................ 649
Table 635: RC32k Control 1 Register (RC32K_CTRL1) ................................................................................ 649
Table 636: XTAL32k Control Register (XTAL32K_CTRL) ................................................................................ 650
Table 637: PMIP Comparator Control Register (PMIP_CMP_CTRL) ........................................................................ 651
Table 638: PMIP Brown-out AV18 Register (PMIP_BRNDT_AV18) ........................................................................ 652
Table 639: PMIP Brown-out VBAT Register (PMIP_BRNDT_VBAT) ........................................................................ 653
Table 640: PMIP Brown-out V12 Register (PMIP_BRNDT_V12) ........................................................................ 653
Table 641: PMIP LDO Control Register (PMIP_LDO_CTRL) ........................................................................... 654
Table 642: PERI Clock Source Register (PERI_CLK_SRC) ........................................................................... 655
Table 643: Unused Register (PMIP_RSVD) ........................................................................................................ 655
Table 644: GPT0 Control Register (GPT0_CTRL) ............................................................................................... 656
Table 645: GPT1 Control Register (GPT1_CTRL) ............................................................................................... 656
Table 646: GPT2 Control Register (GPT2_CTRL) ............................................................................................... 657
Table 647: GPT3 Control Register (GPT3_CTRL) ............................................................................................... 657
Table 648: Wakeup Edge Detect Register (WAKEUP_EDGE_DETECT) .......................................................... 658
Table 649: AON Clock Control Register (AON_CLK_CTRL) ............................................................................ 658
Table 650: PERI3 Control Register (PERI3_CTRL) ............................................................................................ 659
Table 651: Wakeup Mask Interrupt Register (wakeup_mask) ............................................................................... 659
Table 652: WLAN Control Register (wlan Ctrl) ............................................................................................. 660
Table 653: WLAN Control 1 Register (wlan_ctr1) .......................................................................................... 661
Table 655: Chip Revision Register (REV_ID) .................................................................................................. 662
Table 656: RAM0 Control Register (RAM0) .................................................................................................... 663
Table 657: RAM1 Control Register (RAM1) .................................................................................................... 663
Table 658: RAM2 Control Register (RAM2) .................................................................................................... 664
Table 659: RAM3 Control Register (RAM3) .................................................................................................... 664
Table 660: ROM Control Register (ROM) ........................................................................................................ 664
Table 661: AON_MEM Control Register (AON_MEM) ................................................................................... 665
Table 662: GPT Pin-in Selection Register (GPT_in) .......................................................................................... 665
Table 663: Calibration Channel Selection Register (CAL) .............................................................................. 665
Table 664: Peripheral Software Reset Register (PERI_SW_RST) ................................................................. 666
Table 665: USB Control Register (USB_CTRL) .............................................................................................. 667

25 Acronyms and Abbreviation ................................................. 669

Table 666: Acronyms and Abbreviations ................................................. 669

26 Revision History ........................................................................ 672

Table 667: Revision History ........................................................................ 672

27 Legal Information ........................................................................ 673
List of Figures

Product Overview ..................................................1
Figure 1: Block Diagram ...........................................2

1 Package ...............................................................6
Figure 2: Signal Diagram ..........................................6
Figure 3: Pinout—68-Pin QFN ...................................7
Figure 4: Pinout—88-Pin QFN ...................................8
Figure 5: Mechanical Drawing—68-Pin QFN .............9
Figure 6: Mechanical Drawing—88-Pin QFN ..........10

2 Core and System Control .................................34
Figure 7: System Memory Map Diagram .................37
Figure 8: Bus Matrix Interconnection .....................45

3 Power, Reset, and Clock Control ....................46
Figure 9: Power Supply Blocks .............................46
Figure 10: Power Option .........................................47
Figure 11: Power-Up Sequence ................................48
Figure 12: Power Mode Transitions ......................56
Figure 13: High-Level Clocking Diagram ..............61

4 Boot ROM ..........................................................67
Figure 14: Boot ROM Flow, POR Reset .................72
Figure 15: Boot ROM Flow, Code Loading ..............73
Figure 16: Boot ROM Flow, QSPI Loading .............74
Figure 17: Boot ROM Flow, Boot Mode Confirmed to be QSPI Loading ..........................75
Figure 18: Boot ROM Flow, Normal Boot ............76
Figure 19: Boot ROM Flow, System Exception .......76
Figure 20: Boot ROM Flow, UART Loading ..........77
Figure 21: Boot ROM Flow, USB Loading as Slave ....78
Figure 22: Boot ROM Flow, USB Loading as Host ...79
Figure 23: Code Image Memory Mapping .............81
Figure 24: Detection and Detection Acknowledgment Packets .................................................91
Figure 25: Security/Erase and Acknowledgment Packets .........................................................92
Figure 26: Header Request and Acknowledgment Packet .........................................................92
Figure 27: Data Header Packet ...............................93
Figure 28: Data Packet ...........................................93
Figure 29: Entry Address Header Packet ..............94
Figure 30: Flash Boot Mode, Timing ....................98

5 Flash Controller ..................................................104
Figure 31: Flash Controller Block Diagram .........105

6 General Purpose Input Output (GPIO) ..........108
Figure 32: I/O Padding Structure ........................123
Figure 33: General Purpose I/O Block Diagram ....124

7 WLAN ...............................................................127
Figure 34: DMA Internal Signals .........................132
Figure 35: Hardware Handshaking Interface ........137
Figure 36: Burst Transaction – hclk=2*per_clk ....138
Figure 37: Back-to-Back Burst Transaction – hclk=2*per_clk ..................................................139
Figure 38: Single Transaction – hclk=2*per_clk ...140
Figure 39: Burst Followed by Back-to-Back Single Transactions ..............................................141

8 Direct Memory Access (DMA) Controller ......130
Figure 34: DMA Internal Signals .........................132
Figure 35: Hardware Handshaking Interface ........137

9 Real Time Clock (RTC) .................................144
Figure 40: RTC Block Diagram ..........................144
Figure 41: Count-up Mode Timing .......................145

10 Watchdog Timer (WDT) ..................................147
Figure 42: Interrupt Generation ........................148
Figure 43: Counter Restart and System Reset ....148

11 General Purpose Timers (GPT) .................150
Figure 44: GPT Block Diagram ..........................151
Figure 45: Clock Source Selection ....................152
Figure 46: Count-up Mode Timing .......................153
Figure 47: Input Capture Timing .........................155
Figure 48: 1-Shot Pulse .........................................156
Figure 49: 1-Shot Edge Timing ........................157
Figure 50: PWM Edge-Aligned .........................158
Figure 51: PWM Center-Aligned .......................160
Figure 52: ADC Trigger for PWM Edge-Aligned and Center-Aligned ..................................161
Figure 53: DAC Trigger for PWM Edge-Aligned and Center-Aligned ..................................162

12 Advanced Encryption Standard (AES) .......164
Figure 54: AES Operational Flow .....................165

13 Cyclic Redundancy Check (CRC) ..............170
14 Universal Asynchronous Receiver Transmitter (UART) ......................................................... 172
Figure 55: UART Block Diagram .................................. 175
Figure 56: Serial Data Format .................................. 176
Figure 57: Example NRZ Bit Encoding – 0b0100_1011 ......................................................... 177
Figure 58: IR Transmit and Receive Example .......... 179
Figure 59: XMODE Example .................................. 180
Figure 60: Burst Transaction – hclk=2*per_clk ...... 183
Figure 61: Signal Transaction – hclk=2*per_clk ... 184
Figure 62: Burst Followed by Back-to-Back Single Transactions .......................................... 185
Figure 63: Hardware Flow Control............................ 186

15 Inter-Integrated Circuit (I2C) .......................... 190
Figure 64: I2C Block Diagram................................. 191
Figure 65: Master/Slave and Transmitter/Receiver Relationship ........................................... 192
Figure 66: Data Transfer on the I2C Bus................. 193
Figure 67: START and STOP Condition .................. 195
Figure 68: 7-Bit Address Format............................. 195
Figure 69: 10-Bit Address Format............................ 196
Figure 70: Master-Transmitter Protocol............... 196
Figure 71: Master-Receive Protocol......................... 197
Figure 72: Multiple Master Arbitration.................... 198
Figure 73: Multi-Master Clock Synchronization ..... 198

16 Synchronous Serial Protocol (SSP) .................. 205
Figure 74: Burst Transaction, hclk = pclk ............ 209
Figure 75: Burst Transaction, hclk = 2*pclk .......... 209
Figure 76: Burst Transaction, +3 Back-to-Back Singles **C hclk = 2*pclk ......................... 210
Figure 77: Texas Instruments Synchronous Serial Frame Protocol (Single Transfers)........ 213
Figure 78: Texas Instruments Synchronous Serial Frame Protocol (Multiple Transfers) .... 214
Figure 79: Motorola SPI Frame Protocol (Single Transfers) ............................................. 215
Figure 80: Motorola SPI Frame Protocol (Multiple Transfers) ............................................ 215
Figure 81: Motorola SPI Frame Protocols for SPO and SPH Programming (SPH Set) ... 216
Figure 82: Motorola SPI Frame Protocols for SPO and SPH Programming (SPH Cleared) ... 216
Figure 83: Programmable Serial Protocol Format 219
Figure 84: Programmable Protocol Format (Consecutive Transfers) .................................. 219

17 USB OTG Interface Controller (USBC) .............. 227
Figure 94: USB Controller Block Diagram .......... 228
Figure 95: End Point Queue Head Organization ... 230
Figure 96: Periodic Schedule Organization ....... 230

18 Quad Serial Peripheral Interface (QSPI) Control- ler ..................................................... 237
Figure 97: QSPI Controller Block Diagram .......... 238
Figure 98: Frame of Data Format for Serial Flash Access .................................................. 239
Figure 99: Non-DMA Mode Read Flow ............... 241
Figure 100: Non-DMA Mode Write Flow .......... 242
Figure 101: DMA Mode Read Flow ...................... 243
Figure 102: DMA Mode Write Flow ................. 244

19 Analog Digital Converter (ADC) .................... 246
Figure 103: ADC Block Diagram ......................... 248
Figure 104: ADC Temperature Sensor Mode with External Diode .................................. 251

20 Digital Analog Converter (DAC) .................... 257
Figure 105: Synchronous Mode ......................... 259
Figure 106: Sinusoidal Waveform Generation .... 259
Figure 107: Full Triangle Generation Mode ....... 260
Figure 108: Half Triangle Generation Mode ..... 260

21 Analog Comparator (ACOMP) ....................... 262
Figure 109: Comparator Hysteresis ..................... 264
Figure 110: Comparator Output Edge Detection .. 266
Figure 111: Interrupt .............................................267

22Electrical Specifications ...............................269
Figure 112: BUCK18_VBAT_IN = 2.7V Efficiency vs. Current .............................................277
Figure 113: SSP Serial Frame Format Timing Diagram ............................................................294
Figure 114: QSPI Timing Diagram (Normal) .......295
Figure 115: QSPI Timing Diagram (Use Second Clock Capture Edge) ........................................295
Figure 116: USB Timing Diagram .........................296

23Ordering Information/Package Marking .....301
Figure 117: Part Numbering Scheme ..................301
Figure 118: Package Marking and Pin 1 Location—88MW320 .........................................................302
Figure 119: Package Marking and Pin 1 Location—88MW322 .........................................................302

2488MW320/322 Register Set ...........................303
25Acronyms and Abbreviation .........................669
26Revision History ............................................672
27Legal Information ...........................................673
# Table of Contents

**1 Package** .................................................. 6

1.1 Signal Diagram ........................................... 6

1.2 Pinout .................................................... 7

1.2.1 Pinout—68-Pin QFN .................................. 7

1.2.2 Pinout—88-Pin QFN .................................... 8

1.3 Mechanical Drawing ...................................... 9

1.3.1 Mechanical Drawing—68-Pin QFN .................. 9

1.3.2 Mechanical Drawing—88-Pin QFN .................. 10

1.4 Pin Description .......................................... 11

1.5 Configuration Pins ...................................... 33

**2 Core and System Control** ............................ 34

2.1 Overview ................................................. 34

2.2 Cortex-M4F Core ......................................... 34

2.2.1 Features ............................................... 34

2.2.2 Memory Protection Unit (MPU) ................. 34

2.2.3 Nested Vectored Interrupt Controller (NVIC) 35

2.2.4 SysTick Timer ........................................ 35

2.3 System Control .......................................... 35

2.4 Memory Map ............................................ 36

2.5 External Interrupts ..................................... 41

2.5.1 Interrupts Accepted .................................. 41

2.5.2 GPIO Mapping of Interrupts ..................... 43

2.6 AHB Bus Fabric ......................................... 45

2.7 Register Bus Fabric .................................... 45

**3 Power, Reset, and Clock Control** ................. 46

3.1 Overview ................................................. 46

3.2 Power .................................................... 46

3.2.1 Power Supplies ...................................... 46

3.2.2 Power Domains ....................................... 49

3.2.3 I/O Power Configuration .......................... 50

3.2.4 AON Domain .......................................... 51

3.3 Power Modes ............................................. 52

3.3.1 System Power Modes ................................ 52

3.3.2 MCI Subsystem Power Modes ..................... 53

3.3.3 WLAN Power States ................................ 56

3.3.4 Core and SRAM Power States ..................... 57

3.4 Reset/Wake-up Sources ................................ 58

3.4.1 Wake-up from PM1 Mode ......................... 58

3.4.2 Wake-up from PM2/3/4 Modes .................... 58

3.4.3 Reset Controller .................................... 58

3.5 Clock Controller ........................................ 59

3.5.1 Overview ............................................. 59

3.5.2 Clock Sources ........................................ 60

3.5.3 SFLL .................................................... 62

3.5.4 Cortex-M4F Core Clock and Bus Clock ....... 63

3.5.5 UART Clocks .......................................... 64

3.5.6 AUPLL for Audio Clock and GAU Clock ....... 64

3.5.7 GAU Clock ............................................. 65

3.5.8 GPT Clock ............................................. 66

3.5.9 Clock Output ......................................... 66

3.6 Register Description .................................. 66

**4 Boot ROM** ................................................. 67

4.1 Overview ............................................... 67

4.2 Features ................................................. 67

4.2.1 Multiple Boot Sources ............................. 67

4.2.2 Secure Boot .......................................... 67

4.3 Boot Source Selection ................................ 68

4.4 OTP Content ............................................. 68

4.5 Data Format in AON Memory ....................... 69

4.6 Boot ROM Flow Charts .................................. 72

4.6.1 POR Reset ........................................... 72

4.6.2 Code Loading ........................................ 73

4.6.3 QSPI Loading ........................................ 74

4.6.4 Boot Mode Confirmed to be QSPI Loading .... 75

4.6.5 Normal Boot ......................................... 76

4.6.6 System Exception .................................... 76

4.6.7 UART Loading ........................................ 77

4.6.8 USB Slave Loading .................................. 78

4.6.9 USB Host Loading .................................. 79

4.7 Boot from QSPI Flash .................................. 80

4.7.1 Code Image .......................................... 80

4.7.2 Code Image Format .................................. 81

4.8 Boot from UART ......................................... 91

4.9 USB Disk ............................................... 95

4.9.1 Requirements ........................................ 95

4.9.2 Options ............................................... 95

4.9.3 Procedure ............................................ 95

4.10 USB DFU ............................................... 96

4.11 Fast Boot at Wake-up from PM3 Mode .......... 97

4.12 Additional Boot ROM Information ............... 97

4.12.1 Boot ROM GPIOs .................................. 97

4.12.2 Flash Requirements for Flash Boot Mode .... 98

4.12.3 Sample of Code Loading Through UART .... 101

**5 Flash Controller** .......................................... 104

5.1 Overview ............................................... 104

5.2 Interface ................................................. 104

5.3 Cache .................................................... 104

5.4 Functional Description ................................ 104
5.4.1 Block Diagram .............................................. 105
5.4.2 Modes ...................................................... 105
5.4.3 Programming Notes ........................................ 106
5.5 Register Description ........................................ 107
6 General Purpose Input Output (GPIO) .. 108
   6.1 Overview ................................................ 108
   6.2 I/O Configuration ........................................ 108
   6.2.1 PINMUX Alternate Functions .......................... 108
   6.2.2 I/O Padding Pin States ................................ 123
   6.3 Functional Description ................................... 124
   6.3.1 Block Diagram .......................................... 124
   6.3.2 GPIO Ports .............................................. 124
   6.3.3 I/O Control ............................................. 125
   6.3.4 GPIO Interrupt ........................................ 125
   6.3.5 External Interrupts ....................................... 126
   6.4 Register Description ....................................... 126
7 WLAN ............................................................ 127
   7.1 Overview ................................................ 127
   7.2 Features .................................................. 127
   7.3 WLAN MAC ................................................ 127
   7.4 WLAN Baseband .......................................... 128
   7.5 WLAN Radio .............................................. 128
   7.5.1 WLAN Rx Path .......................................... 128
   7.5.2 WLAN Tx Path .......................................... 128
   7.5.3 WLAN Local Oscillator ................................. 128
   7.5.4 Channel Frequencies Supported ...................... 129
   7.6 WLAN Encryption ......................................... 129
8 Direct Memory Access (DMA) Controller 130
   8.1 Overview ................................................ 130
   8.2 Features .................................................. 130
   8.3 Basic Definitions ......................................... 131
   8.4 Interface Signal Description ......................... 132
   8.4.1 Internal Signals Diagram ............................ 132
   8.4.2 Clock and Reset Interface ............................ 132
   8.4.3 Interface to Handshake Interface ................... 133
   8.4.4 DMA Interrupt Request Interface ................... 133
   8.4.5 AHB Slave Interface .................................. 133
   8.4.6 AHB Master Interface ................................ 134
   8.5 Functional Description .................................. 135
   8.5.1 32 Channels and Priorities ......................... 135
   8.5.2 Enable/Stop Channel .................................. 136
   8.5.3 Transfer Type and Flow Controller ................ 136
   8.5.4 Hardware Handshaking Interface .................... 136
   8.5.5 Interrupt Management ................................ 142
   8.5.6 Transfer Operation Example ......................... 142
   8.6 Register Description ..................................... 143
9 Real Time Clock (RTC) ......................... 144
   9.1 Overview ................................................ 144
   9.2 Features .................................................. 144
   9.3 Functional Description .................................. 144
   9.3.1 Block Diagram .......................................... 144
   9.3.2 Counter Clock .......................................... 144
   9.3.3 Counting Mode ........................................ 145
   9.3.4 Counter Update Mode .................................. 145
   9.3.5 Interrupt ............................................... 145
   9.4 Programming Notes ....................................... 146
   9.4.1 Initialization .......................................... 146
   9.4.2 UPP_VAL ................................................. 146
   9.5 Register Description ..................................... 146
10 Watchdog Timer (WDT) ......................... 147
   10.1 Overview ................................................ 147
   10.2 Features .................................................. 147
   10.3 Functional Description .................................. 147
   10.3.1Counter Operation ..................................... 147
   10.3.2Interrupt ............................................... 147
   10.3.3System Reset .......................................... 148
   10.3.4Reset Pulse Length .................................... 148
   10.4 Initialization Sequence ................................. 149
   10.5 Register Description ..................................... 149
11 General Purpose Timers (GPT) .............. 150
   11.1 Overview ................................................ 150
   11.2 Features .................................................. 150
   11.3 Interface Signal Description ....................... 150
   11.4 Functional Description .................................. 151
   11.4.1Block Diagram .......................................... 151
   11.4.2Counter ................................................. 152
   11.4.3Interrupts ............................................. 154
   11.4.4Channel Operation Modes ............................ 154
   11.4.5ADC Trigger ............................................ 161
   11.4.6DAC Trigger ............................................ 162
   11.5 Programming Notes ....................................... 163
   11.5.1Initialization .......................................... 163
   11.5.2UPP_VAL ................................................. 163
   11.5.3User Request Register ............................... 163
   11.6 Register Description ..................................... 163
12 Advanced Encryption Standard (AES) .. 164
   12.1 Overview ................................................ 164
   12.2 Features .................................................. 164
   12.3 Functional Description .................................. 165
   12.3.1AES Operational Flow ................................ 165
   12.3.2AES Configuration ..................................... 166
   12.3.3Data Access Method .................................... 166
24.6.2 CRC Registers ........................................ 453
24.7 I2C Address Block .................................. 457
24.7.1 I2C Register Map .................................. 457
24.7.2 I2C Registers ........................................ 458
24.8 QSPI Address Block .................................. 494
24.8.1 QSPI Register Map .................................. 494
24.8.2 QSPI Registers ........................................ 494
24.9 SSP Address Block ................................... 509
24.9.1 SSP Register Map .................................... 509
24.9.2 SSP Registers ......................................... 509
24.10 UART Address Block ................................ 522
24.10.1 UART Register Map .................................. 522
24.10.2 UART Registers ..................................... 522
24.11 GPIO Address Block .................................. 533
24.11.1 GPIO Register Map ................................... 533
24.11.2 GPIO Registers ...................................... 534
24.12 GPT Address Block ................................... 545
24.12.1 GPT Register Map .................................... 545
24.12.2 GPT Registers ....................................... 546
24.13 RC32 Address Block .................................. 562
24.13.1 RC32 Register Map ................................... 562
24.13.2 RC32 Registers ...................................... 562
24.14 ADC Address Block ................................... 567
24.14.1 ADC Register Map ................................... 567
24.14.2 ADC Registers ....................................... 568
24.15 DAC Address Block ................................... 583
24.15.1 DAC Register Map ................................... 583
24.15.2 DAC Registers ....................................... 583
24.16 ACOMP Address Block ................................ 592
24.16.1 ACOMP Register Map ................................ 592
24.16.2 ACOMP Registers ................................... 592
24.17 PINMUX Address Block .............................. 605
24.17.1 PINMUX Register Map .............................. 605
24.17.2 PINMUX Registers (_GPIO) ....................... 606
24.18 WDT Address Block .................................. 608
24.18.1 WDT Register Map ................................... 608
24.18.2 WDT Registers ....................................... 608
24.19 RTC Address Block ................................... 616
24.19.1 RTC Register Map ................................... 616
24.19.2 RTC Registers ....................................... 616
24.20 PMU Address Block ................................... 622
24.20.1 PMU Register Map ................................... 622
24.20.2 PMU Registers ....................................... 624
24.21 System Control Address Block .................... 662
24.21.1 System Control Register Map .................... 662
24.21.2 System Control Registers ......................... 662
25 Acronyms and Abbreviation ............................ 669
26 Revision History ........................................ 672
27 Legal Information ....................................... 673
27.1 Data sheet status ....................................... 673
27.2 Definitions .............................................. 673
27.3 Disclaimers ............................................. 673
27.4 Trademarks .............................................. 675
List of Tables ................................................. 676
List of Figures ............................................... 690
Table of Contents .......................................... 693